前言
在翻译完 TypeScript 官网文档后,我用 VuePress 搭建博客,又实现了 GitHub 和 Gitee Pages 的主动部署,但我最终还是决定本人建站,而在建站的过程中,必不可少会用到 Linux 命令,所以此篇写一份根本够用的 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:ALL) ALL
简略解释下这句话 git ALL=(ALL:ALL) ALL
:
- git 示意规定利用的用户名
- 第一个
ALL
示意规定利用于所有 hosts - 第二个
ALL
示意规定利用于所有 users - 第三个
ALL
示意规定利用于所有 groups - 第四个
ALL
示意规定利用于所有 commands
咱们保留退出后,git
用户就会取得 root 权限。
2. 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
这就是为什么咱们有的时候须要在创立文件后,又加上执行权限。
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---
。
除了这种数字的形式,还有一种应用符号类型扭转权限的形式:
在这种形式里,咱们将三种身份 Owner
、Group
、Others
,别离简写为 u(User)
、g
、o
,用 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
9. 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 文件。
18. 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
系列文章
系列文章目录地址:https://github.com/mqyqingfeng/Blog
微信:「mqyqingfeng」,加我进冴羽惟一的读者群。
如果有谬误或者不谨严的中央,请务必给予斧正,非常感激。如果喜爱或者 有所启发,欢送 star,对作者也是一种激励。