Linux常见指令以及权限理解

发布于:2025-07-04 ⋅ 阅读:(20) ⋅ 点赞:(0)

一、指令

1.ls(list)

语法: ls [选项] [目录或文件]

功能:对于目录,该命令列出该目录下的所有子目录与文件;对于文件,将列出文件名以及其他信息

常用选项:

-a(all) 列出目录下的所有文件,包括以 . 开头的隐含文件

-d(directory) 将目录像文件一样显示,而不是显示其下的文件。 如:ls –d 指定目录

-l 列出文件的详细信息

-t(time) 以时间排序。

2.pwd(print word directory)

语法: pwd

功能:显示用户当前所在的目录

3.cd(change directory)

语法:cd [目录名]

功能:改变工作目录。将当前工作目录改变到指定的目录下

举例:

cd .. : 返回上级目录
cd /home/litao/linux/ : 绝对路径
cd ../day02/ : 相对路径
cd ~:进入用户家目录
cd -:返回最近访问目录

4.touch

语法:touch [选项] ...文件...

功能:touch命令参数可更改文档或目录的日期时间,包括存取时间和更改时间,或者新建一个不存在的文件

5.mkdir(make directory)

语法:mkdir [选项] dirname...

功能:在当前目录下创建一个名为 “dirname”的目录

常用选项:

-p(parents) 可以创建一个路径。此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录

举例:mkdir –p test/test1 : 递归建立多个目录

6.rmdir(remove directory)

rmdir是一个与mkdir相对应的命令。mkdir是建立目录,而rmdir是删除命令

语法:rmdir [-p][dirName]

适用对象:具有当前目录操作权限的所有使用者

功能:删除空目录

常用选项:

-p 当子目录被删除后,如果父目录也变成空目录的话,就连带父目录一起删除

7.rm(remove directory)

rm命令可以同时删除文件或目录

语法:rm [-f-i-r-v][dirName/dir]

适用对象:所有使用者

功能:删除文件或目录

常用选项:
-f (force)强制删除
-i(interactive) 删除前逐一询问确认
-r (recursive)递归删除目录及其下所有文件

8.man(manual)

访问Linux手册页,查看联机手册获取帮助

语法: man [选项] 命令

常用选项:

-k 根据关键字搜索联机帮助

num 只在第num章节找

-a 将所有章节的都显示出来,比如 man printf 它缺省从第一章开始搜索,知道就停止,用a选项,当按下q退出,他会继续往后面搜索,直到所有章节都搜索完毕。

补充:

手册分为8个章节

1 是普通的命令

2 是系统调用,如open,write之类的(通过这个,至少可以很方便的查到调用这个函数,需要加什么头文件)

3 是库函数,如printf,fread4是特殊文件,也就是/dev下的各种设备文件

(其余章节不需要掌握)

9.cp(copy)

语法:cp [选项] 源文件或目录 目标文件或目录

功能: 复制文件或目录

说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中。若同时指定多个文件或目录,而最后的目的地并非一个已存在的目录,则会出现错误信息

常用选项:

-f (force) 强行复制文件或目录, 不论目标文件或目录是否已经存在

-i (interactive) 覆盖文件之前先询问用户

-r/-R (recursive) 递归处理,将指定目录下的文件与子目录一并处理。若源文件或目录的形态,不属于目录或符号链接,则一律视为普通文件处理

10.mv(move)

语法: mv [选项] 源文件或目录 目标文件或目录

功能:

1. 若第二个参数类型是目标文件,mv命令将文件重命名。此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名

2. 第二个参数类型是目标目录,mv命令将其移至一个新的目录中。此时,源文件或目录参数可以有多个,mv命令将各参数指定的源文件均移至目标目录中

常用选项:

-f (force)如果目标文件已经存在,不会询问而直接覆盖
-i (interactive)若目标文件 (destination) 已经存在时,就会询问是否覆盖!

11.文本查看相关的指令

1.cat(concatenate)

语法:cat [选项] [文件]

功能: 查看目标文件的内容

常用选项:

-b 对非空输出行编号
-n 对输出的所有行编号
-s 不输出多行空行

补充:tac:命令反过来了,打印的内容也反过来了

2.more

语法:more [选项][文件]

功能:more功能类似 cat。全屏幕的方式按页显示文本文件的内容,而且还有搜寻字串的功能 

常用选项:

-n 对输出的所有行编号

-[num] 输出前num行

q 退出more

常用操作:

空白键(space):往下一页显示

 b 键(back):往回一页显示

/字符串:显示所查字符串

3.less

less 工具也是对文件或其它输出进行分页显示的工具

less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看;但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!

除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜。

语法: less [参数] 文件

功能:

less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件

选项:

-[num] 输出前num行

+[num] 跳转到第num行

-i 忽略搜索时的大小写

-N 显示每行的行号

/字符串:向下搜索“字符串”的功能

?字符串:向上搜索“字符串”的功能

n:重复前一个搜索(与 / 或 ? 有关)

N:反向重复前一个搜索(与 / 或 ? 有关)

q:quit

4.head

语法: head [参数]... [文件]...

