剑指数据仓库-Shell命令三

一、上次课程回顾

二、Linux基础命令三

三、作业

一、上次课程回顾

  • 博文连接:https://blog.csdn.net/SparkOnYarn/article/details/104793896

  • 未来部署大数据的组件一定要which一下,验证下是否生效,谨慎下没有问题;别名其实是为了简化操作;删除命令在工作中用的频率比较高,算是高危命令;history查看历史记录,也可以执行历史命令;

二、Linux基础命令二

2.1、用户和用户组

  1. 创建用户
1、关于用户、用户组的几种使用方式:增加、删除、修改
[root@hadoop001 sbin]# ll /usr/sbin/user*
-rwxr-x--- 1 root root 118192 Nov  6  2016 /usr/sbin/useradd
-rwxr-x--- 1 root root  80360 Nov  6  2016 /usr/sbin/userdel
-rwxr-x--- 1 root root 113840 Nov  6  2016 /usr/sbin/usermod
-rwsr-xr-x 1 root root  11296 Apr 13  2017 /usr/sbin/usernetctl
[root@hadoop001 sbin]# ll /usr/sbin/group*
-rwxr-x--- 1 root root 65480 Nov  6  2016 /usr/sbin/groupadd
-rwxr-x--- 1 root root 57016 Nov  6  2016 /usr/sbin/groupdel
-rwxr-x--- 1 root root 57064 Nov  6  2016 /usr/sbin/groupmems
-rwxr-x--- 1 root root 76424 Nov  6  2016 /usr/sbin/groupmod

2、我们创建一个用户为ruoze,默认创建这个名称的用户组ruoze,且设置这个用户的主组还是ruoze
[root@hadoop001 sbin]# useradd ruoze
[root@hadoop001 sbin]# id ruoze
uid=1001(ruoze) gid=1001(ruoze) groups=1001(ruoze)

//举例:老板的小姨子既属于财务部,又属于人力资源部;但是主要部门是财务部==》类比于财务部就是主组
  1. 用户和用户组的存储目录:
1、用户存储文件目录:
cat /etc/passwd

2、用户组存储文件目录:
cat /etc/group

3、创建的用户默认会在home目录下创建自己的目录:
[root@hadoop001 home]# ll
total 8
drwx------ 7 hadoop hadoop 4096 Mar 11 16:18 hadoop
drwx------ 2 ruoze  ruoze  4096 Mar 12 10:47 ruoze
权限			所属用户	所属用户组	文件夹大小不准	创建时间(ll -rt进行时间排序)
  1. 测试删除用户:

1、因为ruoze这个组中只有一个ruoze用户,所以在删除ruoze用户的时候会同时删除ruoze这个用户组,组中有其他成员的时候,ruoze这个组不会被删除

[root@hadoop001 home]# id ruoze
uid=1001(ruoze) gid=1001(ruoze) groups=1001(ruoze)
[root@hadoop001 home]# userdel ruoze
[root@hadoop001 home]# id ruoze
id: ruoze: no such user
[root@hadoop001 home]# cat /etc/passwd | grep ruoze 
[root@hadoop001 home]# cat /etc/group | grep ruoze
[root@hadoop001 home]# ll
total 8
drwx------ 7 hadoop hadoop 4096 Mar 11 16:18 hadoop
drwx------ 2   1001   1001 4096 Mar 12 10:47 ruoze
  1. 删除完ruoze用户后继续尝试添加用户,样式丢失后如何恢复
1、这段话的意思是home目录下的.bash文件已经存在,用户和用户组目录都已经存在了ruoze用户,
[root@hadoop001 home]# useradd ruoze
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
Creating mailbox file: File exists
[root@hadoop001 home]# cat /etc/passwd|grep ruoze
ruoze:x:1001:1001::/home/ruoze:/bin/bash
[root@hadoop001 home]# cat /etc/group | grep ruoze
ruoze:x:1001:

2、使用root用户切换到ruoze用户,删除.bash隐藏文件
[root@hadoop001 ~]# su - ruoze
[ruoze@hadoop001 ~]$ ll -a
total 20
drwx------  2 ruoze ruoze 4096 Mar 12 10:47 .
drwxr-xr-x. 4 root  root  4096 Mar 12 10:47 ..
-rw-r--r--  1 ruoze ruoze   18 Dec  7  2016 .bash_logout
-rw-r--r--  1 ruoze ruoze  193 Dec  7  2016 .bash_profile
-rw-r--r--  1 ruoze ruoze  231 Dec  7  2016 .bashrc
[ruoze@hadoop001 ~]$ rm -rf .bash*
[ruoze@hadoop001 ~]$ ll -a
total 8
drwx------  2 ruoze ruoze 4096 Mar 12 11:17 .
drwxr-xr-x. 4 root  root  4096 Mar 12 10:47 ..

3、删除完.bash隐藏文件后新开session,再切换到ruoze用户,发现样式丢失==>说白了就是丢失.bash文件
[root@hadoop001 ~]# su - ruoze
Last login: Thu Mar 12 11:17:05 CST 2020 on pts/1
-bash-4.2$ 
-bash-4.2$ 

