1.os概念,定位

操作系统是一款管理软件,管理硬件和软件。对上提供良好、稳定和安全、高效的运行环境;对下管理好软硬件资源。
查看Linux主机ip:在终端下敲 ifconfig 指令, 查看到 ip 地址。。
使用XSHell登录主机:在XSHell终端写:ssh [ip]。ip 为刚才看到的 ifconfig 结果.
如果网络畅通, 将会提示输入用户名密码. 输入即可正确登陆。
XSHell下的复制黏贴:
复制: ctrl + insert (有些同学的 insert 需要配合 fn 来按) 粘贴: shift + insert ctrl + c / ctrl + v 是不行的
3.ls指令
语法: ls [选项][目录或文件]
功能:对于目录,该命令列出该目录下的所有子目录与文件。对于文件,将列出文件名以及其他信息
常用选项:
-a 列出目录下的所有文件,包括以 . 开头的隐含文件。
-d 将目录象文件一样显示,而不是显示其下的文件。 如: ls –d 指定目录
-i 输出文件的 i 节点的索引信息。 如 ls –ai 指定文件
-k 以 k 字节的形式表示文件的大小。 ls –alk 指定文件
-l 列出文件的详细信息。
-n 用数字的 UID,GID 代替名称。 (介绍 UID, GID)
-F 在每个文件名后附上一个字符以说明该文件的类型, “*”表示可执行的普通文件; “/”表示目录; “@”表示符号链接; “|”表示FIFOs; “=”表示套接字(sockets)。(目录类型识别)
-r 对目录反向排序。
-t 以时间排序。
-s 在l文件名后输出该文件的大小。(大小排序,如何找到目录下最大的文件)
-R 列出所有子目录下的文件。 (递归)
-1 一行只输出一个文件。
这里列出今天刚刚学习到的:
①ls指令:显示当前路径下的文件或者目录名称。