功能:
head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。

选项:

-[num] 输出前num行

5.tail

语法: tail[必要参数][选择参数][文件]

功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件

选项:

-f 循环读取
-[num] 输出后num行

举例补充:(重定向和管道)

有一个文件共有100行内容,请取出第50行内容<br>

seq 1 100 > test # 生成1到100的序列装入test

方法1:

head -n50 test > tmp #将前50行装入临时文件tmp

tail -n1 tmp #得到中建行

方法2:

head -n50 test | tail -n1

12.时间相关的指令

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的午夜)开始所经过的秒数,不考虑闰秒。

13.cal(calendar)

命令格式: cal [参数][月份][年份]

功能: 用于查看日历等时间信息,如只有一个参数,则表示年份(1-9999),如有两个参数,则表示月份和年份

常用选项:

-3 显示系统前一个月,当前月,下一个月的月历

-j 显示在当年中的第几天(一年日期按天算,从1月1号算起,默认显示当前月在一年中的天数)

-y 显示当前年份的日历

14.find -name

语法: find pathname -options

功能: 用于在文件树中查找文件,并作出相应的处理(可能访问磁盘)

常用选项:

-name 按照文件名查找文件

举例:

find /home -name test.c

15.which

语法:which 搜寻命令

功能:只用来搜索命令

16.alias

语法:alias 指令='别名'

功能:对指令进行重命名

举例:alias ls -l='ll'

17.whereis

语法:whereis 指令或文档

功能:在特定路径下,查找指定文件名对应的指令或文档

举例:whereis test.c

18.文本操作相关的指令

1.grep

文本内容的行过滤工具

语法: grep [选项] '搜寻字符串' 文件

功能: 在文件中搜索字符串,将找到的行打印出来

常用选项:

-i :忽略大小写的不同

-n :顺便输出行号

-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行

2.wc -l(word count -lines)

语法:wc -l filename

功能:统计文件中的行数

举例:wc -l test.txt

3.sort

语法:sort filename

功能:对文本内容进行排序

4.uniq(unique)

语法:uniq filename

功能;对文本内容进行去重

19.zip/unzip

语法: zip 压缩文件.zip 目录或文件

功能: 将目录或文件压缩成zip格式

常用选项:

-r 递归处理,将指定目录下的所有文件和子目录一并处理

举例:

将test2目录压缩:

