目录 🌻🌻
一、 目录管理
1.1 绝对路径和相对路径
- 我们知道Linux的目录结构为树状结构,最顶级的目录为根目录 /。其他目录通过挂载可以将它们添加到树中,通过解除挂载可以移除它们。在开始总结前我们需要先知道什么是绝对路径与相对路径。
1.1.1 绝对路径
路径的写法,由根目录 / 写起,例如:/usr/share/doc 这个目录。
1.1.2 相对路径
路径的写法,不是由 / 写起,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成:cd . . /man 这就是相对路径的写法啦!
1.2 处理目录的常用命令
接下来就来看几个常见的处理目录的命令吧:
ls: 列出目录
cd:切换目录
pwd:显示目前的目录
mkdir:创建一个新的目录
rmdir:删除一个空的目录
cp: 复制文件或目录
rm: 移除文件或目录
mv: 移动文件与目录,或修改文件与目录的名称
你可以使用 man [命令] 来查看各个命令的使用文档,如 :man cp。
ls (列出目录)
在Linux系统当中, ls 命令可能是最常被运行的。
语法:
[root@www ~]# ls [-aAdfFhilnrRSt] 目录名称
选项与参数:
- -a :全部的文件,连同隐藏文件( 开头为 . 的文件) 一起列出来(常用)
- -l :长数据串列出,包含文件的属性与权限等等数据;(常用)
将目录下的所有文件列出来(含属性与隐藏档)
[root@www ~]# ls -al ~
cd (切换目录)
cd是Change Directory的缩写,这是用来变换工作目录的命令。
语法:
cd [相对路径或绝对路径]
测试:
# 切换到用户目录下
[root@bogon ~]# cd /home/
# 使用 mkdir 命令创建 DanielSS目录
[root@bogon home]# mkdir DanielSS
# 进入 DanielSS目录
[root@bogon DanielSS]# cd ..
# 回到上一级
[root@bogon DanielSS]# cd ..
# 回到根目录
[root@bogon /]# cd /
# 表示回到自己的家目录,亦即是 /root 这个目录
[root@bogon DanielSS]# cd ~
接下来大家多操作几次应该就可以很好的理解 cd 命令的。
pwd ( 显示目前所在的目录 )
pwd 是 Print Working Directory 的缩写,也就是显示目前所在目录的命令。
[root@bogon ~]# pwd
/root
选项与参数:-P :显示出确实的路径,而非使用连接(link) 路径。
测试:
# 单纯显示出目前的工作目录
[root@bogon /]# pwd
/
# 如果是链接,要显示真实地址,可以使用 -P参数
[root@bogon bin]# cd /
[root@bogon /]# cd usr/
[root@bogon usr]# cd bin/
[root@bogon bin]# pwd
/usr/bin
mkdir (创建新目录)
如果想要创建新的目录的话,那么就使用mkdir (make directory)吧。
mkdir [-mp] 目录名称
选项与参数:
- -m :配置文件的权限喔!直接配置,不需要看默认权限 (umask) 的脸色~
- -p :帮助你直接将所需要的目录(包含上一级目录)递归创建起来!
测试:
# 进入我们用户目录下
[root@bogon]# cd /home
# 创建一个 test 文件夹
[root@bogon home]# mkdir test
# 创建多层级目录
[root@bogon home]# mkdir test1/test2/test3/test4
mkdir: cannot create directory ‘test1/test2/test3/test4’:
No such file or directory # <== 没办法直接创建此目录啊!
# 加了这个 -p 的选项,可以自行帮你创建多层目录!
[root@bogon home]# mkdir -p test1/test2/test3/test4
# 创建权限为 rwx--x--x 的目录。
[root@bogon home]# mkdir -m 711 test2
[root@bogon home]# ls -l
total 0
drwxr-xr-x. 2 root root 6 Aug 1 14:11 DanielSS
drwxr-xr-x. 2 root root 6 Aug 1 14:09 DanielStudy
drwxr-xr-x. 2 root root 6 Aug 1 14:22 test
drwxr-xr-x. 3 root root 19 Aug 1 14:23 test1
drwx--x--x. 2 root root 6 Aug 1 14:23 test2
[root@bogon home]#
rmdir ( 删除空的目录 )
选项与参数:-p :连同上一级『空的』目录也一起删除
测试:
# 看看有多少目录存在?
# 看看有多少目录存在?
[root@bogon home]# ls -l
drwxr-xr-x 2 root root 4096 Mar 12 21:55 test
drwxr-xr-x 3 root root 4096 Mar 12 21:56 test1
drwx--x--x 2 root root 4096 Mar 12 21:58 test2
# 可直接删除掉,没问题
[root@bogon home]# rmdir test
# 因为尚有内容,所以无法删除!
[root@bogon home]# rmdir test1
rmdir: failed to remove ‘test1’: Directory not empty
# 利用 -p 这个选项,立刻就可以将 test1/test2/test3/test4 依次删除。
[root@bogon home]# rmdir -p test1/test2/test3/test4 ls -l
drwxr-xr-x 2 root root 4096 Mar 12 21:55 test
drwxr-xr-x 3 root root 4096 Mar 12 21:56 test1
drwx--x--x 2 root root 4096 Mar 12 21:58 test2
# 可直接删除掉,没问题
[root@bogon home]# rmdir test
# 因为尚有内容,所以无法删除!
[root@bogon home]# rmdir test1
rmdir: failed to remove ‘test1’: Directory not empty
# 利用 -p 这个选项,立刻就可以将 test1/test2/test3/test4 依次删除。
[root@bogon home]# rmdir -p test1/test2/test3/test4
注意:这个 rmdir 仅能删除空的目录,你可以使用 rm 命令来删除非空目录,后面我们会将!
cp ( 复制文件或目录 )
语法:
[root@www ~]# cp [-adfilprsu] 来源档(source) 目标档(destination)
[root@www ~]# cp [options] source1 source2 source3 .... directory
选项与参数:
- -a:相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用)
- -p:连同文件的属性一起复制过去,而非使用默认属性(备份常用);
- -d:若来源档为连结档的属性(link file),则复制连结档属性而非文件本身;
- -r:递归持续复制,用於目录的复制行为;(常用)
- -f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次;
- -i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用)
- -l:进行硬式连结(hard link)的连结档创建,而非复制文件本身。
- -s:复制成为符号连结档 (symbolic link),亦即『捷径』文件;
- -u:若 destination 比 source 旧才升级 destination !
测试:
# 找一个有文件的目录,我这里找到 root目录
[root@bogon home]# cd /root
[root@bogon ~]# ls
install.sh
[root@bogon ~]# cd /home
# 复制 root目录下的install.sh 到 home目录下
[root@bogon home]# cp /root/install.sh /home
[root@bogon home]# ls
install.sh
# 再次复制,加上-i参数,增加覆盖询问?
[root@bogon home]# cp -i /root/install.sh /home
cp: overwrite ‘/home/install.sh’? y # n不覆盖,y为覆盖
rm ( 移除文件或目录 )
语法:
rm [-fir] 文件或目录
选项与参数:
- -f :就是 force 的意思,忽略不存在的文件,不会出现警告信息;
- -i :互动模式,在删除前会询问使用者是否动作
- -r :递归删除啊!最常用在目录的删除了!这是非常危险的选项!!!
测试:
# 将刚刚在 cp 的实例中创建的 install.sh删除掉!
[root@bogon home]# rm -i install.sh
rm: remove regular file ‘install.sh’? y
# 如果加上 -i 的选项就会主动询问喔,避免你删除到错误的档名!
# 尽量不要在服务器上使用 rm -rf /
mv ( 移动文件与目录,或修改名称 )
语法:
[root@www ~]# mv [-fiu] source destination
[root@www ~]# mv [options] source1 source2 source3 .... directory
选项与参数:
- -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
- -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
- -u :若目标文件已经存在,且 source 比较新,才会升级 (update)
测试:
# 复制一个文件到当前目录
[root@bogon home]# cp /root/install.sh /home
# 创建一个文件夹 test
[root@bogon home]# mkdir test
# 将复制过来的文件移动到我们创建的目录,并查看
[root@bogon home]# mv install.sh test
[root@bogon home]# ls
test
[root@bogon home]# cd test
[root@bogon test]# ls
install.sh
# 将文件夹重命名,然后再次查看!
[root@bogon test]# cd ..
[root@bogon home]# mv test mvtest
[root@bogon home]# ls
mvtest
二、 基本属性
2.1 看懂文件属性
Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。
在Linux中我们可以使用ll或者ls –l
命令来显示一个文件的属性以及文件所属的用户和组,如:
实例中,boot文件的第一个属性用"d"表示。"d"在Linux中代表该文件是一个目录文件。
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等:
- 当为[ d ]则是目录
- 当为[ - ]则是文件;
- 若是[ l ]则表示为链接文档 ( link file );
- 若是[ b ]则表示为装置文件里面的可供储存的接口设备 ( 可随机存取装置 );
- 若是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标 ( 一次性读取装置 )。
接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。
其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。
要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]而已。
每个文件的属性由左边第一部分的10个字符来确定(如下图):
从左至右用0-9这些数字来表示。
第0位确定文件类型,第1-3位确定属主(该文件的所有者)拥有该文件的权限。第4-6位确定属组(所有者的同组用户)拥有该文件的权限,第7-9位确定其他用户拥有该文件的权限。
其中:
第1、4、7位表示读权限,如果用"r"字符表示,则有读权限,如果用"-"字符表示,则没有读权限;
第2、5、8位表示写权限,如果用"w"字符表示,则有写权限,如果用"-"字符表示没有写权限;
第3、6、9位表示可执行权限,如果用"x"字符表示,则有执行权限,如果用"-"字符表示,则没有执行权限。
对于文件来说,它都有一个特定的所有者,也就是对该文件具有所有权的用户。
同时,在Linux系统中,用户是按组分类的,一个用户属于一个或多个组。
文件所有者以外的用户又可以分为文件所有者的同组用户和其他用户。
因此,Linux系统按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限。
在以上实例中,boot 文件是一个目录文件,属主和属组都为 root。
2.2 修改文件属性
1、chgrp:更改文件属组
chgrp [-R] 属组名 文件名
-R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。
2、chown:更改文件属主,也可以同时更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名
3、chmod:更改文件9个属性
chmod [-R] xyz 文件或目录
Linux文件属性有两种设置方法,一种是数字,一种是符号。
Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己的read/write/execute权限。
先复习一下刚刚上面提到的数据:文件的权限字符为:『-rwxrwxrwx』
, 这九个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:
r:4 w:2 x:1
每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为:[-rwxrwx—] 分数则是:
- owner = rwx = 4+2+1 = 7
- group = rwx = 4+2+1 = 7
- others= — = 0+0+0 = 0
chmod 770 filename
可以自己下去多进行测试!
三、文件内容查看
3.1 概述
Linux系统中使用以下命令来查看文件的内容:
- cat 由第一行开始显示文件内容
- tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
- nl 显示的时候,顺道输出行号!
- more 一页一页的显示文件内容
- less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
- head 只看头几行
- tail 只看尾巴几行
你可以使用 man [命令]来查看各个命令的使用文档,如 :man cp。
cat 由第一行开始显示文件内容
语法:
cat [-AbEnTv]
选项与参数:
- -A :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
- -b :列出行号,仅针对非空白行做行号显示,空白行不标行号!
- -E :将结尾的断行字节 $ 显示出来;
- -n :列印出行号,连同空白行也会有行号,与 -b 的选项不同;
- -T :将 [tab] 按键以 ^I 显示出来;
- -v :列出一些看不出来的特殊字符
测试:
# 查看网络配置: 文件地址 /etc/sysconfig/network-scripts/
[root@bogon ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
BOOTPROTO=dhcp
ONBOOT=yes
tac
tac与cat命令刚好相反,文件内容从最后一行开始显示,可以看出 tac 是 cat 的倒着写!如:
[root@bogon ~]# tac /etc/sysconfig/network-scripts/ifcfg-eth0
ONBOOT=yes
BOOTPROTO=dhcp
DEVICE=eth0
nl 显示行号
语法:
nl [-bnw] 文件
选项与参数:
- -b :指定行号指定的方式,主要有两种:-b a :表示不论是否为空行,也同样列出行号(类似 cat -n);-b t :如果有空行,空的那一行不要列出行号(默认值);
- -n :列出行号表示的方法,主要有三种:-n ln :行号在荧幕的最左方显示;-n rn :行号在自己栏位的最右方显示,且不加 0 ;-n rz :行号在自己栏位的最右方显示,且加 0 ;
- -w :行号栏位的占用的位数。
测试:
[root@bogon ~]# nl /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
BOOTPROTO=dhcp
ONBOOT=yes
more 一页一页翻动
在 more 这个程序的运行过程中,你有几个按键可以按的:
- 空白键 (space):代表向下翻一页;
- Enter :代表向下翻『一行』;
- /字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字;
- :f :立刻显示出档名以及目前显示的行数;
- q :代表立刻离开 more ,不再显示该文件内容。
- b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。
[root@bogon etc]# more /etc/csh.login
....(中间省略)....
--More--(28%) # 重点在这一行喔!你的光标也会在这里等待你的命令
less 一页一页翻动,以下实例输出/etc/man.config文件的内容:
less运行时可以输入的命令有:
- 空白键 :向下翻动一页;
- [pagedown]:向下翻动一页;
- [pageup] :向上翻动一页;
- /字串 :向下搜寻『字串』的功能;
- ?字串 :向上搜寻『字串』的功能;
- n :重复前一个搜寻 (与 / 或 ? 有关!)
- N :反向的重复前一个搜寻 (与 / 或 ? 有关!)
- q :离开 less 这个程序;
[root@bogon etc]# more /etc/csh.login
....(中间省略)....
: # 这里可以等待你输入命令!
head 取出文件前面几行
语法:
head [-n number] 文件
选项与参数:-n 后面接数字,代表显示几行的意思!
默认的情况中,显示前面 10 行!若要显示前 20 行,就得要这样:
[root@bogon etc]# head -n 20 /etc/csh.login
tail 取出文件后面几行
语法:
tail [-n number] 文件
选项与参数:
- -n :后面接数字,代表显示几行的意思
默认的情况中,显示最后 10 行!若要显示最后 20 行,就得要这样:
[root@bogon etc]# tail -n 20 /etc/csh.login
拓展:Linux 链接概念
Linux 链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。
情况下,ln 命令产生硬链接。
硬连接
硬连接指通过索引节点来进行连接。在 Linux 的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在 Linux 中,多个文件名指向同一索引节点是存在的。比如:A 是 B 的硬链接(A 和 B 都是文件名),则 A 的目录项中的 inode 节点号与 B 的目录项中的 inode 节点号相同,即一个 inode 节点对应两个不同的文件名,两个文件名指向同一个文件,A 和 B 对文件系统来说是完全平等的。删除其中任何一个都不会影响另外一个的访问。
硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。其原因如上所述,因为对应该目录的索引节点有一个以上的连接。只删除一个连接并不影响索引节点本身和其它的连接,只有当最后一个连接被删除后,文件的数据块及目录的连接才会被释放。也就是说,文件真正删除的条件是与之相关的所有硬连接文件均被删除。
软连接
另外一种连接称之为符号连接(Symbolic Link),也叫软连接。软链接文件有类似于 Windows 的快捷方式。它实际上是一个特殊的文件。在符号连接中,文件实际上是一个文本文件,其中包含的有另一文件的位置信息。比如:A 是 B 的软链接(A 和 B 都是文件名),A 的目录项中的 inode 节点号与 B 的目录项中的 inode 节点号不相同,A 和 B 指向的是两个不同的 inode,继而指向两块不同的数据块。但是 A 的数据块中存放的只是 B 的路径名(可以根据这个找到 B 的目录项)。A 和 B 之间是“主从”关系,如果 B 被删除了,A 仍然存在(因为两个是不同的文件),但指向的是一个无效的链接。
测试:
[root@bogon /]# cd /home
[root@bogon home]# touch f1 # 创建一个测试文件f1
[root@bogon home]# ls
f1
[root@bogon home]# ln f1 f2 # 创建f1的一个硬连接文件f2
[root@bogon home]# ln -s f1 f3 # 创建f1的一个符号连接文件f3
[root@bogon home]# ls -li # -i参数显示文件的inode节点信息
397247 -rw-r--r-- 2 root root 0 Mar 13 00:50 f1
397247 -rw-r--r-- 2 root root 0 Mar 13 00:50 f2
397248 lrwxrwxrwx 1 root root 2 Mar 13 00:50 f3 -> f1
从上面的结果中可以看出,硬连接文件 f2 与原文件 f1 的 inode 节点相同,均为 397247,然而符号连接文件的 inode 节点不同。
# echo 字符串输出 >> f1 输出到 f1文件
[root@bogon home]# echo "I am f1 file" >>f1
[root@bogon home]# cat f1
I am f1 file
[root@bogon home]# cat f2
I am f1 file
[root@bogon home]# cat f3
I am f1 file
[root@bogon home]# rm -f f1
[root@bogon home]# cat f2
I am f1 file
[root@bogon home]# cat f3
cat: f3: No such file or directory
通过上面的测试可以看出:当删除原始文件 f1 后,硬连接 f2 不受影响,但是符号连接 f1 文件无效;
依此您可以做一些相关的测试,可以得到以下全部结论:
- 删除符号连接f3,对f1,f2无影响;
- 删除硬连接f2,对f1,f3也无影响;
- 删除原文件f1,对硬连接f2没有影响,导致符号连接f3失效;
- 同时删除原文件f1,硬连接f2,整个文件会真正的被删除。
四、Vim使用及账号用户管理 (菜鸟网)
4.1 什么是Vim编辑器
Vim是从 vi 发展出来的一个文本编辑器。代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。简单的来说, vi 是老式的字处理器,不过功能已经很齐全了,但是还是有可以进步的地方。vim 则可以说是程序开发者的一项很好用的工具。所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在。连 vim 的官方网站 (官网) 自己也说 vim 是一个程序开发工具而不是文字处理软件。
vim 键盘图:
三种使用模式
基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)。这三种模式的作用分别是:
命令模式:
用户刚刚启动 vi/vim,便进入了命令模式。
此状态下敲击键盘动作会被Vim识别为命令,而非输入字符。比如我们此时按下i,并不会输入一个字符,i被当作了一个命令。
以下是常用的几个命令:
- i 切换到输入模式,以输入字符。
- x 删除当前光标所在处的字符。
- : 切换到底线命令模式,以在最底一行输入命令。
若想要编辑文本:启动Vim,进入了命令模式,按下i,切换到输入模式。
命令模式只有一些最基本的命令,因此仍要依靠底线命令模式输入更多命令。
输入模式:
在命令模式下按下i就进入了输入模式。
在输入模式中,可以使用以下按键:
- 字符按键以及Shift组合,输入字符
- ENTER,回车键,换行
- BACK SPACE,退格键,删除光标前一个字符
-DEL,删除键,删除光标后一个字符- 方向键,在文本中移动光标
- HOME/END,移动光标到行首/行尾
- Page Up/Page Down,上/下翻页
- Insert,切换光标为输入/替换模式,光标将变成竖线/下划线
- ESC,退出输入模式,切换到命令模式
底线命令模式
在命令模式下按下:(英文冒号)就进入了底线命令模式。
底线命令模式可以输入单个或多个字符的命令,可用的命令非常多。
在底线命令模式中,基本的命令有(已经省略了冒号):
- q 退出程序
- w 保存文件
按ESC键可随时退出底线命令模式。
简单的说,我们可以将这三个模式想成底下的图标来表示:
上手体验一下,在home目录下测试
如果你想要使用 vi 来建立一个名为 Daniel.txt 的文件时,你可以这样做:
[root@bogon home]# vi Daniel.txt
然后就会进入文件
按下 i 进入输入模式(也称为编辑模式),开始编辑文字
在一般模式之中,只要按下 i, o, a 等字符就可以进入输入模式了!
在编辑模式当中,你可以发现在左下角状态栏中会出现 –INSERT- 的字样,那就是可以输入任意字符的提示。
这个时候,键盘上除了 Esc 这个按键之外,其他的按键都可以视作为一般的输入按钮了,所以你可以进行任何的编辑。
按下 ESC 按钮回到一般模式
好了,假设我已经按照上面的样式给他编辑完毕了,那么应该要如何退出呢?是的!没错!就是给他按下 Esc 这个按钮即可!马上你就会发现画面左下角的 – INSERT – 不见了!
在一般模式中按下 :wq 储存后离开 vim!
OK! 这样我们就成功创建了一个 Daniel.txt 的文件。
Vim 按键说明 👉🏾👉🏾 菜鸟
五、 用户管理 (菜鸟网)
六、 磁盘管理 (菜鸟网)
七、Linux基础命令大全
Linux基础命令大全
系统密令
网络环境配置文件
查看ip信息
ifconfig
临时设置ip
ifconfig eth0 192.168.20.3
永久设置ip
vim /etc/sysconfig/network-scripts/ifcfg-eth0
查看防火墙信息
查看第一道防火墙是否关闭 iptable -L
查看第二道防火墙是否关闭 sestatus
关闭防火墙
iptables -F 清除预设表filter中的所有规则链的规则
启动方式
init 0 关机
init 6 重启
修改运行级别 图形/密令行
etc/inittab文件
查看当前路径
pwd
查看当前目录文件
dir ls ls-al/ll
清屏
crtl+l/clear
临时中断当前操作
crtl+c
挂载光驱
mount /dev/cdrom /media
根目录下核心目录
./mnt #测试目录
./root #root用户的家目录
./home #普通用户的家目录
./tmp #临时目录(比如文件上传时)
./var #存放软件日志的地方
./boot #系统启动文件
./etc #系统默认放置配置文件的地方
./bin #所有用户都能执行的程序
./sbin #只有root才能执行的程序
./usr #用户自己的软件都可以放到这儿来
./dev #存放硬件设备的地方(/dev/cdrom)
./media #挂载光盘使用的
文件管理
# 创建文件
touch file1
# 删除文件
rm -rf file11
# 修改文件名
mv file1 file11
# 查看文件内容
cat file1
# 复制文件
cp file2 file22
# 移动文件
mv file1 file11
# 编辑文件
vi file1
# 批量创建文件
touch file{1..10}
# 查看文件前3行
cat file1 | head -3
# 查看文件后3行
cat file1 | tail -3
# 查找文件
1)find
find / -name httpd.conf
2)updatedb
locate httpd.conf
# 查找文件内容
cat httpd.conf | grep -i listen
vi编辑器使用
命令模式和编辑模式切换
a:光标向后移动一位进入编辑模式
i:光标和内容没有变化进入编辑模式
o:新起一行进入编辑模式
s:删除光标所在字符进入编辑模式
尾行模式操作
命令模式下进行
# 对编辑后文档进行保存
:w
#退出vi编辑器
:q
#保存后退出vi编辑器
:wq
#强制退出
:q!
#强制保存退出
:wq!
#给编辑器设置行号
:set number 或者 nu
#取消行号设置
:set nonumber 或者 nonu
#光标定位到第n行
:n(数字)
:/内容/ 或 /内容
#内容查找
(n下一个N上一个)
# 内容替换
:s/cont1/cont2/ #cont1替换为cont2 替换光标所在行的第一个目标
:s/cont1/cont2/g #cont1替换为cont2 替换光标所在行的所有目标
:%s/cont1/cont2/g #cont1替换为cont2 替换文档所有目标
命令模式有哪些命令
h 左
j 下
k 上
l 右
dd 删除一行,剪切一行(ndd)
G 最后一行
1G 第一行 nG第几行
yy 复制当前行
3yy 复制三行
r 单字符替换
p 粘贴到下一行
2p 重复粘贴两次
P 粘贴上一行
u 撤销
ctrl+y 恢复
x 删除当前字符,3x删除三个字符
dG 从当前行删除到最后一行
d1G从当前行删除到第一行
dw 删除一个单词
d^ 从当前字符删除到行首
d$ 从当前字符删除到行末
v 按v键再按上下左右进行视图选中,进行快速缩进(选区块)
/hello 查找hello单词,查找多个n键
# 光标移动
# 字符集移动
上下左右键/KJHL
# 单词集移动
:w word #下个单词首字母
:b before #上(本)个单词的单词首字母
:e end #下(本)个单词尾字母
# 行集移动
$ #定义到行尾
0/^ #定义到行首
# 段落集移动
{ #定义到上(本)个段落首部
} #定义到下(本)个段落尾部
# 屏幕集移动
H #当前屏幕首部
L #当前屏幕尾部
# 文档集移动
G #文档尾部
1G #文档首部
nG #文档第n行
# 删除内容
dd #删除光标当前行
n+dd #向后删除n行内容(包括当前行)
x #删除光标所在的字符
c+w #从光标所在位置删除至单词的结尾(同时变为 编辑模式)
# 复制内容
yy #复制光标当前行
n+yy #向后复制n行内容(包括当前行)
p #对复制(删除)后的内容进行粘贴操作
# 快捷操作
r+字符 #快速替换单个字符
u #撤销undo
. #点,重复执行上一次命令
J #大写J,合并两行
目录操作
# 创建目录
mkdir dir1 dir2 dir3
# 删除目录
rm -rf dir1 dir2
# 重命名目录或移动目录
mv dir1 dir11
# 查看目录
ls
# 递归创建目录
mkdir -p a/b/c/d/e/f/g
# 递归查看目录
tree a
用户管理
# 添加用户
useradd user2
# 设置密码
passwd user1
# 删除用户
userdel -r user1
# 查看用户
id user1
别名管理
# 添加别名
alias chttp='cat /etc/httpd/conf/httpd.conf'
# 删除别名
unalias chttp
# 查看别名
alias
zip压缩包
# 制作
zip -r myshop15.zip myshop15
# 解压
unzip myshop15.zip
# 查看
unzip -l myshop15.zip
gz压缩包
# 制作
tar czf myshop15.tar.gz myshop15
# 解压
tar xzf myshop15.tar.gz
# 查看
tar tf myshop15.tar.gz
权限操作
字母相对方式设置权限
chmod u+/-rwx,g+/-rwx,o+/-rwx filename
chmod u+r,u-x filename
chmod +w,-x filename
chmod u+rx filename
chmod g-wx filename
组别每次可以设置一个或多个
具体权限(rwx)可以一次性设置一个或多个
+/-增加、减少权限需要分别设置
可以统一为各个组别设置上统一的权限
普通用户只能给自己"家目录"的文件设置权限。
数字绝对方式设置权限
读: 4
写: 2
执行:1
0----->没有权限
1----->执行 权限
2----->写 权限
3----->写、执行 权限
4----->读 权限
5----->读、执行 权限
6----->读、写 权限
7----->读、写、执行 权限
chmod ABC filename
ABC是三个数字,分别代表主人、同组、其他组用户权限
chmod 642 passwd
主人:读、写
同组:读
其他:写
字母和数字两种方式的取舍
① 权限修改【较少】使用字母方式
② 权限修改【较多】使用数字方式
软链接与硬链接
软链接:ln -s /dir1 /dir2 dir1为绝对路径,创建dir1的软链接dir2。相当于快捷方式,dir1占内存,dir2为快捷方式
硬链接 :ln -d /dir1 /dir2 复制dir1下的内容到dir2,dir2相对dir1是一个独立的文件
Centos7
修改主机名
要查看主机名相关的设置
hostnamectl
hostnamectl status
只查看静态、瞬态或灵活主机名,分别使用–static,–transient或–pretty选项
hostnamectl --static
hostnamectl --transient
hostnamectl --pretty
要同时修改所有三个主机名:静态、瞬态和灵活主机名
hostnamectl set-hostname qqmm
hostnamectl --pretty
hostnamectl --static
hostnamectl --transient
修改启动运行级别
# 获取当前默认启动模式
systemctl get-default
# 重新设置默认启动模式
systemctl set-default multi-user.target
systemctl set-default graphical.target
破解密码
CentOS 7 破解密码教程
1.启动时任意键暂停启动
2.按e键进入编辑模式
3.将光标移动linux16开始的行,(末置位)添加内核参数rd.break
或者将ro改为rw init=/sysroot/bin/sh
4.按ctrl-x启动
5.mount –o remount,rw /sysroot
6.chroot /sysroot
7.passwd root
重复两次输入密码
8.touch /.autorelabel
9.exit
10.reboot