编辑
②ls -l指令:显示当前路径下的文件或者目录的更详细的属性信息。
PS:文件 = 文件内容数据+文件属性数据。因此文件本身是需要占用空间的,即使是空文件,显示0KB,但其属性是占用空间的。文件之间(普通文件 VS 目录):普通文件就是普通的文件,目录现在可以人为是文件夹。
![2KU4T13I[_H{][LD`A094WE.png 2KU4T13I[_H{][LD`A094WE.png](https://ucc.alicdn.com/pic/developer-ecology/ipajprmaanvwy_0f67765724ea4df7a66708b6cee68edf.png)
③ls -a 与ls -al指令:
ls -a显示目录下的所有文件,包括以.开头的隐藏文件。
ls -al是ls -a和ls -l的结合,显示更详细的属性信息

4.pwd指令
语法: pwd
功能:显示用户当前所在的目录
5.cd指令
语法:cd 目录名
功能:改变工作目录。将当前工作目录改变到指定的目录下。
cd .. : 返回上级目录。
cd /home/litao/linux/ : 绝对路径。
cd ../day02/ : 相对路径。
cd ~:进入用户家目。
cd -:返回最近访问目录。
cd指令:切换路径,进入目标路径进行操作。
cd . 和cd .. 指令 :cd .是当前目录 cd ..是返回上级目录 。
cd ~指令:进入家目录。root的家目录是单独的,而所有用户的家目录,都是在/home/XXX。这里显示root家目录。
cd -指令:返回最近访问目录。可以理解为在两个目录下反复横跳。
在分析绝对路径和相对路径前,先要知道Linux系统中,磁盘上的文件和目录被组成一棵目录树,每个节点都是目录或文件。其实几乎任何操作系统文件的目录组织结构是一颗多叉树。
多叉树,有叶子节点和路上节点(其实就是父节点,或非叶子节点,在Linux下这样称呼比较好理解),路上节点一定只能是目录,而叶子节点,可以是普通文件,也可以是空目录。
而我们为什么喜欢用路径来表示一个文件?因为,从根目录到一个文件的路径,是唯一的!尽管某个文件有很多个,放在不同的目录里面,但是,我们可以通过路径,找到那个唯一!
因此,这里分为绝对路径和相对路径。
cd /home/litao/linux/ : 绝对路径。就是直接从根目录开始往下走。
cd ../day02/ : 相对路径。就是,如果我们在处于某个目录中,但是想找到另外的目录中的文件,不需要返回根目录,而是可以通过这个目录,更换到目标目录中,接着找到目标文件。
语法:touch [选项]... 文件...
功能: touch命令参数可更改文档或目录的日期时间,包括存取时间和更改时间,或者新建一个不存在的文件。
常用选项:
-a 或--time=atime或--time=access或--time=use只更改存取时间。
-c 或--no-create 不建立任何文档。
-d 使用指定的日期时间,而非现在的时间。
-f 此参数将忽略不予处理,仅负责解决BSD版本touch指令的兼容性问题。
-m 或--time=mtime或--time=modify 只更改变动时间。
-r 把指定文档或目录的日期时间,统统设成和参考文档或目录的日期时间相同。
-t 使用指定的日期时间,而非现在的时间
touch指令就是在Linux下用来创建普通文件的指令
语法: mkdir [选项] dirname...
功能:在当前目录下创建一个名为 “dirname”的目录
-p, --parents 可以是一个路径名称。此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录。即在使用mkdir命令创建新的目录时,在其父目录不存在时先创建父目录的指令就是 mkdir -p XXX/XXX
8.rmdir指令&&rm指令
rmdir是一个与mkdir相对应的命令。 mkdir是建立目录,而rmdir是删除命令。
语法: rmdir [-p][dirName]
适用对象:具有当前目录操作权限的所有使用者
功能:删除空目录
常用选项:
-p 当子目录被删除后如果父目录也变成空目录的话,就连带父目录一起删除
rm命令可以同时删除文件或目录
语法: rm [-f-i-r-v][dirName/dir]
适用对象:所有使用者
功能:删除文件或目录(rm默认删除普通文件,加上-r,即可删除目录)
常用选项:
-f 即使文件属性为只读(即写保护),亦直接删除
-i 删除前逐一询问确认
-r 删除目录及其下所有文件
9.man指令
inux的命令有很多参数,我们不可能全记住,我们可以通过查看联机手册获取帮助。也就是说:man是一个查看命令、系统调用、C接口的一个手册。man默认从1号手册开始查找,找到即停。man可以根据手册查找:man 1/2/3 命令/接口/C。
访问Linux手册页的命令是:
man 语法: man [选项] 命令
常用选项
-k 根据关键字搜索联机帮助
num 只在第num章节找
-a 将所有章节的都显示出来,比如 man printf 它缺省从第一章开始搜索,知道就停止,用a选项,当按下q退出,他会继续往后面搜索,直到所有章节都搜索完毕。
解释一下,面手册分为8章
1 是普通的命令
2 是系统调用,如open,write之类的(通过这个,至少可以很方便的查到调用这个函数,需要加什么头文件)
3 是库函数,如printf,fread4是特殊文件,也就是/dev下的各种设备文件
5 是指文件的格式,比如passwd, 就会说明这个文件中各个字段的含义
6 是给游戏留的,由各个游戏自己定义
7 是附件还有一些变量,比如向environ这种全局变量在这里就有说明
8 是系统管理用的命令,这些命令只能由root使用,如ifconfig
10. cp指令
语法: cp [选项] 源文件或目录 目标文件或目录
功能: 复制文件或目录
说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中。若同时指定多个文件或目录,而最后的目的地并非一个已存在的目录,则会出现错误信息。
cp拷贝目录或者文件,-r -f -i 同rm
a firstfile new_firstdir test.txt
drwxr-xr-x 3 root root 4096 Sep 18 10:33 b
-rw-r--r-- 1 root root 168908 Sep 27 15:47 test.txt

11. mv指令
mv命令是move的缩写,可以用来移动文件或者将文件改名(move (rename) files),是Linux系统下常用的命令,经常用来备份文件或者目录。
1.mv的功能类似剪切功能,移动目录或文件。 2.对文件或目录重命名
语法: mv [选项] 源文件或目录 目标文件或目录
功能:
1. 视mv命令中第二个参数类型的不同(是目标文件还是目标目录), mv命令将文件重命名或将其移至一个新的目录中。
2. 当第二个参数类型是文件时, mv命令完成文件重命名,此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名。
3. 当第二个参数是已存在的目录名称时,源文件或目录参数可以有多个, mv命令将各参数指定的源文件均移至目标目录中。
常用选项:
-f : force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖
-i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
/root/new_firstdir
[root@VM-12-9-centos new_firstdir]
total 0
[root@VM-12-9-centos new_firstdir]
aaa

12. cat指令
语法: cat [选项][文件] 功能: 查看目标文件的内容
常用选项:
-b 对非空输出行编号
-n 对输出的所有行编号
-s 不输出多行空行
a firstfile new_firstdir test.txt
]
hello 106 [0]
hello 106 [1]
hello 106 [2]
hello 106 [3]
hello 106 [4]
hello 106 [5]
hello 106 [6]
hello 106 [7]
hello 106 [8]
hello 106 [9]
hello 106 [10]

另外,还有一个类似的指令:tac。
它的功能,也是cat一样的,打印、显示。不过,cat和tac的打印的顺序是相反的。
hello 106 [10000]
hello 106 [9999]
hello 106 [9998]
hello 106 [9997]
hello 106 [9996]
hello 106 [9995]
hello 106 [9994]
hello 106 [9993]
hello 106 [9992]
hello 106 [9991]
hello 106 [9990]

13. more指令
语法: more [选项][文件]
功能: more命令,功能类似 cat
常用选项:
-n 对输出的所有行编号
q 退出more
对于上面的cat或tac指令,上面其实是有一万个数据,如果我们需要查找第5千个数据的时候,需要不断的往上或往下翻阅,这其实是很麻烦的,因此,more指令可以解决这样的问题。
总的来说:cat和tac适合比较小的文本或者代码段,而more和接下来要说的less指令,适合大的(日志之类的).
hello 106 [4985]
hello 106 [4986]
hello 106 [4987]
hello 106 [4988]
hello 106 [4989]
hello 106 [4990]
hello 106 [4991]
hello 106 [4992]
hello 106 [4993]
hello 106 [4994]
hello 106 [4995]
hello 106 [4996]
hello 106 [4997]
hello 106 [4998]
hello 106 [4999]

14. less指令
less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。
less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!
除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜。
语法: less [参数] 文件
功能:
less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件
选项:
-i 忽略搜索时的大小写
-N 显示每行的行号
/字符串:向下搜索“字符串”的功能
?字符串:向上搜索“字符串”的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
q:quit
15. head指令
head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块, head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾
语法: head [参数]... [文件]...
功能:
head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。
选项:-n<行数> 显示的行数
hello 106 [0]
hello 106 [1]
hello 106 [2]
hello 106 [3]
hello 106 [4]
hello 106 [5]
hello 106 [6]
hello 106 [7]
hello 106 [8]
hello 106 [9]

16. tail指令
ail 命令从指定点开始将文件写到标准输出.使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容
语法: tail[必要参数][选择参数][文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
选项: -f 循环读取
-n<行数> 显示行数
hello 106 [9998]
hello 106 [9999]
hello 106 [10000]

这里插入一个点:管道。就当提前预习:
如果,我想取中间十行的数据【1000,1010】,怎么办。
有两种方法:第一种,是创建一个文件来接收前1010,然后再读取这个文件的后10行,但是这样很麻烦,而已要创建文件。
所以,第二种方法是利用管道:这里先浅浅地理解什么是管道:管道是传输资源的东西,一般都要有一个入口一个出口。那么:
下面代码中:' | '就是管道,可以将head看成管道的入口,tail看成管道的出口,而管道里面,先放进了前面的"head -1010 test.txt"的数据,然后tail再从管道里面取"tail -3"的数据。
hello 106 [1000]
hello 106 [1001]
hello 106 [1002]

那么,我们将这里是数据,进行逆序,那么,再加跟管道进去就好了!
hello 106 [1002]
hello 106 [1001]
hello 106 [1000]

17.时间相关的指令
date显示
date 指定格式显示时间: date +%Y:%m:%d
date 用法: date [OPTION]... [+FORMAT]
1.在显示方面,使用者可以设定欲显示的格式,格式设定为一个加号后接数个标记,其中常用的标记列表如下
%H : 小时(00..23)
%M : 分钟(00..59)
%S : 秒(00..61)
%X : 相当于 %H:%M:%S
%d : 日 (01..31)
%m : 月份 (01..12)
%Y : 完整年份 (0000..9999)
%F : 相当于 %Y-%m-%d
2.在设定时间方面
date -s //设置当前时间,只有root权限才能设置,其他只能查看。
date -s 20080523 //设置成20080523,这样会把具体时间设置成空00:00:00
date -s 01:01:01 //设置具体时间,不会对日期做更改
date -s “01:01:01 2008-05-23″ //这样可以设置全部时间
date -s “01:01:01 20080523″ //这样可以设置全部时间
date -s “2008-05-23 01:01:01″ //这样可以设置全部时间
date -s “20080523 01:01:01″ //这样可以设置全部时间
3.时间戳
时间->时间戳: date +%s
时间戳->时间: date -d@1508749502
Unix时间戳(英文为Unix epoch, Unix time, POSIX time 或 Unix timestamp)是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒
18.cal指令
cal命令可以用来显示公历(阳历)日历。公历是现在国际通用的历法,又称格列历,通称阳历。 “阳历”又名“太阳历”,系以地球绕行太阳一周为一年,为西方各国所通用,故又名“西历”
命令格式: cal [参数][月份][年份]
功能: 用于查看日历等时间信息,如只有一个参数,则表示年份(1-9999),如有两个参数,则表示月份和年份
常用选项:
-3 显示系统前一个月,当前月,下一个月的月历
-j 显示在当年中的第几天(一年日期按天算,从1月1号算起,默认显示当前月在一年中的天数)
-y 显示当前年份的日历
19 find质指令:-name
Linux下find命令在目录结构中搜索文件,并执行指定的操作。
Linux下find命令提供了相当多的查找条件,功能很强大。由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下。
即使系统中含有网络文件系统( NFS), find命令在该文件系统中同样有效,只你具有相应的权限。
在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统)
语法: find pathname -options
功能: 用于在文件树种查找文件,并作出相应的处理(可能访问磁盘,进而导致效率低下)
常用选项:-name 按照文件名查找文件
[root@VM-12-9-centos ~]
total 12
a
firstfile
lesson4
_firstdir
a/test.txt
a/lesson4/test.txt
lesson4/test.txt
lesson4]
total 168
test.txt
lesson4]
/root/firstfile