zip test2.zip test2/*

zip test2.zip -r test2

解压到tmp目录:

unzip test2.zip -d /tmp

补充:

zip对一个目录进行打包压缩的时候,默认只会对目录本身打包压缩

(zip test.zip /home/test)

unzip默认解压到当前路径

(unzip test2.zip:解压到当前路径)

(unzip test2.zip -d pathname:解压到指定路径)

20.tar

语法:

tar [选项] 压缩文件.tgz 目录或文件

打包并压缩:tar -czf test.tgz test

解包并解压:tar -xzf test.tgz test

功能:打包/解压,不打开他,直接看内容

tar [-cxtzjvf] 文件与目录 .... 参数:

-c (create):建立一个压缩文件

-x :解开一个压缩文件

-f :使用文档名,(在 f 之后要立即接文档名,不要再加参数)

-t :查看不用打开压缩文件,直接查看压缩包里的文件内容

(tar -tf test.tgz)

-v :压缩/解压过程中同步显示压缩文件列表

(tar -czvf test.tgz test)

-C : 解压到指定目录

(tar -xzf test.tgz test -C /home)

21.bc

bc命令可以很方便的进行浮点运算

22.uname 

语法:uname [选项]

功能: uname用来获取电脑和操作系统的相关信息。

补充说明:uname可显示linux主机所用的操作系统的版本、硬件的名称等基本信息。

常用选项:

-a(all) 详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类型,硬件平台类型,操作系统名称

23.重要热键[Tab],[ctrl]-c, [ctrl]-d

[Tab]按键---『命令补全』和『档案补齐』

[Ctrl]-c按键---终止前台异常程序

[Ctrl]-d按键---退出当前用户,通常代表着:『键盘输入结束(End Of File, EOF 戒 End OfInput)』的意思;也可以用来取代exit

[Ctrl]-r按键---搜索历史命令,左右即可选中

24.关机

语法:shutdown [选项]

常见选项:

-h:将系统的服务停掉后,立即关机

-r:在将系统的服务停掉之后就重新启动

-t sec:-t 后面加秒数,亦即『过几秒后关机』的意思

二、shell的命令及运行原理

Linux严格意义上说的是一个操作系统,我们称之为“核心(kernel)“ ,但我们一般用户,不能直接使用kernel。而是通过kernel的“外壳”程序,也就是所谓的shell,来与kernel沟通。

从技术角度,Shell的最简单定义:命令行解释器(command Interpreter)主要包含:

将使用者的命令翻译给核心(kernel)处理;将核心的处理结果翻译给使用者

三、Linux权限

1.linux权限概念

Linux下有两种用户:超级用户(root)、普通用户

超级用户:可以在linux系统下做任何事情,不受限制

普通用户:在linux下做有限的事情。

超级用户的命令提示符是“#”,普通用户的命令提示符是“$”

命令:su [用户名]

功能:切换用户

例如,要从root用户切换到普通用户user,则使用 su user。 要从普通用户user切换到root用户则使用 su root(root可以省略),此时系统会提示输入root用户的口令

补充:

su -:重新登录

sudo command:短暂提权,以root身份执行命令(需要是受信任的用户,且输入用户密码)

2.Linux权限管理

(1)文件访问者的分类

文件和文件目录的所有者:u---User

文件和文件目录的所有者所在的组的用户:g---Group

其它用户:o---Others 

(2)文件类型和访问权限(事物属性)
 

a) 文件类型

d:目录文件

-:普通文件

l:软链接文件(类似Windows的快捷方式)

b:块设备文件(硬盘、光驱等)

p:管道文件

c:字符设备文件(屏幕等)

b)基本权限

i.读(r/4):Read对文件而言,具有读取文件内容的权限;对目录来说,具有浏览该目录信息的权限

ii.写(w/2):Write对文件而言,具有修改文件内容的权限;对目录来说具有删除移动目录内文件的权限

iii.执行(x/1):execute对文件而言,具有执行文件的权限;对目录来说,具有进入目录的权限

iv.“—”表示不具有该项权限

(3)文件权限值的表示方法

1)字符表示方法

rwx-

2)8进制数值表示方法

权限符号(执行 八进制 二进制
r-- 4 100
-w- 2

010

--x 1 001
rw- 6 110
r-x 5 101
-wx 3 011
rwx 7 111
--- 0 000

(4)文件访问权限的相关设置方法

a)chmod

说明:只有文件的拥有者和root才可以改变文件的权限

功能:设置文件的访问权限

常用选项:

-R -> 递归修改目录文件的权限

说明:只有文件的拥有者和root才可以改变文件的权限

格式:chmod [参数] 权限 文件名

chmod命令权限值的格式

① 用户表示符+/-=权限字符

+:向权限范围增加权限代号所表示的权限

-:向权限范围取消权限代号所表示的权限

=:向权限范围赋予权限代号所表示的权限

用户符号:

u:拥有者
g:拥有者同组用
o:其它用户
a:所有用户

举例:

chmod u+w /home/abc.txt

chmod o-x /home/abc.txt

chmod a=x /home/abc.txt

②三位8进制数字

举例:

chmod 664 /home/abc.txt

chmod 640 /home/abc.txt

b)chown

功能:修改文件的拥有者

格式:chown [参数] 用户名 文件名

常用选项:

-R -> 递归修改目录文件的拥有者

说明:root权限才能使用

举例:

chown user1 test.txt

chown -R user1 test.txt

c)chgrp

功能:修改文件或目录的所属组

格式:chgrp [参数] 用户组名 文件名

常用选项:-R 递归修改文件或目录的所属组

d)umask

功能:

查看或修改文件掩码

新建文件默认权限=0666

新建目录默认权限=0777

但实际上你所创建的文件和目录,看到的权限往往不是上面这个值。原因就是创建文件或目录的时候还要受到umask的影响。假设默认权限是mask,则实际创建的出来的文件权限是:

mask & ~umask

直观理解:想要去掉的权限,其umask二进制位为1

格式:umask 权限值

说明:超级用户默认掩码值为0022,普通用户默认为0002

举例:

umask //查看

umask 044//设置

(5)目录权限

x可执行权限: 如果目录没有可执行权限, 则无法cd到目录中

r可读权限: 如果目录没有可读权限, 则无法用ls等命令查看目录中的文件内容.

w可写权限: 如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件

总结:

目录的可执行权限(-x)是表示你可否在目录下执行命令

如果目录没有-x权限,则无法对目录执行任何命令,甚至无法cd 进入目录, 即使目录仍然有-r 读权限(这个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件)

而如果目录具有-x权限,但没有-r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限,所以,在目录下,即使可以执行ls命令,但仍然没有权限读出目录下的文档

(6)粘滞位

语法:chmod +t 目录

功能:由root创建公共目录,普通用户各自可以进行rwx操作,但要禁止删除别人的文件

理解:

a.root创建目录,针对公共目录,普通用户是other,就必须将目录的other权限设为rwx

b.普通用户在公共目录下创建文件,针对文件,该用户为owner,其余用户为other

c.公共目录下,文件的拥有者可以将文件的other权限设为---,其余用户不能查看/修改/执行。但是由于目录的other权限为rwx,所以用户可以删除别人的文件

d.给目录设置粘滞位,可以禁止删除别人的文件(权限的一种特殊情况)

举例:

修改前的公共目录:

drwxrwxrwx 3 root root 4096 9月 19 16:00 /home/

[root@localhost ~]# chmod +t /home/ # 加上粘滞位

修改后:

drwxrwxrwt 3 root root 4096 9月 19 16:00 /home/

当一个目录被设置为"粘滞位"(用chmod +t),则该目录下的文件只能由

a.管理员删除

b.该目录的所有者删除

c.该文件的所有者删除
 


网站公告

今日签到

点亮在社区的每一天
去签到