一份前端够用的 Linux 命令

181 阅读11分钟

前言

分享一份前端基本够用的  Linux 命令,方便查询和学习使用。

0. Owner、Group、Others、Root

Linux 系统是一种多用户系统,它将文件访问者身份分为三种:

文件所有者(Owner)

当创建一个用户的时候,Linux 会为该用户创建一个主目录,路径为 /home/<username>,我们可以使用 cd ~,快捷进入主目录。如果你想放一个私密文件,就可以放在自己的主目录里,然后设置只能自己查看。

群组(Group)

每个用户都有一个用户组,方便多人操作的时候,为一群人分配权限。当创建用户的时候,会自动创建一个与它同名的用户组。

如果一个用户同时属于多个组,用户需要在用户组之间切换,才能具有其他用户组的权限。

其他人(Others)

既不是文件所有者又不是文件所属群组成员的用户,就是其他人。

超级用户(Root)

Root 用户是一类特殊的用户,该用户可以访问所有文件。

1. adduser 添加用户 和 passwd 更改密码

# 添加一个名为 git 的用户
adduser git
# 设置 git 用户的密码
passed git

但是由于创建的用户权限较低,有的时候我们需要为用户提权,此时我们可以这样做:

# 会打开 sudoers 配置文件
sudo visudo

注意同样是编辑 sudoers 配置文件,使用这个命令会比使用 sudo vim /etc/ sudoers 更安全, 除了对语法有校验,并且还会在多用户编辑的时候锁住文件。

打开 sudoers 配置文件后,我们添加这样一行配置:

# Allow git to run any commands anywhere
git ALL=(ALL:ALLALL 

简单解释下这句话 git ALL=(ALL:ALL) ALL

  • git 表示规则应用的用户名
  • 第一个 ALL 表示规则应用于所有 hosts
  • 第二个 ALL 表示规则应用于所有 users
  • 第三个 ALL 表示规则应用于所有 groups
  • 第四个 ALL 表示规则应用于所有 commands

我们保存退出后,git 用户就会获得 root 权限。

2. ls 列出文件和目录

  1. ls 列出文件和目录
[root@iZ2ze learn-typescript.git]# ls
branches  config  description  HEAD  hooks  index  info  objects  refs
  1. ls -la 由 -a 显示所有文件和目录(包括隐藏)和 -l 显示详细列表组成:
[root@iZ2ze learn-typescript.git]# ls -la
总用量 20
drwxrwxr-x  7 git git  132 12月 15 12:33 .
drwx------  3 git git  127 12月 15 14:51 ..
drwxrwxr-x  2 git git    6 12月 15 12:21 branches
-rw-rw-r--  1 git git   66 12月 15 12:21 config
-rw-rw-r--  1 git git   73 12月 15 12:21 description
-rw-rw-r--  1 git git   23 12月 15 12:21 HEAD
drwxrwxr-x  2 git git 4096 12月 15 13:10 hooks
-rw-rw-r--  1 git git  217 12月 15 12:33 index
drwxrwxr-x  2 git git   21 12月 15 12:21 info
drwxrwxr-10 git git   90 12月 15 12:33 objects
drwxrwxr-x  4 git git   31 12月 15 12:21 refs

每一行都有 7 列,我们以 branches 为例讲解每列的含义:

drwxrwxr-x2gitgit612月 15 12:21branches
文件类型和权限信息链接数或者一级子目录数所有者所属组文件大小,单位字节最后修改时间文件名

重点看第 1 列的内容,以 drwxrwxr-x 为例,这里一共 10 位,第 1 位表示文件类型,其中 - 表示普通文件,d 表示目录文件。

第 2 到第 4 位,表示所有者权限,其中 r 表示读权限,w 表示写权限,x 表示可执行权限, -表示无权限,第 2 到 5 位为 rwx,表示所有者可读可写可执行。

第 5 到第 7 位,表示组用户权限,这里也是 rwx

第 8 到第 10 位,表示其他用户权限,这里是 r-x,表示有可读可执行权限,无写入权限。

这里再额外补充一点:

像 root 用户创建文件夹的默认权限为 rwxr-xr-x:

[root@iZ2ze www]# mkdir test
[root@iZ2ze www]# ls -l

drwxr-xr-x  2 root root  6 12月 17 23:53 test

而创建文件的默认权限是 rw-r--r--,注意创建文件默认会去掉 x 权限:

[root@iZ2ze www]# touch index.html
[root@iZ2ze www]# ls -l

-rw-r--r--  1 root root  0 12月 17 23:54 index.html

这就是为什么我们有的时候需要在创建文件后,又加上执行权限。

3. chown 更改文件属主,也可以同时更改文件属组

chown (change owner)  语法:

# -R:递归更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名

将 index.html 的所有者更改为 git

[root@iZ2ze www]# chown git index.html
[root@iZ2ze www]# ls -

-rw-r--r-- 1 git  root  0 12月 17 23:54 index.html

将 index.html 的所有者和群组都改为 git

[root@iZ2ze www]# chown git:git index.html
[root@iZ2ze www]# ls -l

-rw-r--r-- 1 git  git   0 12月 17 23:54 index.html

4. chmod 更改文件权限

权限除了用 r w x 这种方式表示,也可以用数字表示,数组与字母的对应关系为:

  • r:4
  • w:2
  • x:1

之所有如此对应关系,主要还是为了方便推导,比如我们希望一个文件可读可写,那我们可以方便的设置权限为 6(4 + 2),同样,如果我们知道一个权限为 3,我们也可以推导出权限为可写可执行,因为只有 2 + 1 才可能等于 3。

我们看下 chmod (change mode) 的具体语法:

# -R:递归更改文件属组
chmod [-R] xyz 文件或目录

其中 xyz 分别表示 Owner、Group、Others 的权限,如果我们这样设置一个文件的权限:

chomd 750 index.html

我们可以得知,Owner 的权限为 7,为可读可写可执行,Group 的权限为 5,为可读可执行,Others 的权限为 0,表示不可读写不可执行。对应字母为:rwxr-x---

除了这种数字的方式,还有一种使用符号类型改变权限的方式:

在这种方式里,我们将三种身份 OwnerGroupOthers,分别简写为 u(User)go,用 a 表示所有身份,再使用 + - = 表示加入、去除、设定一个权限,r w x 则继续表示读,写,执行权限,举个例子:

chomd u+x,g-x,o-x index.html

意思就是 Owner 加上执行权限,Group 和 Others 去除执行权限。

当然我们也可以直接设定权限

chmod u=rwx,g=rx,o=r index.html

此时文件的权限就相当于 -rwxr-xr--

此外,我们还可以省略不写 ugoa 这类身份内容,直接写:

chmod +x index.html

此时相当于使用了 a,会给所有身份添加执行权限。

5. su 切换身份

# 切换为 git 用户
su git

6. whoami 显示用户名

# whoami 
root

7. pwd 显示当前目录

[git@iZ2ze www]$ pwd
/home/www

8. cd 切换工作目录

# 进入 /home/www/
cd /home/www

# 进入自己的主目录
cd ~

# 进入当前目录的上上两层 :
cd ../..

9. mkdir 创建目录

  1. mkdir 创建目录:
mkdir new_folder
  1. mkdir -p 递归创建目录:
mkdir -p one/two/three

10. touch 创建文件

用于修改文件或者目录的时间属性,当文件不存在,系统会创建空白文件

touch new_file

11. echo 打印输出

echo 是 Shell 命令,用于打印输出:

# 显示转义字符
echo ""test content""

创建或覆盖文件内容为 "test content":

echo "test content" > index.html

如果是想追加内容,就用 >> :

[root@iZ2ze www]# echo "test content" > index.html
[root@iZ2ze www]# cat index.html
test content
[root@iZ2ze www]# echo "test content" >> index.html
[root@iZ2ze www]# cat index.html
test content
test content

12. cat 连接文件并打印输出

查看文件内容:

cat ~/.ssh/id_rsa.pub

清空 index.html 内容:

cat /dev/null > index.html

把 index.html 的内容写入 second.html:

cat index.html > second.html

把 index.html 的内容追加写入 second.html:

cat index.html >> second.html

把 index.html 和 second.html 追加写入 third.html:

cat index.html second.html >> third.html

13. cp 复制文件或目录

将目录 website/ 下的所有文件复制到新目录 static 下:

# -r:若给出的源文件是一个目录文件,此时将复制该目录下所有的子目录和文件。
cp –r website/ static

14. mv 移动并重命名

文件改名:

mv index.html index2.html

隐藏文件:

# 文件名上加上 .
mv index.html .index.html

移动文件:

# 仅仅移动
mv  /home/www/index.html   /home/static/
# 移动又重命名
mv /home/www/index.html   /home/static/index2.html

批量移动:

mv  /home/www/website/*  /home/www/static

15. rm 删除一个文件或者目录

# 系统会询问
rm file

# -f 表示直接删除
# -r 表示目录下的所有文件删除

# 删除当前目录下的所有文件及目录
rm -r  * 

# 跑路
rm -rf /*

16. vi/vim

Linux 内建 vi 文书编辑器,Vim 是从 vi 发展出来的一个文本编辑器。

基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode)输入模式(Insert mode)和底线命令模式(Last line mode) 。我们边操作边介绍这三种模式:

打开

我们执行 vim index.html,如果没有该文件,则会创建文件:

vim index.html

此时是命令模式,在命令模式下,输入的任何字符都会被视为命令,接下来几个常用的命令:\

  • i 切换到输入模式。
  • x 删除当前光标所在处的字符。
  • : 切换到底线命令模式。

编辑

我们按下 i,便会进入输入模式

输入模式下,左下角有 -- INSERT -- 标志

此时我们可以进行各种输入

查找

按下 ESC 回到命令模式

输入 :/字符串

比如搜索user, 输入 /user

按下回车之后,可以看到vim已经把光标移动到该字符处和高亮了匹配的字符串

查看下一个匹配,按下小写 n

跳转到上一个匹配,按下大写 N

搜索后,我们打开别的文件,发现也被高亮了,怎么关闭高亮?

输入模式下,输入 :nohlsearch  也可以 :set nohlsearch; 当然,可以简写,:noh或者 :set noh

保存

当输入完毕后,按下 ESC 回到命令模式

此时左下角的 INSERT已经消失不见了,如果我们要保存退出,我们先输入 : ,进入底线命令模式

在底线命令模式中,常见的命令有:

  • :w 保存文件,但不退出

  • :w file 将修改另外保存到file中,不退出

  • :w! 强制保存,不退出

  • :wq 保存文件,并退出

  • :wq! 强制保存文件,并退出

  • :q 不保存文件,退出

  • :q! 不保存文件,强制退出

  • :e! 放弃所有修改,从上次保存文件开始再编辑

我们输入 wq,表示保存并退出,此时我们就会发现并创建了一个 HTML 文件。

17. ssh 远程连接工具

注意 ssh 监听是 22 端口。

其基本语法为:

ssh [OPTIONS] [-p PORT] [USER@]HOSTNAME [COMMAND]

监听端口示例:

ssh -p 300 git@8.8.8.8

打开调试模式:

# -v 冗详模式,打印关于运行情况的调试信息
ssh -v git@8.8.8.8

18. zip 文件压缩与解压

安装

yum install -y unzip

压缩

zip -q -r 1.zip 1.txt

将当前目录下的1.txt压缩为1.zip。选项-q表示忽略执行过程,-r表示递归处理,将指定目录下的所有文件和子目录一并处理

解压

unzip 1.zip

直接解压到当前目录下

unzip 1.zip -d folder

通过-d指定解压路径,即解压到当前目录下folder这个文件夹下,如果这个文件夹不存在,可以自动创建

查看

zip -sf 1.zip

列出压缩文件1.zip中的内容

19. 查看进程

ps aux

ps命令用于报告当前系统的进程状态。可以搭配kill指令随时中断、删除不必要的程序。ps命令是最基本同时也是非常强大的进程查看命令,使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等,总之大部分信息都是可以通过执行该命令得到的。

可以带上|grep  查询特定进程。

a:显示当前终端下的所有进程信息,包括其他用户的进程。
u:使用以用户为主的格式输出进程信息。
x:显示当前用户在所有终端下的进程。

1652422953(1).png

 **上图中各字段解释:**
 
USER:启动该进程的用户账号名称
PID:该进程的ID号,在当前系统中是唯一的
%CPU:CPU占用的百分比
%MEM:内存占用的百分比

VSZ:占用虚拟内存(swap空间)的大小
RSS:占用常驻内存(物理内存)的大小

TTY:该进程在哪个终端上运行。“?”表未知或不需要终端
STAT:显示了进程当前的状态,如S(休眠)、R(运行)、Z(僵死)、<(高优先级)、N(低优先级)、s(父进程)、+(前台进程)。对处于僵死状态的进程应予以手动终止。

START:启动该进程的时间
TIME:该进程占用CPU时间
COMMAND:启动该进程的命令的名称

**总结:ps aux 是以简单列表的形式显示出进程信息。**

ps -elf

可以带上|grep  查询特定进程。

-e:显示系统内的所有进程信息。
-l:使用长(long)格式显示进程信息。
-f:使用完整的(full)格式显示进程信息。

1652422992(1).png

上图字段解释:
大部分跟第一种一样,PPID为父进程的PID。

top

以全屏交互式的界面显示进程排名,及时跟踪包括CPU、内存等系统资源占用情况,默认情况下每三秒刷新一次,其作用基本类似于Windows系统中的任务管理器。

1652423339(1).png

** 上图各字段解释:**
Tasks(系统任务)信息:total,总进程数;running,正在运行的进程数;sleeping,休眠的进程数;stopped,中止的进程数;zombie,僵死无响应的进程数。

CPU信息:us,用户占用;sy,内核占用;ni,优先级调度占用;id,空闲CPU;wa,I/O等待占用;hi,硬件中断占用;si,软件中断占用;st,虚拟化占用。了解空闲的CPU百分比,主要看%id部分。

Mem(内存)信息:total,总内存空间;used,已用内存;free,空闲内存;buffers,缓存区域。

Swap(交换空间)信息:total,总交换空间;used,已用交换空间;free,空闲交换空间;cached,缓存空间。

pstree -aup

可以带上|grep  查询特定进程。例如 pstree -aup | grep php

1652423549(1).png

 **上图中各字段解释:**
以树状图的方式展现进程之间的派生关系,显示效果比较直观。
-a:显示每个程序的完整指令,包含路径,参数或是常驻服务的标示;
-c:不使用精简标示法;
-G:使用VT100终端机的列绘图字符;
-h:列出树状图时,特别标明现在执行的程序;
-H<程序识别码>:此参数的效果和指定"-h"参数类似,但特别标明指定的程序;
-l:采用长列格式显示树状图;
-n:用程序识别码排序。预设是以程序名称来排序;
-p:显示程序识别码;
-u:显示用户名称;

20. 查看端口号

显示所有已开放端口

netstat -anp

a 显示所有连线中的Socket
n 直接使用ip地址,而不通过域名服务器
p 显示正在使用Socket的程序识别码和程序名称

1652426434(1).png

可以通过grep查询特定端口号

netstat -anp|grep 80

1652426468(1).png