拓展关于搜索查找的指令:
①which 用来查找命令的路径的指令
/usr/bin/pwd
alias rm='rm -i'
/usr/bin/rm

这里有个指令:alias,它用于对一个指令进行重命名。于此同时,当我们执行ll或ls指令的时候,会发现,文件和目录的颜色不一样,那是因为alias带上了colors的指令。
alias ls='ls --color=auto'

②whereis:在特定的路径下,查找指定的文件名对应的指令或者文档
ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz
test: /usr/bin/test /usr/share/man/man1/test.1.gz

20. grep指令
文本内容的过滤工具,对文本内容进行匹配,匹配成功的进行行显示
语法: grep [选项] 搜寻字符串 文件
功能: 在文件中搜索字符串,将找到的行打印出来
常用选项:
-i :忽略大小写的不同,所以大小写视为相同
-n :顺便输出行号
-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行
hello 106 [9999]
hello 106 [999]
hello 106 [1999]
hello 106 [2999]
hello 106 [3999]
hello 106 [4999]
hello 106 [5999]
hello 106 [6999]
hello 106 [7999]
hello 106 [8999]
hello 106 [9990]
hello 106 [9991]
hello 106 [9992]
hello 106 [9993]
hello 106 [9994]
hello 106 [9995]
hello 106 [9996]
hello 106 [9997]
hello 106 [9998]
hello 106 [9999]

