首頁  >  文章  >  運維  >  整理一份常用的linux指令(總結分享)

整理一份常用的linux指令(總結分享)

WBOY
WBOY轉載
2022-01-05 17:53:501492瀏覽

這篇文章帶給大家基本夠用的  Linux 指令,會涵蓋部落格建立系列文章用到的各種指令,方便查詢學習使用,希望對大家有幫助。

整理一份常用的linux指令(總結分享)

檔案擁有者(Owner)

當建立一個使用者的時候,Linux 會為該使用者建立一個主目錄,路徑為/home/,我們可以使用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

整理一份常用的linux指令(總結分享)

我們儲存退出後,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 為例講解每列的含義:

#重點看第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

8. 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

相关推荐:《Linux视频教程

以上是整理一份常用的linux指令(總結分享)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:juejin.im。如有侵權,請聯絡admin@php.cn刪除