Linux常见指令以及权限理解

一、指令

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.该文件的所有者删除

相关推荐
苹果醋32 分钟前
[MySQL] MySQL 版本不支持 ST_Distance_Sphere替代方案和解决方案
java·运维·spring boot·mysql·nginx
F_D_Z15 分钟前
【解决办法】pip install albumentations安装下载遇19kB/s超级慢细水管
linux·运维·python·pip
luoqice16 分钟前
在嵌入式 Linux 系统中,配置 DNS 以实现内网或外网连接
linux·运维·服务器
中心观察者24 分钟前
haproxy应用详解
运维
青草地溪水旁33 分钟前
Ubuntu上开通Samba网络共享
linux·运维·ubuntu·samba
妙妙屋(zy)38 分钟前
基于Astro开发的Fuwari静态博客模版配置CICD流程
服务器·docker
芥子沫1 小时前
ElasticSearch 的3种数据迁移方案
运维·elasticsearch·搜索引擎
IvanCodes1 小时前
三、Linux用户与权限管理详解
linux·运维·服务器
默默敲代码的徐哥儿1 小时前
八股文整理——计算机网络
服务器·网络·计算机网络
IvanCodes1 小时前
四、Linux核心工具:Vim, 文件链接与SSH
linux·ssh·vim