4、样式丢失的话怎么办呢?
//拷贝这个目录下的文件到ruoze用户目录
[root@hadoop001 skel]# cp /etc/skel/.* /home/ruoze/
[root@hadoop001 skel]# chown -R ruoze:ruoze /home/ruoze/.bash*

//最简单的就是直接拷贝其它用户下的.bash文件到ruoze目录下,并且修改用户和用户组
  1. 增加用户组
1、增加bigdata用户组
groupadd bigdata

2、添加ruoze用户到bigdata用户组
[root@hadoop001 skel]# id ruoze
uid=1001(ruoze) gid=1001(ruoze) groups=1001(ruoze)
[root@hadoop001 skel]# usermod -a -G bigdata ruoze
[root@hadoop001 skel]# id ruoze
uid=1001(ruoze) gid=1001(ruoze) groups=1001(ruoze),1002(bigdata)

3、usermod --help查看命令帮助
Usage: usermod [options] LOGIN

-g, --gid GROUP               force use GROUP as new primary group
强制使用组作为新组

-G, --groups GROUPS           new list of supplementary GROUPS
新增补充组的名单

-a, --append                  append the user to the supplemental GROUPS
                                mentioned by the -G option without removing
                                him/her from other groups
将用户追加到补充组中,将-G选项中提到,但没有删除来自其它组的他 
  1. 需求:修改bigdata为ruoze用户的主组,同时ruoze用户也要在ruoze这个组中:
1、没有修改前,ruoze用户的组和主组是ruoze,还在bigdata组中
[ro[root@hadoop001 skel]# id ruoze
uid=1001(ruoze) gid=1001(ruoze) groups=1001(ruoze),1002(bigdata)

2、强制修改ruoze用户的组和主组
[root@hadoop001 skel]# usermod -g bigdata ruoze
[root@hadoop001 skel]# id ruoze
uid=1001(ruoze) gid=1002(bigdata) groups=1002(bigdata)

3、ruoze用户的主组是bigdata,把ruoze这个组另外加进去
[root@hadoop001 skel]# usermod -a -G ruoze ruoze
[root@hadoop001 skel]# id ruoze
uid=1001(ruoze) gid=1002(bigdata) groups=1002(bigdata),1001(ruoze)

2.2、为普通用户设置密码、给普通用户sudo权限

1、为用户设置密码,使用root用户来设置:

[root@hadoop001 skel]# passwd ruoze
Changing password for user ruoze.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@hadoop001 skel]# su - ruoze
Last login: Thu Mar 12 11:26:07 CST 2020 on pts/1

2、为普通用户设置密码主要是为了在远程连接的时候使用:

  • file --> quick connetc -->输入主机名

3、passwd后面不跟名称就是为当前用户修改密码

  • Changing password for ruoze.
    (current) UNIX password:

给普通用户root的最大权限并且无密码

 1、使用root用户,vi /etc/sudoers,编辑这个文件,找到如下行数在91行后添加如下信息:hadoop是我的用户,NOPASSWD:ALL意思是无需密码
 90 ## Allow root to run any commands anywhere(允许root用户在任何地方执行命令)
 91 root    ALL=(ALL)       ALL
 92 hadoop  ALL=(ALL)       NOPASSWD:ALL

2.3、su 和 su - 的区别

1、su 和su - 的区别

1、使用su的时候切换到ruoze用户还是在原用户的目录
[root@hadoop001 ~]# su ruoze
[ruoze@hadoop001 root]$ pwd
/root
[ruoze@hadoop001 root]$ exit;
exit

2、su - 的时候代表着切换的时候也在ruoze用户的家目录,且执行ruoze用户的环境变量文件
[root@hadoop001 ~]# su - ruoze
Last login: Thu Mar 12 11:56:52 CST 2020 on pts/2
[ruoze@hadoop001 ~]$ pwd
/home/ruoze

2、如何验证su - ruoze,会执行ruoze用户的环境变量,而su ruoze不会生效

此处验证到的一点是.bash_profile文件,su ruoze不会执行
.bashrc 对于su ruoze和su - ruoze都会执行
  • 得出的结论,我们以后切换用户要使用su - 用户,环境变量要配置在.bashrc这个配置文件中。

2.4、/etc/passwd的重点剖析

1、查看修改/etc/passwd文件内容:

1、查看文件的最后两行
ldap:x:55:55:OpenLDAP server:/var/lib/ldap:/sbin/nologin
ruoze:x:1001:1002::/home/ruoze:/bin/bash

2、修改/bin/bash为/bin/false和/sbin/nologin
修改为这两种以后都是不能登录的

2、生产环境讲解:

在CDH中有很多的组件:
hdfs组件有hdfs用户
hbase组件有hbase用户,
yarn组件有yarn用户;
存在的情况:切换用户切换不过去,只要对应的在/etc/passwd文件中修改最后一行内容为/bin/bash,这样才是没有问题的。