-n带上行号:
1000:hello 106 [999]
2000:hello 106 [1999]
3000:hello 106 [2999]
......

-i:
abc
abc
abc
abc
ABC
aBc
Abc
abc
abc
ABC
x
x

-v:就是反向。
补充1:wc -l 统计行数

补充2:sort 按照ASCII码进行排序(升序)
total 180
a
file.txt
firstfile
lesson4
new_firstdir
test.txt
111111
2222
33333
44444444
66666
555555
7777
111111
2222
33333
44444444
555555
66666
7777

补充3:uniq 对文本内容中,相邻,相等的,去重。
111111
2222
33333
44444444
66666
555555
7777
7777
7777
7777
22222
555555
555555
555555
111111
2222
33333
44444444
66666
555555
7777
22222
555555

我们发现,有一些没有相邻的,没去去重,我们可以利用管道,先进行排序,然后再去重
111111
2222
22222
33333
44444444
555555
555555
555555
555555
66666
7777
7777
7777
7777
111111
2222
22222
33333
44444444
555555
66666
7777

21. zip/unzip指令
语法: zip 压缩文件.zip 目录或文件
功能: 将目录或文件压缩成zip格式
常用选项:
-r 递 归处理,将指定目录下的所有文件和子目录一并处理
例子:
将test2目录压缩: zip test2.zip test2/*
解压到tmp目录: unzip test2.zip -d /tmp
zip默认对一个目录进行打包压缩的时候,只会对目录文件打包压缩,也就是目录文件的内容不达标压缩。于此,需要加上-r递归。
zip -r 你的压缩包(自定义) dir(要打包压缩的目录)
unzip 你的压缩包(自定义)--在当前目录下进行解包解压的功能
# mkdir temp
# ll
total 244
a
file.txt
firstfile
lesson4
my.zip
new_firstdir
temp
test.txt
# mv my.zip temp
# ll
total 188
a
5 file.txt
firstfile
lesson4
53 new_firstdir
temp
test.txt
# cd temp
# ll
total 56
my.zip
# unzip my.zip
Archive: my.zip
creating: a/
creating: a/b/
creating: a/b/c/
creating: a/b/c/d/
inflating: a/test.txt
creating: a/lesson4/
inflating: a/lesson4/test.txt
inflating: a/my.tgz
# ll
total 60
a
my.zip
# tree a
a
|-- b
| `-- c
| `-- d
|-- lesson4
| `-- test.txt
|-- my.tgz
`-- test.txt
4 directories, 3 files
# pwd
/root/temp
# ll
total 60
a
my.zip
# cd a
# ll
total 204
b
lesson4
my.tgz
test.txt
# tree b
b
`-- c
`-- d
2 directories, 0 files
# less test.txt
[3]+ Stopped less test.txt

上面的是解压到当前目录,那么,接下来的指令,便是解压到指定目录中:
unzip my.zip -d /home/XXX或者/root/XXX
# unzip my.zip -d /root/a/b
Archive: my.zip
creating: /root/a/b/a/
creating: /root/a/b/a/b/
creating: /root/a/b/a/b/c/
creating: /root/a/b/a/b/c/d/
inflating: /root/a/b/a/test.txt
creating: /root/a/b/a/lesson4/
inflating: /root/a/b/a/lesson4/test.txt
inflating: /root/a/b/a/my.tgz

22 tar指令:打包/解包,不打开,直接看内容
tar [-cxtzjvf] 文件与目录 ....
参数:
-c :建立一个压缩文件的参数指令(create 的意思);
-x :解开一个压缩文件的参数指令!
-t :查看 tarfile 里面的文件!
-z :是否同时具有 gzip 的属性?亦即是否需要用 gzip 压缩?
-j :是否同时具有 bzip2 的属性?亦即是否需要用 bzip2 压缩?
-v :压缩的过程中显示文件!这个常用,但不建议用在背景执行过程!
-f :使用档名,请留意,在 f 之后要立即接档名喔!不要再加参数!
-C : 解压到指定目录
下面代码中,分别实现了打包压缩和解包的操作:
打包压缩:tar -czf oh.tgz(压缩包名字)lesson4(压缩的目录文件名)(czf:c代表创建一个压缩包,z代表使用z代表的算法,f代表文件名)。
解包:tar -xzf oh.tgz x代表解开压缩包。
如果带个v,-xzvf -cvzf 会把过程显示出来。
~]# ll
total 188
a
file.txt
firstfile
lesson4
firstdir
temp
test.txt
~]# tree lesson4
lesson4
`-- test.txt
0 directories, 1 file
~]# tar -czf oh.tgz lesson4
~]# ll
total 216
a
file.txt
firstfile
lesson4
new_firstdir
oh.tgz
temp
test.txt
~]# mv oh.tgz temp
~]# cd temp
temp]# ll
total 28
oh.tgz
# tar -xzf oh.tgz
# ll
total 32
lesson4
oh.tgz
# tree lesson4
lesson4
`-- test.txt
0 directories, 1 file

不解压,看里面的内容:相当于windows下,点开压缩包,查看里面的东西一样。-t
temp]# tar -tf oh.tgz
lesson4/
lesson4/test.txt

上面的也是默认到当前目录。那么,指定路径解压,就需要 -C 指令
a
file.txt
firstfile
new_firstdir
temp
test.txt
~]# cd temp
temp]# ll
total 32
lesson4
oh.tgz
temp]# tar -xzvf oh.tgz -C ~
lesson4/
lesson4/test.txt
temp]# ls ~
a file.txt firstfile lesson4 new_firstdir temp test.txt

23. bc指令:
bc命令可以很方便的进行浮点运算。
temp]# bc
bc 1.06.95
30-90
-60
3.25-36.3
-33.05
^Z
[5]+ Stopped bc
temp]# echo "1+2+3+4+5+6+7+8+9"
1+2+3+4+5+6+7+8+9
temp]# echo "1+2+3+4+5+6+7+8+9" | bc
45

24. uname -r 指令
语法: uname [选项]
功能: uname用来获取电脑和操作系统的相关信息。
补充说明: uname可显示linux主机所用的操作系统的版本、硬件的名称等基本信息 常用选项:
-a或–all 详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类型,硬件平台类型,操作系统名称
25. 重要的几个热键[TAB],[ctrl]-c,[ctrl]-d
[Tab]按键---具有『命令补全』和『档案补齐』的功能
[Ctrl]-c按键---让当前的程序『停掉』
[Ctrl]-d按键---通常代表着:『键盘输入结束(End Of File, EOF 戒 End OfInput)』的意思;另外他也可以用来取代exit
26. 关机
语法: shutdown [选项] ** 常见选项: **
-h :将系统的服务停掉后,立即关机。 -r : 在将系统的服务器停掉之后就重新启动。 -t sec : -t 后面加秒数,亦即『过几秒后关机』的意思
27. 拓展
◆安装和登录命令: login、 shutdown、 halt、 reboot、 install、 mount、 umount、 chsh、 exit、 last;
◆ 文件处理命令: file、 mkdir、 grep、 dd、 find、 mv、 ls、 diff、 cat、 ln;
◆ 系统管理相关命令: df、 top、 free、 quota、 at、 lp、 adduser、 groupadd、 kill、 crontab;
◆ 网络操作命令: ifconfig、 ip、 ping、 netstat、 telnet、 ftp、 route、 rlogin、 rcp、 finger、 mail、 nslookup;
◆ 系统安全相关命令: passwd、 su、 umask、 chgrp、 chmod、 chown、 chattr、 sudo ps、 who;
◆ 其它命令: tar、 unzip、 gunzip、 unarj、 mtools、 man、 unendcode、 uudecode。
查看xpu:lscpu
查看内存:lsmem
查看磁盘:df -h
查看登录了服务器的账号,也就是用户:who
27.1 shell命令以及运行原理
Linux严格意义上说的是一个操作系统,我们称之为“核心(kernel) “ ,但我们一般用户,不能直接使用kernel。
而是通过kernel的“外壳”程序,也就是所谓的shell,来与kernel沟通。如何理解?为什么不能直接使用kernel?
从技术角度, Shell的最简单定义:命令行解释器(command Interpreter)主要包含:
将使用者的命令翻译给核心(kernel)处理。同时,将核心的处理结果翻译给使用者。
对比windows GUI,我们操作windows 不是直接操作windows内核,而是通过图形接口,点击,从而完成我们的操作(比如进入D盘的操作,我们通常是双击D盘盘符.或者运行起来一个应用序)。
shell 对于Linux,有相同的作用,主要是对我们的指令进行解析,解析指令给Linux内核。反馈结果在通过内核运行出结果,通过shell解析给用户。
windows的图形界面,本质也是一种外壳程序。
所以,Linux shell命令行外壳 和 Windows图形界面,本质是一样的。
通过用户——shell——内核这样的结构,可以有效的执行很多指令。当用户传入的是非法指令,那么,shell会直接拒绝,不需要进入到内核当中,也起到了保护作用。
帮助理解:如果说你是一个闷骚且害羞的程序员,那shell就像媒婆,操作系统内核就是你们村头漂亮的且有让你心动的MM小花。你看上了小花,但是有不好意思直接表白,那就让你你家人找媒婆帮你提亲,所有的事情你都直接跟媒婆沟通,由媒婆转达你的意思给小花,而我们找到媒婆姓王,所以我们叫它王婆,它对应我们常使用的bash

Linux下有两种用户:超级用户(root)、普通用户。
超级用户:可以再linux系统下做任何事情,不受限制
普通用户:在linux下做有限的事情。
超级用户的命令提示符是“#”,普通用户的命令提示符是“$
命令: su [用户名]
功能:切换用户。
例如,要从root用户切换到普通用户user,则使用 su user。 要从普通用户user切换到root用户则使用 su root(root可以省略),此时系统会提示输入root用户的口令
~]$ su -
Password:
~]# pwd
/root
~]# su wjmhlh
]$ pwd
/root
]$ whoami
wjmhlh
]$ su
Password:
~]# whoami
root
~]# su wjmhlh
]$
# 代表root $代表普通用户

~]$ pwd
/home/wjmhlh
~]$ clear
~]$ mkdir lesson5
~]$ ll
total 4
lesson5
~]$ cd lesson5
lesson5]$ su -
Password:
Last login: Thu Oct 6 16:44:28 CST 2022 on pts/0
~]# whoami
root
~]# exit
logout
lesson5]$ whoami
wjmhlh
lesson5]$ su
Password:
lesson5]# whoami
root
lesson5]# su wjmhlh
lesson5]$ whoami
wjmhlh
lesson5]$
root与普通用户之间的切换操作

当我不想转换为root用户,但是需要root权限的时候,可以使用命令sudo XXX。但会有个问题,那就是,root对普通用户的信任。
当root对普通用户信任的时候,使用sudo XXX后,再使用whoami的时候,发现,我们的权限更换成了root,但不信任,就会出现以下信息:
~]$ sudo whoami
[sudo] password for wjmhlh:
wjmhlh is not in the sudoers file. This incident will be reported.
所以,说了那么多,什么是权限?我们为什么需要权限?
①什么是权限?
权限是约束人的(一个人或者某群体)。而对于人,并不是真的去约束这个人或群体,而是对他的身份或者扮演的角色进行约束。就好比如,我张三,开通了某奇艺的会员,我张三能去看VIP电影,真的是因为我是张三,所以我能看吗?如果另外的一个人也是叫做张三,他能也看吗?不!仅仅是因为我在某奇艺的身份!
因此:文件权限 = 人+文件属性。
续上:
人—>角色—>权限。角色(身份)->(拥有者:owner 其他人:other 所属组:grouper)
lesson5]$ touch file.txt
lesson5]$ ll
total 0
-rw-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
第一个红: 文件的拥有者 第二个红:文件的所属组,因为这里只有我一个人在用。
对于其他人,则是,用户在访问这个文件的时候,用户名与拥有者和所属组的名字不相同的话,那么,这个用户就是其他人other。
那么,为什么要存在所属组呢?文件创建者是拥有者,拥有者以外的是其他人,这个能很好的理解。而所属组,用来干嘛?
所谓组,那就是一群人在一起奋斗的组别。如果有一天,一个项目中,几个团队共用一个Linux机器。我想要给我的团队小组成员看我的代码,即对他们开源,但是又不能给小组以外的人看,如果没有所属组,那么,我需要将拥有者和其他人的权限放开,这时候,只要是个人都能查看我的代码了。这样显然是绝对不行的!因此,所属组就诞生了,我只需要在所属组中,对我的小组成员开源,其他人也不能看见,这就皆大欢喜了!
文件属性是啥?
文件属性:r(读权限) w(写权限) x(执行权限)
来介绍一些小知识:
lesson5]$ mkdir dir
lesson5]$ ll
total 4
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
第一个红: 文件的拥有者 第二个红:文件的所属组
第一个绿是文件大小。
第一个蓝指的是最近修改或创建时间
之前我们讲过,文件 = 内容 + 属性。所以,上面那行信息,都是属于文件的属性
而橙色部分:
看第一个字符:

剩下的部分:

所以,我们阅读权限的正确方法是:
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
对于dir,它是目录文件,拥有者允许读权限、写权限和执行权限;所属组允许读权限、写权限和执行权限;其他人允许读权限,不允许写权限,允许执行权限。
同理:-rw-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
对于file.txt,它是普通文件,拥有者允许读权限、写权限和不允许执行权限;所属组允许读权限、写权限和不允许执行权限;其他人允许读权限,不允许写权限,不允许执行权限。
还有噢,其实,rwx可以使用二进制来表示,然后三组转换成八进制数字。

结合以下的指令:
# chmod 664 /home/abc.txt
# chmod 640 /home/abc.txt
接下来,我们来看看,如何操作权限?
chmod
功能: 设置文件的访问权限
格式: chmod [参数] 权限 文件名
常用选项:
R -> 递归修改目录文件的权限
说明:只有文件的拥有者和root才可以改变文件的权限
chmod
① 用户表示符+/-=权限字符
+:向权限范围增加权限代号所表示的权限
-:向权限范围取消权限代号所表示的权限
=:向权限范围赋予权限代号所表示的权限
用户符号:
u:拥有者
g:拥有者同组用
o:其它用户
a:所有用户
例子:
lesson5]$ whoami
wjmhlh
lesson5]$ chmod u-r file.txt //去掉读权限 //拥有者
lesson5]$ ll
total 4
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
--w-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
lesson5]$ chmod u+x file.txt // 增加执行权限 //拥有者
lesson5]$ ll
total 4
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
--wxrw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
lesson5]$ chmod u-rwx file.txt // 去掉读写执行权限 //拥有者
lesson5]$ ll
total 4
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
----rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
lesson5]$ chmod u+rw file.txt //增加读和执行权限 //拥有者
lesson5]$ ll
total 4
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
-rw-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
同时,如果我们需要同时操作拥有者、所属组和其他人的权限,可以用逗号分开。
chmod u-rwx,u-rwx,g-rwx,o-rwx file.txt
也可以
chmod a-rwx file.txt
值得注意的是,当拥有者的某个权限失效时,但是所属组拥有,我们使用拥有者来操作这个失效的权限时,依然无法执行,既然所属组拥有这个权限。因为,对于拥有者——所属组——other,是if——else if ——else的关系,拥有者没有,那么,匹配到所属组也是拥有者的名称,那么,这个权限也不能使用!
还有一点的就是:root不受权限的约束!
root能够删掉普通用户的任意权限,但是却可以在用户没有这个文件的权限的时候,去操作这个权限!
比如,-rw-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt。普通用户只有r和w。root可以将两个也删掉,变成----rw-r--。删掉后,root依然可以对其进行读写和执行。你一点脾气都没有!所以,root一定不能丢!
chown
功能:修改文件的拥有者
格式: chown [参数] 用户名 文件名
实例:
# chown user1 f1
# chown -R user1 filegroup1
当然,当你要将一个东西给别人的时候,需要跟别人说一声,我们可以使用sudo 来强行给。————sudo chown XXX file
同时将拥有者和所属组都修改给别人,那么是这样的:sudo chown XXX:XXX file
chgrp
功能:修改文件或目录的所属组
格式: chgrp [参数] 用户组名 文件名
常用选项: -R 递归修改文件或目录的所属组
file指令:
功能说明:辨识文件类型。
语法: file [选项] 文件或目录
常用选项
-c 详细显示指令执行过程,便于排错或分析程序执行的情形。
-z 尝试去解读压缩文件的内容。
drwxrwxr-x 2 wjmhlh wjmhlh 4096 Oct 7 14:00 dir
-rw-rw-r-- 1 wjmhlh wjmhlh 0 Oct 7 13:43 file.txt
lesson5]$ file dir
dir: directory
lesson5]$ file file.txt
file.txt: empty
关于使用sudo分配权限,后续再解析。
为什么需要权限?
便于系统进行安全的管理。
那么,为什么在我们创建了目录或者文件后,默认的权限是我们所看到的样子,意思是说,为什么一开始不是rwx rwx rwx,而是rw- rw- rw-等等类似的样子?
因为Linux规定:
目录:起始权限:777
文件:起始权限:666
$umask
0002——>000 000 010---系统会默认配置好umask 权限掩码:反是在umask出现的权限,都必须在起始权限中去掉!!!
这里的去掉,不是做减法,而是按位与&
最终权限 = 起始权限 & (^umask),即现对umask进行按位取反,再进行按位与,最终得到最终权限。
比如:


值得注意的一点是:umask是可以被修改的,也就是,默认的是0002,但我们可以修改为0444,0000. umask 0000
最后,关于rwx的一些补充:
r—读权限,并不决定我们能否进入这个目录或文件,而是决定了我们能否使用ls或ll来查看里面的内容 w—写权限。决定了能否在目录里面创建文件或目录
x—执行权限,决定了我们能否进入这个目录或文件
所以为什么系统规定目录的默认的权限是777开始的?因为所有的目录,在创建初,一般都可以进入(x)。