本节内容:
1,文件权限的控制,chmod,chown
2,用户的增删和所属组,useradd,userdel
3,用户组的增删,groupadd,groupdel
4,su,sudo的介绍
5,别名的使用,alias
6,管道符|,重定向
7,comtab,计划任务
8,locat,find查找的使用
9,df,显示所有空间的使用情况
10,mount硬盘的挂载和卸载
11,tar解压
12,grep正则表达
1,文件权限,chmod,chown
r:可读------4
w:可写-----2
x:可执行---1,普通文件可以直接通过./来执行
-:代表没有权限
chmod o+w filename
chmod g+w filename
chmod u+w filename
chmod u=rwx filename
# 其中:
# u 代表所有者(user)
# g 代表所有者所在的组群(group)
# o 代表其他人,但不是u和g (other)
# a 代表全部的人,也就是包括u,g和o
2,useradd添加用户,usermod改变用户的信息
# -c 备注 加上备注。并会将此备注文字加在/etc/passwd中的第5项字段中
# -d 用户主文件夹。指定用户登录所进入的目录,并赋予用户对该目录的的完全控制权
# -e 有效期限。指定帐号的有效期限。格式为YYYY-MM-DD,将存储在/etc/shadow
# -f 缓冲天数。限定密码过期后多少天,将该用户帐号停用
# -g 主要组。设置用户所属的主要组 www.cit.cn
# -G 次要组。设置用户所属的次要组,可设置多组
# -M 强制不创建用户主文件夹
# -m 强制建立用户主文件夹,并将/etc/skel/当中的文件复制到用户的根目录下
# -p 密码。输入该帐号的密码
# -s shell。用户登录所使用的shell
# -u uid。指定帐号的标志符user id,简称uid
useradd user1 # 添加用户 user1
useradd -d /home/userTT user2
sudo mkdir user1 # 在/home目录下新建用户文件目录
sudo chown user1:user1 user1 # 改变目录的所有者和组的权限
cp /etc/skel/.bash* /home/user1 # 将目录下.bash开始的文件复制到家目录
source /home/user1/.bash* # 可以使家目录下的环境变量生效
userdel删除用户
userdel user1 #
userdel -r user1
# -r, --remove 用户主目录中的文件将随用户主目录和用户邮箱一起删除。在其它文件系统中的文件必须手动搜索并删除。
# -f, --force 此选项强制删除用户账户,甚至用户仍然在登录状态。它也强制删除用户的主目录和邮箱,即使其它用户也使用同一个主目录或邮箱不属于指定的用户
usermod用法:
chmod o+w file1
chmod g-w file1
chmod go-w file1
chmod u=rwx file1
chmod 755 file1 # -rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限
chmod 644 # -rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
# 其中:
# u 代表所有者(user)
# g 代表所有者所在的组群(group)
# o 代表其他人,但不是u和g (other)
# a 代表全部的人,也就是包括u,g和o
3,groupadd,groupdel,chown
groupadd group # 添加用户组
groupadd -u 1000 group1 #指定gid的用户组
groupdel # 删除组
groupdel group # 删除组
chown # 改变文件的所属组所有者
chown root:root file
chown root file
chown :root file
4,su与 sudo
su : 切换用户,没有参数时,默认切换为root用户;
su # 切换为root
## 推荐
su - # 切换为root 并加载root的环境配置
su - user1 # 切换为user1 并加载user1的环境配置
sudo让当前用户暂时以管理员的身份root来执行命令。
sudo的配置文件:/etc/sudoers;可以通过修改它配置sudo命令
5,alias : 给命令起别名
alias ll='ls -l'
alias la='ls -a'
关于各个文件的作用域,在网上找到了以下说明:
(1) /etc/profile: 此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. 并从/etc/profile.d目录的配置文件中搜集shell的设置。
(2) /etc/bashrc: 为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取(即每次新开一个终端,都会执行bashrc)。
(3) ~/.bash_profile: 每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次。默认情况下,设置一些环境变量,执行用户的.bashrc文件。
(4) ~/.bashrc: 该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该该文件被读取。
(5) ~/.bash_logout: 当每次退出系统(退出bash shell)时,执行该文件. 另外,/etc/profile中设定的变量(全局)的可以作用于任何用户,而~/.bashrc等中设定的变量(局部)只能继承 /etc/profile中的变量,他们是"父子"关系。(6) ~/.bash_profile: 也可能是 .profile 是交互式、login 方式进入 bash 运行的~/.bashrc 是交互式 non-login 方式进入 bash 运行的通常二者设置大致相同,所以通常前者会调用后者。
6,管道符,重定向,标准输出
管道符 就是 | :他的作用是 将前一个命令的结果 交给后一个命令使用
>ww.txt # 文件ww.txt会变为空的
> 重定向,则覆盖文件内容,没有该文件就创建(需要有创建的权限)
>> 重定向,则向文件追加内容,没有该文件就创建(需要有创建的权限)
1> 标准正确输出,则覆盖文件内容,没有该文件就创建(需要有创建的权限)
1>> 标准正确输出,则向文件追加内容,没有该文件就创建(需要有创建的权限)
2> 标准错误输出,则覆盖文件内容,没有该文件就创建(需要有创建的权限)
2>> 标准错误输出,则向文件追加内容,没有该文件就创建(需要有创建的权限)
&> 标准正确输出和标准错误输出,文件中保存了写入的东西,报错信息也会出现在文件中,没有该文件就创建(需要有创建的权限)
7,crontab,计划任务
crontab -e # 修改计划配置* * * * * command to be executed
- - - - - -
| | | | | |
| | | | | --- 预执行的命令
| | | | ----- 表示星期0~7(其中星期天可以用0或7表示)
| | | ------- 表示月份1~12
| | --------- 表示日期1~31
| ----------- 表示小时1~23(0表示0点)
------------- 表示分钟1~59 每分钟用*或者 */1表示
---------- 表示小时1~23(0表示0点)
1,crontab -e 进行编辑操作,选择是用vim,下次不需要选择,自动默认vim,在最下边加入:
*/1**** /bin/bash /tmp/cron.sh
# /bin/bash 指定运行的路径
# cron.sh是自定义的一个文件内容下方
date >> /tmp/date.txt # 这样是防止配置文件中字符超过60个会执行错误
2,crontab -l 显示当前客户的crontab内容
8,locate,find查询命令
locate /etc/sh # 所有包含/etc/sh路径的文件
locate -i ~/a # 所有主目录下所有以开头的文件,忽略大小写
因为是本地更新,据说是每天凌晨的4点进行更新
可以使用sudo updatedb更新数据库来实现更新
find
使用方法:
find path -option [-print ] [ -exec -ok command ] {} \;
###### 根据文件名查找 #######
find / -name filename 再根目录里面搜索文件名为filename的文件
find /home -name "*.txt"
find /home -iname "*.txt" # 忽略大小写
###### 根据文件类型查找 #######
find /home/wuzhenhu/Desktop/ . -type 类型参数,有点的时候是可以查找到隐藏文件,没有点的时候不能查到隐藏文件
f 普通文件
l 符号连接
d 目录
c 字符设备
b 块设备
s 套接字
p Fifo
###### 根据目录深度查找 #######
find . -maxdepth 3 -type f # 最大深度为3
find . -mindepth 2 -type f # 最小深度为2
-o:逻辑或,两个条件只要满足一个即可。
-a:逻辑与,两个条件必须同时满足。
find /etc -size +2M -a -size -10M
+代表大于,-代表小于
######### 对查找结果进行处理 #############
-exec shell命令 {} \;
-ok shell命令 {} \;
其中-exec就是代表要执行shell命令,后面加的是shell指令,再后面的“{}”表示的是要对前面查询到的结果进行查询,最后的“\;”表示命令结束。需要注意的是“{}”和“\”之间是要有空格的。
而-ok选项与-exec的唯一区别就是它在执行shell命令的时候会事先进行询问,-print选项是将结果显示在标准输入上
find /home -name “*.txt” -ok ls -l {} \;
find /home -name “*.txt” -ok rm {} \;
9,df显示所有空间的使用
df -Th #
h以能显示的最大单位显示
T:显示文件系统类型
10,mount/mount3挂载和卸载设备
mount # 查询挂在设备及属性
# 挂载光盘
mount /dev/sr0 /mnt
# 重新挂载设备
mount -o remount,rw /mnt # 重新挂载设备并设置rw属性
# 挂载iso文件
mount a.iso -o loop /mnt
umount /mnt # 卸载设备
umount -l /mnt # 强制卸载
11,tar解压,压缩命令
-c :建立一个压缩文件的参数指令(create 的意思);
-x :解开一个压缩文件的参数指令!
-t :查看 tarfile 里面的文件!
特别注意 c/x/t 同时仅能存在一个,因为不可能同时压缩与解压缩。
-z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩?
-j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩?
-v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程!
-f :使用档名,请留意,在 f 之后要立即接文件名
-p :使用原文件的原来属性(属性不会依据使用者而变)
-P :可以使用绝对路径来压缩!
-N :比后面接的日期(yyyy/mm/dd)还要新的才会被打包进新建的文件中!
# 将当前目录下所有.txt文件打包并压缩归档到文件this.tar.gz
tar czvf this.tar.gz ./*.txt
# 将当前目录下的this.tar.gz中的文件解压到当前目录
tar xzvf this.tar.gz ./
# 将整个 /etc 目录下的文件全部打包成为 /tmp/etc.tar
tar -cvf /tmp/etc.tar /etc # 仅打包,不压缩!
tar -zcvf /tmp/etc.tar.gz /etc # 打包后,以 gzip 压缩
tar -jcvf /tmp/etc.tar.bz2 /etc # 打包后,以 bzip2 压缩
# 解压文件
tar -xf a.tar.gz #
tar -xf a.tar.gz -C /tmp # 指定解包路径
12,grep匹配正则表达式
正则表达式:
初识正则表达式
^ : 匹配开头
$ : 匹配结尾
[] : 范围匹配
[a-z] : 匹配有小写字母
[A-Z] : 匹配所有大写字母
[0-9] : 匹配所有数字
. : 匹配单个字符
* : 表示*前面的内容出现0次或多次
+ : 表示+前面的内容出现1次或多次
? : 表示?前面的内容出现0次或1次
cat a.txt |grep hat$ # 匹配以hat结尾的行
cat a.txt |grep ^hat # 匹配以hat开头的行
cat a.txt | grep -E "[0-9]*" # 匹配有0到多个数字的行
cat a.txt | grep -E "[0-9]+" # 匹配有至少有1个数字的行
cat a.txt | grep -E "[0-9]?" # 匹配有0到1个数字的行