2.5、权限(chmod、chown)&& 案例演示

chmod -R 777 文件或者文件夹
chown -R 用户:用户组 文件或者文件夹

跟权限挂钩的错误:Permission denied

1、举例:
[root@hadoop001 hadoop]# ll
total 20
drwxrwxr-x 2 hadoop hadoop 4096 Mar  5 15:58 app

rwx 第一组权限之和为7,代表的是文件和文件夹的用户root,它对这个文件有读写执行的权限
rwx  第二组权限之和为7,代表文件或文件夹的用户组root,读写执行
r-x 第三组权限之和为5,代表其他组的所属用户对这个文件或文件夹的权限,具有读和执行的权限

chmod

d:directory目录
r:read读,代表的数字4
w:write写,代表的数字是2
x:执行,代表的数字是1

7 = 4 + 2 + 1,代表r + w + x

777代表着任意的用户和用户组都有读写执行权限

案例:
在linux上有一个/tmp目录,/tmp目录的权限就是777,我们在/tmp目录下创建一个rz.log文件;

1、查看/tmp目录,查看创建的rz.log文件权限
drwxrwxrwt. 12 root root       4096 Mar 12 17:08 tmp

2、查看rz.log的文件权限:
-rw-r--r-- 1 root root   24 Mar 12 17:05 rz.log

3、我们测试使用root用户是没有问题的,但是使用hadoop用户进入编辑,编辑rz.log的时候提示如下: warning: changing a readonly file,使用wq!强制保存的时候提示如下:can't open file for writing.


4、提示如3中的不能写入文件的时候,我们直接输入ctrl+z来中断写入,此时相当于产生了一个缓存文件,我们ll -a查看后进行删除,rm -f .rz.log.swap
-rw-r--r--   1 root   root      24 Mar 12 17:05 rz.log
-rw-------   1 hadoop hadoop 12288 Mar 12 17:10 .rz.log.swp

5、我们修改vi.log的权限:chmod -R 746 rz.log
此时再使用Hadoop用户进行编辑:保存退出就没有问题了,
因为id hadoop查看到hadoop用户不是root用户,也不是root用户所在的组,而是属于其它用户用户组,所以赋予746权限:
[root@hadoop001 tmp]# id hadoop
uid=1000(hadoop) gid=1000(hadoop) groups=1000(hadoop)

注意生产上执行ctrl+z,相当于是直接中断掉文件,会产生swap文件,此时直接ll -a,然后再删除文件即可。

  • 测试我们把hadoop用户加入到root这个用户组:
1、原先hadoop所属的用户和用户组:
[root@hadoop001 tmp]# id hadoop
uid=1000(hadoop) gid=1000(hadoop) groups=1000(hadoop)

2、把hadoop这个用户加到root这个用户组中:
[root@hadoop001 tmp]# usermod -a -G root hadoop
[root@hadoop001 tmp]# id hadoop
uid=1000(hadoop) gid=1000(hadoop) groups=1000(hadoop),0(root)

3、/tmp/rz.log的这个文件还是644权限,此时测试编辑能不能用
仍然提示不能保存

4、修改rz.log的权限为chmod -R 664 rz.log进行测试:
需要新开一个session或者重新连接当前窗口,vi rz.log能够顺利写入并且保存退出。

2.6、文件、文件夹查看大小

1、查看文件大小:

[root@hadoop001 software]# ll php-7.2.28.tar.gz 
-rw-r--r-- 1 root root 19935034 Mar  5 13:54 php-7.2.28.tar.gz
[root@hadoop001 software]# du -sh php-7.2.28.tar.gz 
20M     php-7.2.28.tar.gz

2、查看文件夹大小:

[root@hadoop001 hadoop]# du -sh software/
866M    software

2.7、搜索find命令

history 历史记录
ps -ef 查看进程
top 系统情况

1、我们手上拿到了一台新机器,比如某个大数据组件hadoop,我们需要自行去寻找部署在哪个路径下?

  • 使用最大的root权限,find / -name “hadoop”
1、从根目录开始搜索到名字为hadoop的文件:
[root@hadoop001 ~]# find / -name "hadoop"
/home/hadoop
/var/db/sudo/hadoop
/var/spool/mail/hadoop

2、可以指定在/home下查找:
[root@hadoop001 ~]# find /home -name "*hadoop*"
/home/hadoop

3、可以对需要查找的内容进行模糊匹配:前后都加上*号:
[root@hadoop001 ~]# find / -name "*hadoop*"
/home/hadoop
/var/db/sudo/hadoop
/var/spool/mail/hadoop

三、本次课程作业

作业:
1、整理用户、用户组
2、sudo命令
3、用户为什么会无法登陆(/etc/passwd文件有关)
4、权限(rwx)、chown和chmod命令
注意:linux上使用-R的命令只有chown和chmod命令

上一篇:hadoop部署


下一篇:使用阿里云服务器进行CDH部署学习