一份前端够用的 Linux 命令

helloworld_51691982
• 阅读 471

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

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

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

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

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

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

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

    添加一个名为 git 的用户

    adduser git

    设置 git 用户的密码

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

会打开 sudoers 配置文件

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

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

Allow git to run any commands anywhere

git ALL=(ALL:ALL) ALL 复制代码 简单解释下这句话 git ALL=(ALL:ALL) ALL :

git 表示规则应用的用户名 第一个 ALL 表示规则应用于所有 hosts 第二个 ALL 表示规则应用于所有 users 第三个 ALL 表示规则应用于所有 groups 第四个 ALL 表示规则应用于所有 commands 我们保存退出后,git 用户就会获得 root 权限。

  1. ls 列出文件和目录 ls 列出文件和目录 [root@iZ2ze learn-typescript.git]# ls branches config description HEAD hooks index info objects refs 复制代码 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-x 10 git git 90 12月 15 12:33 objects drwxrwxr-x 4 git git 31 12月 15 12:21 refs 复制代码 每一行都有 7 列,我们以 branches 为例讲解每列的含义:

drwxrwxr-x 2 git git 6 12月 15 12:21 branches 文件类型和权限信息 链接数或者一级子目录数 所有者 所属组 文件大小,单位字节 最后修改时间 文件名 ​ 重点看第 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 复制代码 这就是为什么我们有的时候需要在创建文件后,又加上执行权限。

  1. 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 的权限,如果我们这样设置一个文件的权限:

chmod 750 index.html 复制代码 我们可以得知,Owner 的权限为 7,为可读可写可执行,Group 的权限为 5,为可读可执行,Others 的权限为 0,表示不可读写不可执行。对应字母为:rwxr-x---。

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

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

chmod 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,会给所有身份添加执行权限。

  1. su 切换身份

    切换为 git 用户

    su git 复制代码
  2. whoami 显示用户名

    whoami

    root 复制代码
  3. pwd 显示当前目录 [git@iZ2ze www]$ pwd /home/www 复制代码
  4. cd 切换工作目录

    进入 /home/www/

    cd /home/www

进入自己的主目录

cd ~

进入当前目录的上上两层 :

cd ../.. 复制代码 10. mkdir 创建目录 mkdir 创建目录: mkdir new_folder 复制代码 mkdir -p 递归创建目录: mkdir -p one/two/three 复制代码 11. touch 创建文件 用于修改文件或者目录的时间属性,当文件不存在,系统会创建空白文件

touch new_file 复制代码 12. 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 复制代码 13. 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 复制代码 14. cp 复制文件或目录 将目录 website/ 下的所有文件复制到新目录 static 下:

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

cp –r website/ static 复制代码 15. 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 复制代码 16. rm 删除一个文件或者目录

系统会询问

rm file

-f 表示直接删除

-r 表示目录下的所有文件删除

删除当前目录下的所有文件及目录

rm -r *

跑路

rm -rf /* 复制代码 17. 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 回到命令模式:

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

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

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

有想交流探讨的欢迎联系我。

点赞
收藏
评论区
推荐文章
Stella981 Stella981
3年前
Linux 编程笔记(四)
一、用户和用户组管理    添加新的用户账户使用useradd格式useradd  选项 用户名   1、创建一个用户tian其中dm参数用来为登陆,登录名产生一个主目录/usr/tian(其中/usr为默认的用户主目录所在的父目录)        !(https://oscimg.oschina.net/oscnet
Stella981 Stella981
3年前
Linux和MySQL添加用户和授予权限
Linux下添加账户和设置密码useradd添加用户useradd–d/usr/sammtest此命令创建了一个用户test,其中d和m选项用来为登录名test产生一个主目录/usr/test(/usr为默认的用户主目录所在的父目录)。设置密码passwdtest
Stella981 Stella981
3年前
Linux文件属性查询与管理
一、Linux文件角色Linux为了方便对文件针对不同用户做权限控制,针对文件定义了三种角色:文件所有者(owner)、用户组(group)和其他人(others)。二、文件权限  r:读权限w:写权限x:执行权限三、Linux文件属性  Linux查看文件属
Stella981 Stella981
3年前
Linux各目录及每个目录的详细介绍
【常见目录说明】目录/bin存放二进制可执行文件(ls,cat,mkdir等),常用命令一般都在这里。/etc存放系统管理和配置文件/home存放所有用户文件的根目录,是用户主目录的基点,比如用户user的主目录就是/home/user,可以用~user表示/usr用于存放系统应用程序,比较重要的目录/us
Stella981 Stella981
3年前
Linux用户管理
Linux用户管理用户管理配置文件 用户信息文件:/etc/passwd                                 用户名,密码位,UID(用户标识号),GID(缺省组织标识号),注释性描述(例如存放用户全名等信息),宿主目录(用户登陆系统后的缺省目录),命令解释器(用户使用的Shell,默认为bash
Stella981 Stella981
3年前
Linux文件目录和权限
前言:Linux一般将文件可存取的身份分为三个类别,分别是owner/group/others,根据权限划分,每个目录都可以拥有相对身份的rwx\可读可写可执行\使用者与群组:Owner:文件拥有者,如jane拥有此文件所属权,可对该文件进行相应权限操作。Group :文件拥有组,如一个project组中,有三个人
Stella981 Stella981
3年前
Linux中的权限发布啦!
一、Linux中的权限在linux中,我们可以将文件的访问者分为三类,针对这三类访问者我们可以对他们设置不同的权限。1、文件访问者的分类文件和文件目录的所有者:u(User)。文件和文件目录的所有者所在的组中的用户:g(Group)。其他用户:o(Others)。2、文件的基本权限读(r):具有读取文件
Stella981 Stella981
3年前
Linux权限详解
权限简介Linux系统上对文件的权限有着严格的控制,用于如果相对某个文件执行某种操作,必须具有对应的权限方可执行成功。Linux下文件的权限类型一般包括读,写,执行。对应字母为r、w、x。Linux下权限的粒度有拥有者、群组、其它组三种。每个文件都可以针对三个粒度,设置不同的rwx(读写执行)权限。通常情况
Wesley13 Wesley13
3年前
2.18 特殊权限set_uid 2.19 特殊权限set_gid 2.20 特殊权限stick_bit 2.21 软链接文件 2.22 硬连接文件
set\_uid权限说明:setuid权限针对二进制可执行文件,使文件在执行阶段具有文件所有者的权限。比如passwd这个命令就具有该权限。当普通用户执行passwd命令时,可以临时获得root权限,从而可以更改密码。作用:setuid的作用是保证普通用户临时拥有该命令所有者的身份。给一个文件设置成setuid,前提这个文件是一个二
芝士年糕 芝士年糕
2年前
linux--用户、组、权限
最近在学习linux,租了一台VPS,需要多用户,刚好查了资料,顺便整理了一下,如果有需要服务器的话,可以后台私信我说到用户组权限,可以想像成windows操作系统一样,同样都是基于用户身份来控制对资源的访问,每个用户账户都有唯一的用户名与密码,只是个别细节方面存在一些差异。系统用户文件系统文件路径:/etc/passwd用户信息文件