Linux文件管理命令
Linux基础-文件管理命令
1.ls
查看目录信息
ls
#参数
-l 以长格的形式显示属性信息
-a 显示所有文件
-h 以人类的可读形式显示
-i 显示inode号
-d 只显示目录信息
-t 按照时间排序
-r 倒叙排序
-1(数字1) 列表形式显示
2.cd
切换工作目录
. 当前目录
.. 当前目录的上一级目录
- 返回上一次所在的位置
~ 返回到当前用户的家目录
cd 返回到当前用户的家目录
/ 进入/目录,顶点目录。
3.mkdir
创建文件夹
#参数
-p 递归创建
-v 显示创建过程
[root@git ~]# mkdir abc #相对路径的写法
[root@git ~]# mkdir /data #绝对路径的写法
[root@git ~]# mkdir -p /data/abc #级联创建目录
4.rm
删除文件夹
[root@git ~]# rm abc
rm: 无法删除"abc": 是一个目录
[root@git ~]# rm -fr abc
[root@git ~]# echo $?
0
5.mv
修改文件夹名称
[root@git ~]# mv abc aaa
[root@git ~]# ll
-rw-r--r-- 1 root root 473 7月 24 10:52 host_ip.sh
#移动文件或目录
[root@git ~]# mv host_ip.sh aaa
[root@git ~]# ll -l aaa
-rw-r--r-- 1 root root 473 7月 24 10:52 host_ip.sh
6.rename
用来批量更改文件名
[root@git aaa]# ll
-rw-r--r-- 1 root root 473 7月 24 10:52 host_ip.sh
[root@git aaa]# rename .sh .sh.bak *
[root@git aaa]# ll
-rw-r--r-- 1 root root 473 7月 24 10:52 host_ip.sh.bak
7. tree
以树状型显示目录结构。
#参数
-d 只显示目录
-L 显示目录层级
-f 只显示文件信息
-a 显示所有文件信息
8. cp
复制或者拷贝文件和目录
#参数
-r 递归复制
-p 保持属性
-a =-pdr
-i 提示文件存在时是否覆盖(系统默认别名有)
-v 显示复制的过程
-t 把源路径和目标位置进行调换。
9.ln软连接
软链接:相当于windows的快捷方式,软链接文件会将inode指向源文件的block
命令:ln
语法:ln+原文件+目标
-s:做软链
-f:强制做
-v:反向做链接
&&:衔接多条命令,前面执行成功之后,再执行后面的
||:衔接多条命令,前面执行不成功,后面也要执行
实例:
#使用命令ln -s 创建链接
[root@Centos7 ~]#ln -s xcz/xcz.txt /root/xcz.txt
[root@Centos7 ~]#ll -i
50707261 drwxr-xr-x. 2 root root 24 Jun 21 14:30 xcz
33575384 lrwxrwxrwx. 1 root root 17 Jun 21 14:45 xcz.txt -> xcz/xcz.txt
#软链接的应用场景
1)软件升级
2)代码发布
3)不方便移动的目录
4)数据回滚
5)程序读取
10.ln硬链接
#什么是硬链接?
硬链接:硬链接就是同一个文件使用了多个别名。
命令:ln(后面不加s)
语法:ln+原文件+目标
实例:
#使用命令ln -s 创建链接
[root@xcz /xcz]# ln /opt/xcz/xcz.txt /xcz/xcz.txt
[root@xcz /xcz]# ll -i /xcz/
50735412 -rw-r--r-- 2 root root 0 Mar 7 21:55 xcz.txt
[root@xcz /xcz]# ll -i /opt/xcz/
50735412 -rw-r--r-- 2 root root 0 Mar 7 21:55 xcz.txt
注意:
1)具有同一个inode号的文件,互为硬链接文件
2)目录不能创建硬链接
11.touch
创建文件
[root@git aaa]# touch 123.txt
[root@git aaa]# echo "xcz" > abc.txt
[root@git aaa]# cat abc.txt
xcz
# ">" 标准输出重定向,覆盖文件内所有内容
[root@git aaa]# echo "123" >abc.txt
[root@git aaa]# cat abc.txt
123
# “>>” 标准输出追加重定向,追加到文件结尾,不覆盖
[root@git aaa]# echo "456" >>abc.txt
[root@git aaa]# cat abc.txt
123
456
12.vim
文件编辑器
#三种模式:
普通模式(命令模式):普通模式:删除、复制、粘贴、撤销等操作
编辑模式:
底行模式(末行模式、视图模式)
vim视图模式(从命令模式进入视图模式):
Ctrl +v 进入VISUAL BLOCK 选中需要注释的行(可视模块)
1.插入:按shift+i进入编辑模式,输入 #结束按ESC键
2.删除:选中内容后,按x或者d键删除
3.替换:选中需要替换的内容, 按下r键,然后输入替换后的内容
Shif + v 进入VISUAL LINE 选中行内容(可视模块)
1.复制:选中行内容后按y键及可复制。
2.删除:选中行内容后按d键删除。
#环境变量永久生效
~/.vimrc个人环境变量(优先级高)
/etc/vimrc全局环境变量
语法检查及高亮;syntax on
设定默认解码:set fenc=utf-8
set fencs=utf-8,usc-bom,euc-jp,gb18030,gbk,gb2312,cp936
显示行号:set number
自动对齐,将当前行的对齐格式应用到下一行:set autoindent
依据上面的对齐方式,智能的选择对齐方式:set smartindent
设置tab键为4个空格:set tabstop=4
设置当行之间交错时使用4个空格:set shiftwidth=4
设置在编辑过程中,与右下角显示光标位置状态行:set ruler
设置增量搜索,这样的查询比较smart:set incsearch
高亮显示匹配的括号:set showmatch
匹配括号高亮时间:set matchtime=10
在搜索的时间忽略大小写:set ignorecase
当前行高亮显示:set cursorline
支持256色:set t_Co=256
使用molokai颜色模板:colorscheme molokai
#如何同时编辑多个文件
vim -o file1 file2 水平分割
vim -O file1 file2 垂直分割
#相同文件之间差异对比
diff 文件对比(用的不多) vim diff 以vim方式打开两个文件对比,标记不同的内容
#如果VIM非正常退出 (ctrl+z)挂起或强制退出终端没关闭VIM后
rm -f .filename.swp
1.vim命令模式快捷键
G | 跳转到最后一行 |
---|---|
gg/1G | 跳转到首行 |
N(数字)G/Ngg | N(数字)G/Ngg 跳转到某行 |
yy | 复制当前行 |
Nyy | 复制当前行及向下多少行,包含当前行 |
p | 在当前行的所在位置的下一行进行粘贴 |
Np | 向下粘贴多次 |
P | 在当前行的所在位置的上一行进行粘贴 |
NP | 向上粘贴多次 |
u | 撤销 |
dd | 删除当前行 |
Ndd | 删除当前行及向下多少行,包含当前行。 |
dG | 删除当前光标以下所有行。 |
x/delete | 删除当前光标从前往后删除一个字符 |
X | 删除当前光标从后往前删除一个字符 |
r | 替换当前字符,单个进行替换 |
R | 进行连续替换,在当前光标所在字符 |
^ | 从前当前光标移动行首 |
$ | 从前当前光标移动行尾 |
Ctrl键+f | 向下翻页 |
Ctrl键+b | 向上翻页 |
D | 删除当前光标所在位置之后的内容,针对当前行的操作 |
de/dw | 删除一组字符串 |
j | 向下一个字符 |
k | 向上一个字符 |
h | 向左一个字符 |
l | 向右一个字符 |
Nj | 向下指定多少个字符 |
Nk | 向上指定多少个字符 |
Nh | 向左指定多少个字符 |
Nl | 向右指定多少个字符 |
ZZ | 保存退出 |
2.vim编辑模式快捷键
快捷键 | 动作 |
---|---|
i | 在当前光标所在位置前插入字符 |
a | 在当前光标所在位置后插入字符 |
I | 在当前光标所在行的行首插入字符 |
A | 在当前光标所在行的行尾插入字符 |
o | 在当前光标所在行的下一行插入字符 |
O | 在当前光标所在行的上一行插入字符 |
s | 删除当前光标所在字符,并在当前光标所在位置前插入字符 |
S | 删除当前光标所在行,并进入编辑模式 |
C | 删除当前光标所在位置之后的内容,并进入编辑模式 |
cw | 删除一组字符串,会进入编辑模式 |
3.vim视图模式快捷键
快捷键 | 动作 |
---|---|
:N | 跳转到某行 |
:w | 保存 |
:q | 退出 |
:wq | 保存退出 |
:q! | 强制退出 |
:x | 保存退出 |
/+内容 | 搜索 |
:%s###g | 全局替换 |
:1,3s###g | 替换第一行到第三行的内容 |
4.vim变量(临时生效)
快捷键 | 动作 |
---|---|
:set nu | 显示行号 |
:set nonu | 取消 |
:set list | 给每行的结尾添加一个标识符 |
:set nolist | 取消 |
13.which
查找命令的绝对路径
[root@xcz /xcz]# which cd
/usr/bin/cd
[root@xcz /xcz]# which ld
/usr/bin/ld
[root@xcz /xcz]# which ls
alias ls='ls --color=auto'
/usr/bin/ls
[root@xcz /xcz]# which ip
/usr/sbin/ip
14.whereis
查找包含命令的名称绝对路径
[root@xcz /xcz]# whereis ip
ip: /usr/sbin/ip /usr/share/man/man8/ip.8.gz
[root@xcz /xcz]# whereis cd
cd: /usr/bin/cd /usr/share/man/man1/cd.1.gz
[root@xcz /xcz]# whereis ls
ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz
[root@xcz /xcz]# whereis cp
cp: /usr/bin/cp /usr/share/man/man1/cp.1.gz
15. typ
显示命令的绝对路径
[root@xcz /xcz]# type ip
ip is /usr/sbin/ip
[root@xcz /xcz]# type cd
cd is a shell builtin
[root@xcz /xcz]# type ls
ls is aliased to `ls --color=auto'
16.cat
查看文件内容
#cat:查看文件的内容,会将文件的所有内容显示出来。
-n 显示行号
[root@git opt]# cat -n /etc/passwd
1 root:x:0:0:root:/root:/bin/bash
2 bin:x:1:1:bin:/bin:/sbin/nologin
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
4 adm:x:3:4:adm:/var/adm:/sbin/nologin
-A 给文件内容的每行结尾加个标识符。
[root@git opt]# cat -A /etc/passwd
root:x:0:0:root:/root:/bin/bash$
bin:x:1:1:bin:/bin:/sbin/nologin$
daemon:x:2:2:daemon:/sbin:/sbin/nologin$
17.tac
倒叙查看文件的内容
[root@git opt]# tac /etc/passwd
ntp:x:38:38::/etc/ntp:/sbin/nologin
18.more
分页显示文件的内容,文件显示完成会自动退出
快捷键 | 动作 |
---|---|
空格/f | 向下翻页 |
b | 向上翻页 |
q | 退出 |
/ | 搜索关键字,不会高亮显示 |
= | 显示当前光标所在行 |
-N(数字) | 指定分页显示内容的行数 |
+N(数字) | 指定从第几行显示文件内容 |
19.less
分页显示文件的内容,文件显示完成不会自动退出。
快捷键 | 动作 |
---|---|
空格/f | 向下翻页 |
b | 向上翻页 |
q | 退出 |
/ | 搜索关键字,会高亮显示 |
-N | 显示行号 |
20.head
显示文件头部信息,默认显示前十行
参数 | 说明 |
---|---|
-n | 取消默认输出,指定你要输出的行数 |
-N(数字) | 显示文件内容的前多少行 |
-cN(数字) | 显示文件内容的前多少个字符 |
21.tail
显示文件尾部信息,默认显示最后十行
参数 | 说明 |
---|---|
-n | 取消默认输出,指定你要输出的行数 |
-N(数字) | 显示文件内容的最后多少行 |
-cN(数字) | 显示文件内容的最后多少个字符 |
-f | 实时查看文件内容的更新 |
-F | 实时查看文件内容的更新,当文件不存在时,会一直尝试。 |
22.tailf
实时查看文件内容的更新
[root@git opt]# tailf /var/log/messages
Nov 26 19:20:01 xcz systemd: Started Session 18 of user root.
Nov 26 19:30:02 xcz systemd: Started Session 19 of user root.
Nov 26 19:40:01 xcz systemd: Started Session 20 of user root.
Nov 26 19:50:01 xcz systemd: Started Session 21 of user root.
23. sort
排序,默认以空格为分隔符
#参数说明
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已经按照顺序排序。
-d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f 排序时,将小写字母视为大写字母。
-i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m 将几个排序好的文件进行合并。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-u 意味着是唯一的(unique),输出的结果是去完重了的。
-o <输出文件> 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t <分隔字符> 指定排序时所用的栏位分隔字符。
+ <起始栏位>-<结束栏位> 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
--help 显示帮助。
--version 显示版本信息。
#编辑文件
[root@xcz opt]# vim sort.txt
b:3
c:2
a:4
e:5
d:1
f:11
#以冒号为分割字符,以字母进行排序
[root@xcz opt]# sort -t ':' -k1 sort.txt
a:4
b:3
c:2
d:1
e:5
f:11
#以冒号为分割字符,以第一位数字从小到大进行排序
[root@xcz opt]# sort -t ':' -k2 sort.txt
d:1
f:11
c:2
b:3
a:4
e:5
#以冒号为分割字符,以数字从小到大排序
[root@xcz opt]# sort -t ':' -nk2 sort.txt
d:1
c:2
b:3
a:4
e:5
f:11
#以冒号为分割字符,以数字从大到小排序
[root@xcz opt]# sort -t ':' -rnk2 sort.txt
f:11
e:5
a:4
b:3
c:2
d:1
24. uniq
去重
参数 | 说明 |
---|---|
-c | 统计次数 |
-d | 只显示重复的行数 |
-u | 只显示不重复的行数 |
#编辑文件
[root@xcz /xcz]# vim xcz.txt
xcz
123
xcz
123
def
abc
def
xcz
xcz
123
#排序去重
[root@xcz /xcz]# sort xcz.txt | uniq
123
abc
def
xcz
#排序去重并统计次数
[root@xcz /xcz]# sort xcz.txt | uniq -c
3 123
1 abc
2 def
4 xcz
#排序去重、统计次数并从小到大排序
[root@xcz /xcz]# sort xcz.txt | uniq -c | sort -n
1 abc
2 def
3 123
4 xcz
#排序去重、统计次数并从大到小排序
[root@xcz /xcz]# sort xcz.txt | uniq -c | sort -nr
4 xcz
3 123
2 def
1 abc
#排序并只显示重复内容
[root@xcz /xcz]# sort xcz.txt | uniq -d
123
def
xcz
#排序并只显示非重复内容
[root@xcz /xcz]# sort xcz.txt | uniq -u
abc
25. wc
统计
参数 | 说明 |
---|---|
-l | 统计行号 |
-c | 统计文件大小,字节数 |
-w | 统计列数,默认以空格为分隔符 |
#统计密码文件有多少行
[root@xcz opt]# wc -l passwd
23 passwd
#统计密码文件有多少字节
[root@xcz opt]# wc -c passwd
965 passwd
#统计密码文件有多少列
[root@xcz opt]# wc -w xcz.txt
7 xcz.txt
#统计本地解析文件有多少列
[root@xcz opt]# wc -w /etc/hosts
10 /etc/hosts
[root@xcz opt]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
26. cut
截取字符,没有默认的分隔符
参数 | 说明 |
---|---|
-d | 指定分隔符 |
-fN(数字) | 取指定的列 |
-cN(数字) | 取指定的字符 |
#查看密码文件第一行
[root@xcz opt]# head -1 passwd
fbgroot:x:0:0:root:/root:/bin/bash
#以“:”为分隔,查看密码文件所有行的第7列
[root@xcz opt]# cut -d ':' -f7 passwd
/bin/bash
/sbin/nologin
/sbin/nologin
/sbin/nologin
#以“:”为分隔,查看密码文件第一行的第7列
[root@xcz opt]# cut -d ':' -f7 passwd | head -1
/bin/bash
#读取eth0前三行
[root@xcz opt]# ip a s eth0
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:71:30:98 brd ff:ff:ff:ff:ff:ff
inet 10.0.0.100/24 brd 10.0.0.255 scope global noprefixroute eth0
valid_lft forever preferred_lft forever
inet6 fe80::80b2:dc89:7adf:c7b1/64 scope link noprefixroute
valid_lft forever preferred_lft forever
[root@xcz opt]# ip a s eth0 | head -3
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:71:30:98 brd ff:ff:ff:ff:ff:ff
inet 10.0.0.100/24 brd 10.0.0.255 scope global noprefixroute eth0
#读取eth0第三行
[root@xcz opt]# ip a s eth0 | head -3 | tail -1
inet 10.0.0.100/24 brd 10.0.0.255 scope global noprefixroute eth0
#读取eth0的IP地址
[root@xcz opt]# ip a s eth0 | head -3 | tail -1 | cut -d ' ' -f6 |cut -d '/' -f1
10.0.0.100
[root@xcz opt]# ip a s eth0 | grep -w inet | cut -d ' ' -f6 |cut -d '/' -f1
10.0.0.100
[root@xcz opt]# ip a s eth0 | grep -w inet |tr '/' ' ' |cut -d ' ' -f6
10.0.0.100
27. tr
替换命令,单对单替换
#将xcz.txt文件内的“1”替换为“2”
[root@xcz opt]# tr '1' '2' < xcz.txt
xcz
223
xcz
223
#将xcz.txt文件内的“1”删除
-d ---删除字符
[root@xcz opt]# tr -d 1 < xcz.txt
xcz
23
xcz
23
28.chmod
权限的管理
# 什么是权限
权限:就是针对某些文件或者进程,对用户进行限制
# 权限和用户的关系
drwxr-xr-x 2 root root 64 Jul 1 02:00 bak
文件类型 文件属主(所属用户)权限 文件所(属组)属用户组 其他用户
d rwx r-x r-x
硬链接数 文件的属主(所属用户) 文件的属组(所属用户组) 文件的大小(文件中的字节数)
2 root root 64
文件的修改时间 文件名
Jul 1 02:00 bak
# 标志
- #普通文件
l #软链接文件
s #socket套接字
c #块设备
d #目录文件
# 权限对文件的作用
#读取权限(r)
文件只有r权限: 具有读取\阅读文件内容权限
1.能使用查看类命令cat、head、tail、less、more
2.不能复制、不能移动、不能编辑,不能删除
#写入权限(w)
如果文件只有w权限: 具有新增、修改文件内容的权限
1.使用vim编辑会提示权限拒绝, 但可强制保存,会覆盖文件的所有内容
2.使用echo、cat命令重定向或追加重定向技术可以往文件内写入数据
3.不能复制、不能移动、不能删除,(删除需要看上级目录w的权限)
#执行权限(x)
文件只有x权限,具有执行文件的权限。
# 注意: 普通用户需要有r权限,管理员不需要
1.不能执行、查看、编辑、复制、移动、删除
13.6 权限对目录的作用
目录只有r权限: 具有浏览目录及子目录权限
1.能使用ls命令浏览目录及子目录, 同时会提示权限拒绝
2.能使用ls -l命令浏览目录及子目录, 会带问号,同时只能看到文件名
总结: 目录只有r权限,仅仅只能浏览内的文件名,无其他操作权限
# 授权方式(ugo:u:rwx g:rwx o:rwx )
1)+号 -号 授权
rw- r-x -wx
--x -w- r--
--x -w- r--
rwx ---> u(user)g(group)o(other)
[root@xcz ~]# chmod u+w xcz
u+x
g+w
o+r
2)数字授权(比如 755、644、000)
r:4
w:2
x:1
-:0
rwxr-xr-x bak 755
3)=号授权
[root@xcz ~]# chmod u=rwx,g=rw,o=r xcz
29.chown
chown(英文全拼:change owner)命令用于设置文件所有者和文件关联组的命令。chown 需要超级用户 root 的权限才能执行此命令。只有超级用户和属于组的文件所有者才能变更文件关联组。非超级用户如需要设置关联组可能需要使用 chgrp 命令。
参数 :
user : 新的文件拥有者的使用者 ID
group : 新的文件拥有者的使用者组(group)
-c : 显示更改的部分的信息
-f : 忽略错误信息
-h :修复符号链接
-v : 显示详细的处理信息
-R : 处理指定目录以及其子目录下的所有文件
--help : 显示辅助说明
--version : 显示版本
#示例:
[root@buttercup ~]# chown -R www.www /code/*
30.特殊权限与umask
#setuid
setuid==suid(数字权限定义编辑4000)
SetUID(suid):会在属主权限位的执行权限上写个s
[root@Centos7 ~]#ll /bin/passwd
-rws r-x r-x. 1 root root 27832 Jun 10 2014 /bin/passwd
# 如果该属主权限位上有执行权限,则:s(小写)
[root@Centos7 ~]#ll xcz
- rws r-x r-x. 1 root root 0 Jul 1 10:40 xcz
# 如果该属主权限位上没有执行权限,则:S(大写)
[root@Centos7 ~]#ll xcz
- rwS r-x r-x. 1 root root 0 Jul 1 10:40 xcz
# 授权方式
方式一(加减授权):chmod u+s filename
方式二(数字授权):chmod 4755 filename
# SetUID总结
1.让普通用户对可执行的二进制文件,临时拥有二进制文件的属主权限
2.如果设置的二进制文件没有执行权限,那么suid的权限显示就是S
3.特殊权限suid仅对二进制可执行程序有效,其他文件或目录则无效
##注意:suid极其危险,不要对vim或者rm命令进行设定suid
#setgid
setgid==sgid(2000)
setgid==sgid(数字权限定义编辑2000)
#如果该属组权限位上有执行权限,则:s
[root@Centos7 ~]#ll xcz
-rwx r-s r-x. 1 root root 0 Jul 1 10:40 xcz
# 如果该属组权限位上没有执行权限,则:S
[root@Centos7 ~]#ll xcz
- rwx rwS r-x. 1 root root 0 Jul 1 10:40 xcz
# 授权方式
方式一(加减授权): chmod 2755 /tmp/test/
方式二(数字授权): chmod g+s /tmp/test/
# SetGID的作用
1.针对用户组权限位修改,用户创建的目录或文件所属组和该目录的所属组一致。
2.当某个目录设置了sgid后,在该目录中新建的文件不在是创建该文件的默认所属组
3.使用sgid可以使得多个用户之间共享一个目录的所有文件变得简单。
#sbit
sbit(1000)
sbit(数字权限定义编辑1000)
粘滞位:
[root@Centos7 ~]#ll -d /tmp/
drwxrwxrwt. 7 root root 93 Jul 2 08:28 /tmp/
# 如果该其他用户权限位上有执行权限,则:t
[root@Centos7 ~]#chmod 1767 xcz
[root@Centos7 ~]#ll xcz
-rwxrw-rwt. 1 root root 0 Jul 1 10:40 xcz
# 如果该其它用户权限位上没有执行权限,则:T
[root@Centos7 ~]#ll xcz
-rwxrw-rwT. 1 root root 0 Jul 1 10:40 xcz
# 授权方式:
方式一(加减授权):chmod 1755 /opt
方式二(数字授权):chmod o+t /opt
# sbit的作用
粘滞,目前只对目录有效,作用如下:
普通用户对该目录拥有w和x权限,即普通用户可以在此目录中拥有写入权限,如果没有粘滞位,那么普通用户拥有w权限,就可以删除此目录下的所有文件,包括其他用户建立的文件。但是一旦被赋予了粘滞位,除了root可以删除所有文件,普通用户就算有w权限也只能删除自己建立的文件,而不能删除其他用户建立的文件。 系统中存在的/tmp目录是经典的粘滞位目录,谁都有写权限,因此安全成问题,常常是***第一手跳板。
# 特殊权限总结:
1.SUID
主要是对命令,或者二进制文件,以该二进制文件的属主权限来执行该文件 命令:passwd
2.SGID
主要是针对目录进行授权,共享目录
3.SBIT
粘滞位,即便是该目录拥有w权限,但是除了root用户,其他用户只能对自己的文件进行删除、移动操作
#字符代表含义:
一个普通用户:zls 属于 xcz这个组
一个文件权限:rwxrw-r-x root.xcz filename1
r:读 4
w:写 2
x:执行 1
suid:4000
sgid:2000
t:1000
# Linux权限属性chattr概述:凌驾于r w x suid sgid t 之上的权限
# lsattr:查看特殊权限
[root@Centos7 ~]#lsattr /etc/passwd
---------------- /etc/passwd
# chattr:设置特殊权限
i:锁定文件,不能编辑,不能修改,不能删除,不能移动,可以执行
#chattr +i
[root@Centos7 ~]#chattr +i /etc/passwd
[root@Centos7 ~]#lsattr /etc/passwd
----i----------- /etc/passwd
#chattr -i
[root@Centos7 ~]#chattr -i /etc/passwd
[root@Centos7 ~]#lsattr /etc/passwd
---------------- /etc/passwd
a:仅可以追加文件,不能编辑,不能删除,不能移动,可以执行
#chattr +a
[root@Centos7 ~]#chattr +a /etc/passwd
[root@Centos7 ~]#lsattr /etc/passwd
-----a---------- /etc/passwd
#chattr -a
[root@Centos7 ~]#chattr -a /etc/passwd
[root@Centos7 ~]#lsattr /etc/passwd
---------------- /etc/passwd
#Linux进程掩码umask
#umask标准值为:0022
[root@Centos7 ~]#umask
0022
#umask与目录和文件之间的计算
#实例1:
目录:0777-0022=0755
0777-0023=0754
文件:0666-0022=0644
#实例2:
umask=0024
目录:0777-0024=0753
文件:0666-0024=0642
#实例3:
umask=0023
目录:0777-0023=0754
文件:0666-0023=064(3+1)
#实例4:
umask=051
目录:0777-0051=0726
文件:0666-0051=06(1+1)(5+1)
结论:目录最高权限为0777
文件最高权限为0666
如设定umask数值有基数时候,需要加1
实例:
umask 0657
目录:0120
文件:0020
umask影响范围:
777-077=700
31.压缩
#压缩打包的介绍:
windows下我们接触最多的压缩文件就是.rar格式, 但Linux有自己所特有的压缩工具。
如果希望windows和Linux互相能使用的压缩工具, 建议.zip格式
# 压缩打包的优点:
1节省磁盘空间占用率
2节省网络传输带宽消耗
3网络传输更加快捷
# Linux系统常见的压缩包有哪些类型
格式 压缩工具
.zip zip压缩工具
.gz gzip压缩工具,只能压缩文件,会删除源文件(通常配合tar使用)
.bz2 bzip2压缩工具,只能压缩文件,会删除源文件(通常配合tar使用)
.tar.gz 先使用tar命令归档打包,然后使用gzip压缩
.tar.bz2 先使用tar命令归档打包,然后使用bzip压缩
#注意:
1.Linux下常用压缩文件以.tar.gz结尾.
2.Linux下压缩文件必须带后缀.
# gzip压缩工具
使用gzip压缩工具需要先安装源:
yum install -y gzip
# gzip打包会删除源文件
#压缩----gzip
[root@Centos7 ~]#gzip passwd
-rw-r--r--. 1 root root 447 Jul 3 16:07 passwd.gz
#解压----gzip -d
[root@Centos7 ~]#gzip -d passwd.gz
-rw-r--r--. 1 root root 1036 Jul 3 16:07 passwd
#不需要解压,查看文件内容----zcat
[root@Centos7 ~]#zcat passwd.gz
root:x:0:0:root:/root:/bin/bash
#注意:
1.gzip 不可以压缩目录,只能压缩文件
[root@Centos7 ~]#gzip etc/
gzip: etc/ is a directory -- ignored
2.gzip压缩的文件不在当前目录下
3.压缩会删除源文件
4.解压会删除压缩文件
练习:
把/etc目录 拷贝/root下,找到/root/etc/下面所有一级二级目录中的 普通文件,压缩
[root@Centos7 ~]#find /root/etc/ -maxdepth 2 -type f |xargs gzip
# zip压缩工具
-r:递归压缩
-T:检查压缩包是否完好
#压缩
(压缩使用方式:命令zip+压缩后的文件名+需要压缩的文件)----zip
[root@Centos7 ~]#zip dai_access access.log
adding: access.log (deflated 94%)
-rw-r--r--. 1 root root 58817074 Sep 21 2017 access.log
-rw-r--r--. 1 root root 3766015 Jul 8 14:28 dai_access.zip
注意:zip压缩方式压缩不会删除源文件
#解压
(解压使用方式:命令unzip +需要解压的文件)----unzip
-d:解压到指定路径
-l :查看压缩包里面的内容
-t :检查压缩包里面的文件是否完好
[root@xcz ~]# unzip zls.zip
[root@Centos7 ~]#unzip dai_access.zip
Archive: dai_access.zip
replace access.log? [y]es, [n]o, [A]ll, [N]one [r]ename:
替换 文件名 替换 不替换 替换所有 啥也不做 改名
#递归压缩目录
(压缩使用方式:命令unzip + -r(选项)+解压后的文件名+需要解压的文件)----unzip
[root@Centos7 ~]#zip -r dai_etc_.zip etc/
-rw-r--r--. 1 root root 12314125 Jul 8 14:44 dai_etc_.zip
#查看目录信息----file(命令)
[root@Centos7 ~]#file dai_etc_.zip
gzip: dai_etc_.zip has more than one entry--rest ignored
注意:
1.压缩不会删除源文件
2.解压不会删除压缩文件
3.解压开会覆盖源文件内容
练习题:
查找到etc下所有1,2,3目录,包括目录下的文件,zip打包名字叫:yourname_etc.zip
[root@Centos7 ~]#find /root/etc/ -maxdepth 3 -type d -type f |xargs zip -r xcz_etc_.zip /root/etc/
-rw-r--r--. 1 root root 12337695 Jul 8 14:56 xcz_etc_.zip
#tar压缩工具
#语法:tar [-zjxcvfP] filename
c //创建新的归档文件
x //对归档文件解包
t //列出归档文件里的文件列表
v //输出命令的归档或解包的过程
f //指定包文件名,多参数f写最后
C //指定解压目录位置
z //使用gzip压缩归档后的文件(.tar.gz)
j //使用bzip2压缩归档后的文件(.tar.bz2)
J //使用xz压缩归档后的文件(tar.xz)
X //排除多个文件(写入需要排除的文件名称)
h //打包软链接
P //连带绝对路径打包
--hard-dereference //打包硬链接
--exclude //在打包的时候写入需要排除文件或目录
#打包压缩
(压缩使用方式:命令tar+选项+压缩后的文件名+需要压缩的文件)
[root@Centos7 ~]#tar zcvf dyc.tar.gz etc/
命令 选项 压缩包名字 需要压缩的文件名
#查看打包内容
(查看打包内容方式:命令tar+选项+压缩后的文件名)
[root@Centos7 ~]#tar tf dyc.tar.gz
命令 选项 压缩包名字
#解压
(解压压缩包方式:命令tar+选项+压缩后的文件名)
[root@Centos7 ~]#tar xf xcz.tar.gz
命令 选项 压缩包名字
#注意:
1.不要使用绝对路径
如果非要打包绝对路径:
[root@Centos7 /tmp]#tar zvcfP dyc.tar.gz /tmp/etc/ etc/
解压的时候:
[root@Centos7 /tmp]#tar xfP dyc.tar.gz
2.tar 打包可以接多个文件f
[root@xcz ~]# tar zcf abc1.tar.gz 1.txt 2.txt 3.txt
格式 压缩工具
.zip zip
zip -r dir.zip dirname
zip file.zip filename
.gz #gzip压缩工具,只能压缩文件,会删除源文件(通常配合tar使用)
gzip filename
.bz2 #bzip2压缩工具,只能压缩文件,会删除源文件(通常配合tar使用)
.tar.gz #先使用tar命令归档打包,然后使用gzip压缩
tar zcf dirname.tar.gz dirname
.tar.bz2 #先使用tar命令归档打包,然后使用bzip压缩
tar cjf dirname.tar.bz2 dirname
.tar.xz
tar cJf dirname.tar.xz dirname
# 常用打包与压缩组合
czf #打包tar.gz格式
cjf #打包tar.bz格式
cJf #打包tar.xz格式
xf #自动选择解压模式
tf #查看压缩包内容
#不想打包 的文件
[root@xcz /]# tar zcf etc3.tar.gz --exclude=Makefile etc
#指定解压路径
[root@xcz ~]# tar xf abc1.tar.gz -C /opt/
#常用的压缩与解压配合
tar zcf 压缩
tar xf 解压
32.检查文件大小命令
du -sh /*
33.crontab
定时任务
crontab:
01 00 * * * /bin/bash /root/usr/tiananCaiXianWeChat/weChatProject/start.sh &>/dev/null
* * * * * [user] command
分 时 日 月 周 [用户] 命令
第1列表示分钟0~59 每分钟用*或者 */1表示
第2列表示小时0~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~7(0或7表示星期天)
第6列要运行的命令
-e :编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件
-l :表示查看 crontab job
-r :删除所有 crontab job(慎用)
* :表示任何时刻都接受;
, :表示分割时段,如0 3,6 * * * command 表示每天的3:00和6:00会执行command
- :表示一段时间范围,如20 8-12 * * * command表示8点-12点每20分钟执行一次
/n :表示每隔n个单位间隔,如*/5 * * * * command表示每隔5分钟执行一次
34.Selinux相关命令
1、查看SELinux状态
1.1getenforce
getenforce 命令是单词get(获取)和enforce(执行)连写,可查看selinux状态,与setenforce命令相反。
setenforce 命令则是单词set(设置)和enforce(执行)连写,用于设置selinux防火墙状态,如: setenforce 0用于关闭selinux防火墙,但重启后失效。
[root@gm-aip-al ~]# getenforce
Enforcing
1.2 /usr/sbin/sestatus
Current mode表示当前selinux防火墙的安全策略
[root@gm-aip-al ~]# sestatus
SELinux status: enabled #selinux防火墙的状态,enabled表示启用selinux防火墙
SELinuxfs mount: /sys/fs/selinux
SELinux root directory: /etc/selinux
Loaded policy name: targeted
Current mode: enforcing #selinux防火墙当前的安全策略,enforcing 表示强
Mode from config file: enforcing
Policy MLS status: enabled
Policy deny_unknown status: allowed
Max kernel policy version: 28
2、关闭SELinux
2.1 临时关闭
setenforce 0 :用于关闭selinux防火墙,但重启后失效。
2.1 永久关闭
修改selinux的配置文件,重启后生效。
打开 selinux 配置文件
vim /etc/selinux/config
# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
# enforcing - SELinux security policy is enforced.
# permissive - SELinux prints warnings instead of enforcing.
# disabled - No SELinux policy is loaded.
SELINUX=disabled #将SELINUX=enforcing改为SELINUX=disabled,保存后退出
# SELINUXTYPE= can take one of three two values:
# targeted - Targeted processes are protected,
# minimum - Modification of targeted policy. Only selected processes are protected.
# mls - Multi Level Security protection.
SELINUXTYPE=targeted
35.字符集修改
centos7:
vim /etc/locale.conf
LANG="zh_CN.UTF-8"
source /etc/locale.conf
centos6:
vi /etc/sysconfig/i18n
LANG="zh_CN.UTF-8"
SYSFONT="latarcyrheb-sun16"
source /etc/sysconfig/i18n