Linux基礎命令

玩轉Linux操做系統

說明:本文中對Linux命令的講解都是基於名爲CentOS的Linux發行版本,我本身使用的是阿里雲服務器,系統版本爲CentOS Linux release 7.6.1810。不一樣的Linux發行版本在Shell命令和工具程序上會有一些差異,可是這些差異是很小的。javascript

Linux概述

Linux是一個通用操做系統。一個操做系統要負責任務調度、內存分配、處理外圍設備I/O等操做。操做系統一般由內核(運行其餘程序,管理像磁盤、打印機等硬件設備的核心程序)和系統程序(設備驅動、底層庫、shell、服務程序等)兩部分組成。html

Linux內核是芬蘭人Linus Torvalds開發的,於1991年9月發佈。而Linux操做系統做爲Internet時代的產物,它是由全世界許多開發者共同合做開發的,是一個自由的操做系統(注意自由和免費並非同一個概念,想了解兩者的差異能夠點擊這裏)。html5

Linux系統優勢

  1. 通用操做系統,不跟特定的硬件綁定。
  2. 用C語言編寫,可移植性強,有內核編程接口。
  3. 支持多用戶和多任務,支持安全的分層文件系統。
  4. 大量的實用程序,完善的網絡功能以及強大的支持文檔。
  5. 可靠的安全性和良好的穩定性,對開發者更友好。

Linux系統發行版本

  1. Redhat
  2. Ubuntu
  3. CentOS
  4. Fedora
  5. Debian
  6. openSUSE

基礎命令

Linux系統的命令一般都是以下所示的格式:java

命令名稱 [命名參數] [命令對象]
  1. 獲取登陸信息 - w / who / last/ lastbnode

    [root ~]# w
     23:31:16 up 12:16,  2 users,  load average: 0.00, 0.01, 0.05
    USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
    root     pts/0    182.139.66.250   23:03    4.00s  0.02s  0.00s w
    jackfrue pts/1    182.139.66.250   23:26    3:56   0.00s  0.00s -bash
    [root ~]# who
    root     pts/0        2018-04-12 23:03 (182.139.66.250)
    jackfrued pts/1        2018-04-12 23:26 (182.139.66.250)
    [root ~]# who am i
    root     pts/0        2018-04-12 23:03 (182.139.66.250)
    [root ~]# who mom likes
    root     pts/0        2018-04-12 23:03 (182.139.66.250)
    [root ~]# last
    root     pts/0        117.136.63.184   Sun May 26 18:57   still logged in   
    reboot   system boot  3.10.0-957.10.1. Mon May 27 02:52 - 19:10  (-7:-42)   
    root     pts/4        117.136.63.184   Sun May 26 18:51 - crash  (08:01)    
    root     pts/4        117.136.63.184   Sun May 26 18:49 - 18:49  (00:00)    
    root     pts/3        117.136.63.183   Sun May 26 18:35 - crash  (08:17)    
    root     pts/2        117.136.63.183   Sun May 26 18:34 - crash  (08:17)    
    root     pts/0        117.136.63.183   Sun May 26 18:10 - crash  (08:42)    
  2. 查看本身使用的Shell - pspython

    Shell也被稱爲「殼」或「殼程序」,它是用戶與操做系統內核交流的翻譯官,簡單的說就是人與計算機交互的界面和接口。目前不少Linux系統默認的Shell都是bash(Bourne Again SHell),由於它可使用tab鍵進行命令和路徑補全、能夠保存歷史命令、能夠方便的配置環境變量以及執行批處理操做。mysql

    [root@izwz97tbgo9lkabnat2lo8z ~]# ps
      PID TTY          TIME CMD
     3531 pts/0    00:00:00 bash
     3553 pts/0    00:00:00 ps
  3. 查看命令的說明和位置 - whatis / which / whereislinux

    [root ~]# whatis ps
    ps (1)        - report a snapshot of the current processes.
    [root ~]# whatis python
    python (1)    - an interpreted, interactive, object-oriented programming language
    [root ~]# whereis ps
    ps: /usr/bin/ps /usr/share/man/man1/ps.1.gz
    [root ~]# whereis python
    python: /usr/bin/python /usr/bin/python2.7 /usr/lib/python2.7 /usr/lib64/python2.7 /etc/python /usr/include/python2.7 /usr/share/man/man1/python.1.gz
    [root ~]# which ps
    /usr/bin/ps
    [root ~]# which python
    /usr/bin/python
  4. 清除屏幕上顯示的內容 - clearios

  5. 查看幫助文檔 - man / info / help / aproposnginx

    [root@izwz97tbgo9lkabnat2lo8z ~]# ps --help
    Usage:
     ps [options]
     Try 'ps --help <simple|list|output|threads|misc|all>'
      or 'ps --help <s|l|o|t|m|a>'
     for additional help text.
    For more details see ps(1).
    [root@izwz97tbgo9lkabnat2lo8z ~]# man ps
    PS(1)                                User Commands                                PS(1)
    NAME
           ps - report a snapshot of the current processes.
    SYNOPSIS
           ps [options]
    DESCRIPTION
    ...
  6. 查看系統和主機名 - uname / hostname

    [root@izwz97tbgo9lkabnat2lo8z ~]# uname
    Linux
    [root@izwz97tbgo9lkabnat2lo8z ~]# hostname
    izwz97tbgo9lkabnat2lo8z
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# cat /etc/centos-release
    CentOS Linux release 7.6.1810 (Core)

    說明:cat是鏈接文件內容並打印到標準輸出的命令,後面會講到該命令;/etc是Linux系統上的一個很是重要的目錄,它保存了不少的配置文件;centos-release是該目錄下的一個文件,由於我本身使用的Linux發行版本是CentOS 7.6,所以這裏會有一個這樣的文件。

  7. 時間和日期 - date / cal

    [root@iZwz97tbgo9lkabnat2lo8Z ~]# date
    Wed Jun 20 12:53:19 CST 2018
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# cal
          June 2018
    Su Mo Tu We Th Fr Sa
                    1  2
     3  4  5  6  7  8  9
    10 11 12 13 14 15 16
    17 18 19 20 21 22 23
    24 25 26 27 28 29 30
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# cal 5 2017
          May 2017
    Su Mo Tu We Th Fr Sa
        1  2  3  4  5  6
     7  8  9 10 11 12 13
    14 15 16 17 18 19 20
    21 22 23 24 25 26 27
    28 29 30 31
  8. 重啓和關機 - reboot / shutdown

    [root ~]# shutdown -h +5
    Shutdown scheduled for Sun 2019-05-26 19:34:27 CST, use 'shutdown -c' to cancel.
    [root ~]# 
    Broadcast message from root (Sun 2019-05-26 19:29:27 CST):
    
    The system is going down for power-off at Sun 2019-05-26 19:34:27 CST!
    [root ~]# shutdown -c
    
    Broadcast message from root (Sun 2019-05-26 19:30:22 CST):
    
    The system shutdown has been cancelled at Sun 2019-05-26 19:31:22 CST!
    [root ~]# shutdown -r 23:58
    Shutdown scheduled for Sun 2019-05-26 23:58:00 CST, use 'shutdown -c' to cancel.
    [root ~]# shutdown -c
    
    Broadcast message from root (Sun 2019-05-26 19:31:06 CST):
    
    The system shutdown has been cancelled at Sun 2019-05-26 19:32:06 CST!

    說明:在執行shutdown命令時會向登陸系統的用戶發出警告,能夠在命令後面跟上警告消息來替換默認的警告消息,也能夠在-h參數後經過now來表示馬上關機。

  9. 退出登陸 - exit / logout

  10. 查看歷史命令 - history

[root@iZwz97tbgo9lkabnat2lo8Z ~]# history
...
452  ls
453  cd Python-3.6.5/
454  clear
455  history
[root@iZwz97tbgo9lkabnat2lo8Z ~]# !454

說明:查看到歷史命令以後,能夠用!歷史命令編號來從新執行該命令;經過history -c能夠清除歷史命令。

實用程序

文件和文件夾操做

  1. 建立/刪除空目錄 - mkdir / rmdir

    [root ~]# mkdir abc
    [root ~]# mkdir -p xyz/abc
    [root ~]# rmdir abc
  2. 建立/刪除文件 - touch / rm

    [root ~]# touch readme.txt
    [root ~]# touch error.txt
    [root ~]# rm error.txt
    rm: remove regular empty file ‘error.txt’? y
    [root ~]# rm -rf xyz
    • touch命令用於建立空白文件或修改文件時間。在Linux系統中一個文件有三種時間:
      • 更改內容的時間 - mtime。
      • 更改權限的時間 - ctime。
      • 最後訪問時間 - atime。
    • rm的幾個重要參數:
      • -i:交互式刪除,每一個刪除項都會進行詢問。
      • -r:刪除目錄並遞歸的刪除目錄中的文件和目錄。
      • -f:強制刪除,忽略不存在的文件,沒有任何提示。
  3. 切換和查看當前工做目錄 - cd / pwd

    說明:cd命令後面能夠跟相對路徑(以當前路徑做爲參照)或絕對路徑(以/開頭)來切換到指定的目錄,也能夠用cd ..來返回上一級目錄。請你們想想,若是要返回到上上一級目錄應該給cd命令加上什麼樣的參數呢?

  4. 查看目錄內容 - ls

    • -l:以長格式查看文件和目錄。
    • -a:顯示以點開頭的文件和目錄(隱藏文件)。
    • -R:遇到目錄要進行遞歸展開(繼續列出目錄下面的文件和目錄)。
    • -d:只列出目錄,不列出其餘內容。
    • -S / -t:按大小/時間排序。
  5. 查看文件內容 - cat / tac / head / tail / more / less / rev / od

    [root ~]# wget http://www.sohu.com/ -O sohu.html
    --2018-06-20 18:42:34--  http://www.sohu.com/
    Resolving www.sohu.com (www.sohu.com)... 14.18.240.6
    Connecting to www.sohu.com (www.sohu.com)|14.18.240.6|:80... connected.
    HTTP request sent, awaiting response... 200 OK
    Length: 212527 (208K) [text/html]
    Saving to: ‘sohu.html’
    100%[==================================================>] 212,527     --.-K/s   in 0.03s
    2018-06-20 18:42:34 (7.48 MB/s) - ‘sohu.html’ saved [212527/212527]
    [root ~]# cat sohu.html
    ...
    [root ~]# head -10 sohu.html
    <!DOCTYPE html>
    <html>
    <head>
    <title>搜狐</title>
    <meta name="Keywords" content="搜狐,門戶網站,新媒體,網絡媒體,新聞,財經,體育,娛樂,時尚,汽車,房產,科技,圖片,論壇,微博,博客,視頻,電影,電視劇"/>
    <meta name="Description" content="搜狐網爲用戶提供24小時不間斷的最新資訊,及搜索、郵件等網絡服務。內容包括全球熱點事件、突發新聞、時事評論、熱播影視劇、體育賽事、行業動態、生活服務信息,以及論壇、博客、微博、個人搜狐等互動空間。" />
    <meta name="shenma-site-verification" content="1237e4d02a3d8d73e96cbd97b699e9c3_1504254750">
    <meta charset="utf-8"/>
    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1"/>
    [root ~]# tail -2 sohu.html
    </body>
    </html>
    [root ~]# less sohu.html
    ...
    [root ~]# cat -n sohu.html | more
    ...

    說明:上面用到了一個名爲wget的命令,它是一個網絡下載器程序,能夠從指定的URL下載資源。

  6. 拷貝/移動文件 - cp / mv

    [root ~]# mkdir backup
    [root ~]# cp sohu.html backup/
    [root ~]# cd backup
    [root backup]# ls
    sohu.html
    [root backup]# mv sohu.html sohu_index.html
    [root backup]# ls
    sohu_index.html
  7. 文件重命名 - rename

[root@iZwz97tbgo9lkabnat2lo8Z ~]# rename .htm .html *.htm
  1. 查找文件和查找內容 - find / grep

    [root@iZwz97tbgo9lkabnat2lo8Z ~]# find / -name "*.html"
    /root/sohu.html
    /root/backup/sohu_index.html
    [root@izwz97tbgo9lkabnat2lo8z ~]# find . -atime 7 -type f -print
    [root@izwz97tbgo9lkabnat2lo8z ~]# find . -type f -size +2k
    [root@izwz97tbgo9lkabnat2lo8z ~]# find . -type f -name "*.swp" -delete
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# grep "<script>" sohu.html -n
    20:<script>
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# grep -E \<\/?script.*\> sohu.html -n
    20:<script>
    22:</script>
    24:<script src="//statics.itc.cn/web/v3/static/js/es5-shim-08e41cfc3e.min.js"></script>
    25:<script src="//statics.itc.cn/web/v3/static/js/es5-sham-1d5fa1124b.min.js"></script>
    26:<script src="//statics.itc.cn/web/v3/static/js/html5shiv-21fc8c2ba6.js"></script>
    29:<script type="text/javascript">
    52:</script>
    ...

    說明:grep在搜索字符串時可使用正則表達式,若是須要使用正則表達式能夠用grep -E或者直接使用egrep

  2. 建立連接和查看連接 - ln / readlink

    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ls -l sohu.html
    -rw-r--r-- 1 root root 212131 Jun 20 19:15 sohu.html
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ln /root/sohu.html /root/backup/sohu_backup
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ls -l sohu.html
    -rw-r--r-- 2 root root 212131 Jun 20 19:15 sohu.html
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ln /root/sohu.html /root/backup/sohu_backup2
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ls -l sohu.html
    -rw-r--r-- 3 root root 212131 Jun 20 19:15 sohu.html
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ln -s /etc/centos-release sysinfo
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# ls -l sysinfo
    lrwxrwxrwx 1 root root 19 Jun 20 19:21 sysinfo -> /etc/centos-release
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# cat sysinfo
    CentOS Linux release 7.4.1708 (Core)
    [root@iZwz97tbgo9lkabnat2lo8Z ~]# cat /etc/centos-release
    CentOS Linux release 7.4.1708 (Core)

    說明:連接能夠分爲硬連接和軟連接(符號連接)。硬連接能夠認爲是一個指向文件數據的指針,就像Python中對象的引用計數,每添加一個硬連接,文件的對應連接數就增長1,只有當文件的連接數爲0時,文件所對應的存儲空間纔有可能被其餘文件覆蓋。咱們日常刪除文件時其實並無刪除硬盤上的數據,咱們刪除的只是一個指針,或者說是數據的一條使用記錄,因此相似於「文件粉碎機」之類的軟件在「粉碎」文件時除了刪除文件指針,還會在文件對應的存儲區域填入數據來保證文件沒法再恢復。軟連接相似於Windows系統下的快捷方式,當軟連接連接的文件被刪除時,軟連接也就失效了。

  3. 壓縮/解壓縮和歸檔/解歸檔 - gzip / gunzip / xz

[root@iZwz97tbgo9lkabnat2lo8Z ~]# wget http://download.redis.io/releases/redis-4.0.10.tar.gz
--2018-06-20 19:29:59--  http://download.redis.io/releases/redis-4.0.10.tar.gz
Resolving download.redis.io (download.redis.io)... 109.74.203.151
Connecting to download.redis.io (download.redis.io)|109.74.203.151|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 1738465 (1.7M) [application/x-gzip]
Saving to: ‘redis-4.0.10.tar.gz’
100%[==================================================>] 1,738,465   70.1KB/s   in 74s
2018-06-20 19:31:14 (22.9 KB/s) - ‘redis-4.0.10.tar.gz’ saved [1738465/1738465]
[root@iZwz97tbgo9lkabnat2lo8Z ~]# ls redis*
redis-4.0.10.tar.gz
[root@iZwz97tbgo9lkabnat2lo8Z ~]# gunzip redis-4.0.10.tar.gz
[root@iZwz97tbgo9lkabnat2lo8Z ~]# ls redis*
redis-4.0.10.tar
  1. 歸檔和解歸檔 - tar
[root@iZwz97tbgo9lkabnat2lo8Z ~]# tar -xvf redis-4.0.10.tar
redis-4.0.10/
redis-4.0.10/.gitignore
redis-4.0.10/00-RELEASENOTES
redis-4.0.10/BUGS
redis-4.0.10/CONTRIBUTING
redis-4.0.10/COPYING
redis-4.0.10/INSTALL
redis-4.0.10/MANIFESTO
redis-4.0.10/Makefile
redis-4.0.10/README.md
redis-4.0.10/deps/
redis-4.0.10/deps/Makefile
redis-4.0.10/deps/README.md
...

說明:歸檔(也稱爲建立歸檔)和解歸檔都使用tar命令,一般建立歸檔須要-cvf三個參數,其中c表示建立(create),v表示顯示建立歸檔詳情(verbose),f表示指定歸檔的文件(file);解歸檔須要加上-xvf參數,其中x表示抽取(extract),其餘兩個參數跟建立歸檔相同。

  1. 將標準輸入轉成命令行參數 - xargs

下面的命令會將查找當前路徑下的html文件,而後經過xargs將這些文件做爲參數傳給rm命令,實現查找並刪除文件的操做。

[root@iZwz97tbgo9lkabnat2lo8Z ~]# find . -type f -name "*.html" | xargs rm -f

下面的命令將a.txt文件中的多行內容變成一行輸出到b.txt文件中,其中<表示從a.txt中讀取輸入,>表示將命令的執行結果輸出到b.txt中。

[root@iZwz97tbgo9lkabnat2lo8Z ~]# xargs < a.txt > b.txt

說明:這個命令就像上面演示的那樣常在管道(實現進程間通訊的一種方式)和重定向(從新指定輸入輸出的位置)操做中用到,後面的內容中會講到管道操做和輸入輸出重定向操做。

  1. 顯示文件或目錄 - basename / dirname

  2. 其餘相關工具。

  • sort - 對內容排序
  • uniq - 去掉相鄰重複內容
  • tr - 替換指定內容爲新內容
  • cut / paste - 剪切/黏貼內容
  • split - 拆分文件
  • file - 判斷文件類型
  • wc - 統計文件行數、單詞數、字節數
  • iconv - 編碼轉換
[root ~]# cat foo.txt
grape
apple
pitaya
[root ~]# cat bar.txt
100
200
300
400
[root ~]# paste foo.txt bar.txt
grape   100
apple   200
pitaya  300
        400
[root ~]# paste foo.txt bar.txt > hello.txt
[root ~]# cut -b 4-8 hello.txt
pe      10
le      20
aya     3
0
[root ~]# cat hello.txt | tr '\t' ','
grape,100
apple,200
pitaya,300
,400
[root ~]# split -l 100 sohu.html hello
[root ~]# wget https://www.baidu.com/img/bd_logo1.png
[root ~]# file bd_logo1.png
bd_logo1.png: PNG image data, 540 x 258, 8-bit colormap, non-interlaced
[root ~]# wc sohu.html
  2979   6355 212527 sohu.html
[root ~]# wc -l sohu.html
2979 sohu.html
[root ~]# wget http://www.qq.com -O qq.html
[root ~]# iconv -f gb2312 -t utf-8 qq.html

管道和重定向

  1. 管道的使用 - |

    例子:查找當前目錄下文件個數。

    [root ~]# find ./ | wc -l
    6152

    例子:列出當前路徑下的文件和文件夾,給每一項加一個編號。

    [root ~]# ls | cat -n
         1  dump.rdb
         2  mongodb-3.6.5
         3  Python-3.6.5
         4  redis-3.2.11
         5  redis.conf

    例子:查找record.log中包含AAA,但不包含BBB的記錄的總數

    [root ~]# cat record.log | grep AAA | grep -v BBB | wc -l
  2. 輸出重定向和錯誤重定向 - > / >> / 2>

    [root ~]# cat readme.txt
    banana
    apple
    grape
    apple
    grape
    watermelon
    pear
    pitaya
    [root ~]# cat readme.txt | sort | uniq > result.txt
    [root ~]# cat result.txt
    apple
    banana
    grape
    pear
    pitaya
    watermelon
  3. 輸入重定向 - <

    [root ~]# echo 'hello, world!' > hello.txt
    [root ~]# wall < hello.txt
    [root ~]#
    Broadcast message from root (Wed Jun 20 19:43:05 2018):
    hello, world!
    [root ~]# echo 'I will show you some code.' >> hello.txt
    [root ~]# wall < hello.txt
    [root ~]#
    Broadcast message from root (Wed Jun 20 19:43:55 2018):
    hello, world!
    I will show you some code.
  4. 多重定向 - tee

    下面的命令除了在終端顯示命令ls的結果以外,還會追加輸出到ls.txt文件中。

    [root ~]# ls | tee -a ls.txt

別名

  1. alias

    [root ~]# alias ll='ls -l'
    [root ~]# alias frm='rm -rf'
    [root ~]# ll
    ...
    drwxr-xr-x  2 root       root   4096 Jun 20 12:52 abc
    ...
    [root ~]# frm abc
  2. unalias

    [root ~]# unalias frm
    [root ~]# frm sohu.html
    -bash: frm: command not found

文本處理

  1. 字符流編輯器 - sed

    sed是操做、過濾和轉換文本內容的工具。假設有一個名爲fruit.txt的文件,內容以下所示。

    [root ~]# cat -n fruit.txt 
         1  banana
         2  grape
         3  apple
         4  watermelon
         5  orange

    接下來,咱們在第2行後面添加一個pitaya。

    [root ~]# sed '2a pitaya' fruit.txt 
    banana
    grape
    pitaya
    apple
    watermelon
    orange

    注意:剛纔的命令和以前咱們講過的不少命令同樣並無改變fruit.txt文件,而是將添加了新行的內容輸出到終端中,若是想保存到fruit.txt中,可使用輸出重定向操做。

    在第2行前面插入一個waxberry。

    [root ~]# sed '2i waxberry' fruit.txt
    banana
    waxberry
    grape
    apple
    watermelon
    orange

    刪除第3行。

    [root ~]# sed '3d' fruit.txt
    banana
    grape
    watermelon
    orange

    刪除第2行到第4行。

    [root ~]# sed '2,4d' fruit.txt
    banana
    orange

    將文本中的字符a替換爲@。

    [root ~]# sed 's#a#@#' fruit.txt 
    b@nana
    gr@pe
    @pple
    w@termelon
    or@nge

    將文本中的字符a替換爲@,使用全局模式。

    [root ~]# sed 's#a#@#g' fruit.txt 
    b@n@n@
    gr@pe
    @pple
    w@termelon
    or@nge
  2. 模式匹配和處理語言 - awk

    awk是一種編程語言,也是Linux系統中處理文本最爲強大的工具,它的做者之一和如今的維護者就是以前提到過的Brian Kernighan(ken和dmr最親密的夥伴)。經過該命令能夠從文本中提取出指定的列、用正則表達式從文本中取出咱們想要的內容、顯示指定的行以及進行統計和運算,總之它很是強大。

    假設有一個名爲fruit2.txt的文件,內容以下所示。

    [root ~]# cat fruit2.txt 
    1       banana      120
    2       grape       500
    3       apple       1230
    4       watermelon  80
    5       orange      400

    顯示文件的第3行。

    [root ~]# awk 'NR==3' fruit2.txt 
    3       apple       1230

    顯示文件的第2列。

    [root ~]# awk '{print $2}' fruit2.txt 
    banana
    grape
    apple
    watermelon
    orange

    顯示文件的最後一列。

    [root ~]# awk '{print $NF}' fruit2.txt 
    120
    500
    1230
    80
    400

    輸出末尾數字大於等於300的行。

    [root ~]# awk '{if($3 >= 300) {print $0}}' fruit2.txt 
    2       grape       500
    3       apple       1230
    5       orange      400

    上面展現的只是awk命令的冰山一角,更多的內容留給讀者本身在實踐中去探索。

用戶管理

  1. 建立和刪除用戶 - useradd / userdel

    [root home]# useradd hellokitty
    [root home]# userdel hellokitty
    • -d - 建立用戶時爲用戶指定用戶主目錄
    • -g - 建立用戶時指定用戶所屬的用戶組
  2. 建立和刪除用戶組 - groupadd / groupdel

    說明:用戶組主要是爲了方便對一個組裏面全部用戶的管理。

  3. 修改密碼 - passwd

    [root ~]# passwd hellokitty
    New password: 
    Retype new password: 
    passwd: all authentication tokens updated successfully.

    說明:輸入密碼和確認密碼沒有回顯且必須一鼓作氣的輸入完成(不能使用退格鍵),密碼和確認密碼須要一致。若是使用passwd命令時沒有指定命令做用的對象,則表示要修改當前用戶的密碼。若是想批量修改用戶密碼,可使用chpasswd命令。

    • -l / -u - 鎖定/解鎖用戶。
    • -d - 清除用戶密碼。
    • -e - 設置密碼當即過時,用戶登陸時會強制要求修改密碼。
    • -i - 設置密碼過時多少天之後禁用該用戶。
  4. 查看和修改密碼有效期 - chage

    設置hellokitty用戶100天后必須修改密碼,過時前15天通知該用戶,過時後15天禁用該用戶。

    chage -M 100 -W 15 -I 15 hellokitty
  5. 切換用戶 - su

    [root ~]# su hellokitty
    [hellokitty root]$
  6. 以管理員身份執行命令 - sudo

    [hellokitty ~]$ ls /root
    ls: cannot open directory /root: Permission denied
    [hellokitty ~]$ sudo ls /root
    [sudo] password for hellokitty:

    說明:若是但願用戶可以以管理員身份執行命令,用戶必需要出如今sudoers名單中,sudoers文件在 /etc目錄下,若是但願直接編輯該文件也可使用下面的命令。

  7. 編輯sudoers文件 - visudo

    這裏使用的編輯器是vi,關於vi的知識在後面有講解。該文件的部份內容以下所示:

    ## Allow root to run any commands anywhere 
    root    ALL=(ALL)   ALL
    
    ## Allows members of the 'sys' group to run networking, software, 
    ## service management apps and more.
    # %sys ALL = NETWORKING, SOFTWARE, SERVICES, STORAGE, DELEGATING, PROCESSES, LOCATE, DRIVERS
    ## Allows people in group wheel to run all commands
    %wheel  ALL=(ALL)   ALL
    
    ## Same thing without a password
    # %wheel    ALL=(ALL)   NOPASSWD: ALL
    
    ## Allows members of the users group to mount and unmount the
    ## cdrom as root
    # %users  ALL=/sbin/mount /mnt/cdrom, /sbin/umount /mnt/cdrom
    
    ## Allows members of the users group to shutdown this system
    # %users  localhost=/sbin/shutdown -h now
  8. 顯示用戶與用戶組的信息 - id

  9. 給其餘用戶發消息 -write / wall

    發送方:

    [root ~]# write hellokitty
    Dinner is on me.
    Call me at 6pm.

    接收方:

    [hellokitty ~]$ 
    Message from root on pts/0 at 17:41 ...
    Dinner is on me.
    Call me at 6pm.
    EOF
  10. 查看/設置是否接收其餘用戶發送的消息 - mesg

[hellokitty ~]$ mesg
is y
[hellokitty ~]$ mesg n
[hellokitty ~]$ mesg
is n

文件系統

文件和路徑

  1. 命名規則:文件名的最大長度與文件系統類型有關,通常狀況下,文件名不該該超過255個字符,雖然絕大多數的字符均可以用於文件名,可是最好使用英文大小寫字母、數字、下劃線、點這樣的符號。文件名中雖然可使用空格,但應該儘量避免使用空格,不然在輸入文件名時須要用將文件名放在雙引號中或者經過\對空格進行轉義。
  2. 擴展名:在Linux系統下文件的擴展名是可選的,可是使用擴展名有助於對文件內容的理解。有些應用程序要經過擴展名來識別文件,可是更多的應用程序並不依賴文件的擴展名,就像file命令在識別文件時並非依據擴展名來斷定文件的類型。
  3. 隱藏文件:以點開頭的文件在Linux系統中是隱藏文件(不可見文件)。

目錄結構

  1. /bin - 基本命令的二進制文件。
  2. /boot - 引導加載程序的靜態文件。
  3. /dev - 設備文件。
  4. /etc - 配置文件。
  5. /home - 普通用戶主目錄的父目錄。
  6. /lib - 共享庫文件。
  7. /lib64 - 共享64位庫文件。
  8. /lost+found - 存放未連接文件。
  9. /media - 自動識別設備的掛載目錄。
  10. /mnt - 臨時掛載文件系統的掛載點。
  11. /opt - 可選插件軟件包安裝位置。
  12. /proc - 內核和進程信息。
  13. /root - 超級管理員用戶主目錄。
  14. /run - 存放系統運行時須要的東西。
  15. /sbin - 超級用戶的二進制文件。
  16. /sys - 設備的僞文件系統。
  17. /tmp - 臨時文件夾。
  18. /usr - 用戶應用目錄。
  19. /var - 變量數據目錄。

訪問權限

  1. chmod - 改變文件模式比特。

    [root ~]# ls -l
    ...
    -rw-r--r--  1 root       root 211878 Jun 19 16:06 sohu.html
    ...
    [root ~]# chmod g+w,o+w sohu.html
    [root ~]# ls -l
    ...
    -rw-rw-rw-  1 root       root 211878 Jun 19 16:06 sohu.html
    ...
    [root ~]# chmod 644 sohu.html
    [root ~]# ls -l
    ...
    -rw-r--r--  1 root       root 211878 Jun 19 16:06 sohu.html
    ...

    說明:經過上面的例子能夠看出,用chmod改變文件模式比特有兩種方式:一種是字符設定法,另外一種是數字設定法。除了chmod以外,能夠經過umask來設定哪些權限將在新文件的默認權限中被刪除。

    長格式查看目錄或文件時顯示結果及其對應權限的數值以下表所示。

  2. chown - 改變文件全部者。

    [root ~]# ls -l
    ...
    -rw-r--r--  1 root root     54 Jun 20 10:06 readme.txt
    ...
    [root ~]# chown hellokitty readme.txt
    [root ~]# ls -l
    ...
    -rw-r--r--  1 hellokitty root     54 Jun 20 10:06 readme.txt
    ...
  3. chgrp - 改變用戶組。

磁盤管理

  1. 列出文件系統的磁盤使用情況 - df

    [root ~]# df -h
    Filesystem      Size  Used Avail Use% Mounted on
    /dev/vda1        40G  5.0G   33G  14% /
    devtmpfs        486M     0  486M   0% /dev
    tmpfs           497M     0  497M   0% /dev/shm
    tmpfs           497M  356K  496M   1% /run
    tmpfs           497M     0  497M   0% /sys/fs/cgroup
    tmpfs           100M     0  100M   0% /run/user/0
  2. 磁盤分區表操做 - fdisk

    [root ~]# fdisk -l
    Disk /dev/vda: 42.9 GB, 42949672960 bytes, 83886080 sectors
    Units = sectors of 1 * 512 = 512 bytes
    Sector size (logical/physical): 512 bytes / 512 bytes
    I/O size (minimum/optimal): 512 bytes / 512 bytes
    Disk label type: dos
    Disk identifier: 0x000a42f4
       Device Boot      Start         End      Blocks   Id  System
    /dev/vda1   *        2048    83884031    41940992   83  Linux
    Disk /dev/vdb: 21.5 GB, 21474836480 bytes, 41943040 sectors
    Units = sectors of 1 * 512 = 512 bytes
    Sector size (logical/physical): 512 bytes / 512 bytes
    I/O size (minimum/optimal): 512 bytes / 512 bytes
  3. 磁盤分區工具 - parted

  4. 格式化文件系統 - mkfs

    [root ~]# mkfs -t ext4 -v /dev/sdb
    • -t - 指定文件系統的類型。
    • -c - 建立文件系統時檢查磁盤損壞狀況。
    • -v - 顯示詳細信息。
  5. 文件系統檢查 - fsck

  6. 轉換或拷貝文件 - dd

  7. 掛載/卸載 - mount / umount

  8. 建立/激活/關閉交換分區 - mkswap / swapon / swapoff

說明:執行上面這些命令會帶有必定的風險,若是不清楚這些命令的用法,最好不用隨意使用,在使用的過程當中,最好對照參考資料進行操做,並在操做前確認是否要這麼作。

編輯器 - vim

  1. 啓動vim。能夠經過vivim命令來啓動vim,啓動時能夠指定文件名來打開一個文件,若是沒有指定文件名,也能夠在保存的時候指定文件名。

    [root ~]# vim guess.py
  2. 命令模式、編輯模式和末行模式:啓動vim進入的是命令模式(也稱爲Normal模式),在命令模式下輸入英文字母i會進入編輯模式(Insert模式),屏幕下方出現-- INSERT --提示;在編輯模式下按下Esc會回到命令模式,此時若是輸入英文:會進入末行模式,在末行模式下輸入q!能夠在不保存當前工做的狀況下強行退出vim;在命令模式下輸入v會進入可視模式(Visual模式),能夠用光標選擇一個區域再完成對應的操做。

  3. 保存和退出vim:在命令模式下輸入: 進入末行模式,輸入wq能夠實現保存退出;若是想放棄編輯的內容輸入q!強行退出,這一點剛纔已經提到過了;在命令模式下也能夠直接輸入ZZ實現保存退出。若是隻想保存文件不退出,那麼能夠在末行模式下輸入w;能夠在w後面輸入空格再指定要保存的文件名。

  4. 光標操做。

    • 在命令模式下能夠經過hjkl來控制光標向左、下、上、右的方向移動,能夠在字母前輸入數字來表示移動的距離,例如:10h表示向左移動10個字符。
    • 在命令模式下能夠經過Ctrl+yCtrl+e來實現向上、向下滾動一行文本的操做,能夠經過Ctrl+fCtrl+b來實現向前和向後翻頁的操做。
    • 在命令模式下能夠經過輸入英文字母G將光標移到文件的末尾,能夠經過gg將光標移到文件的開始,也能夠經過在G前輸入數字來將光標移動到指定的行。
  5. 文本操做。

    • 刪除:在命令模式下能夠用dd來刪除整行;能夠在dd前加數字來指定刪除的行數;能夠用d$來實現刪除從光標處刪到行尾的操做,也能夠經過d0來實現從光標處刪到行首的操做;若是想刪除一個單詞,可使用dw;若是要刪除全文,能夠在輸入:%d(其中:用來從命令模式進入末行模式)。
    • 複製和粘貼:在命令模式下能夠用yy來複制整行;能夠在yy前加數字來指定複製的行數;能夠經過p將複製的內容粘貼到光標所在的地方。
    • 撤銷和恢復:在命令模式下輸入u能夠撤銷以前的操做;經過Ctrl+r能夠恢復被撤銷的操做。
    • 對內容進行排序:在命令模式下輸入%!sort
  6. 查找和替換。

    • 查找操做須要輸入/進入末行模式並提供正則表達式來匹配與之對應的內容,例如:/doc.*\.,輸入n來向前搜索,也能夠輸入N來向後搜索。
    • 替換操做須要輸入:進入末行模式並指定搜索的範圍、正則表達式以及替換後的內容和匹配選項,例如::1,$s/doc.*/hello/gice,其中:
      • g - global:全局匹配。
      • i - ignore case:忽略大小寫匹配。
      • c - confirm:替換時須要確認。
      • e - error:忽略錯誤。
  7. 參數設定:在輸入:進入末行模式後能夠對vim進行設定。

    • 設置Tab鍵的空格數:set ts=4

    • 設置顯示/不顯示行號:set nu / set nonu

    • 設置啓用/關閉高亮語法:syntax on / syntax off

    • 設置顯示標尺(光標所在的行和列): set ruler

    • 設置啓用/關閉搜索結果高亮:set hls / set nohls

      說明:若是但願上面的這些設定在每次啓動vim時都能自動生效,須要將這些設定寫到用戶主目錄下的.vimrc文件中。

  8. 高級技巧

    • 比較多個文件。

      [root ~]# vim -d foo.txt bar.txt

    • 打開多個文件。

      [root ~]# vim foo.txt bar.txt hello.txt

      啓動vim後只有一個窗口顯示的是foo.txt,能夠在末行模式中輸入ls查看到打開的三個文件,也能夠在末行模式中輸入b <num>來顯示另外一個文件,例如能夠用:b 2將bar.txt顯示出來,能夠用:b 3將hello.txt顯示出來。

    • 拆分和切換窗口。

      能夠在末行模式中輸入spvs來實現對窗口的水平或垂直拆分,這樣咱們就能夠同時打開多個編輯窗口,經過按兩次Ctrl+w就能夠實現編輯窗口的切換,在一個窗口中執行退出操做只會關閉對應的窗口,其餘的窗口繼續保留。

    • 映射快捷鍵:在vim下能夠將一些經常使用操做映射爲快捷鍵來提高工做效率。

      • 例子1:在命令模式下輸入F4執行從第一行開始刪除10000行代碼的操做。

        :map <F4> gg10000dd

        例子2:在編輯模式下輸入__main直接補全爲if __name__ == '__main__':

        :inoremap __main if __name__ == '__main__':

      說明:上面例子2的inoremap中的i表示映射的鍵在編輯模式使用, nore表示不要遞歸,這一點很是重要,不然若是鍵對應的內容中又出現鍵自己,就會引起遞歸(至關於進入了死循環)。若是但願映射的快捷鍵每次啓動vim時都能生效,須要將映射寫到用戶主目錄下的.vimrc文件中。

    • 錄製宏。

      • 在命令模式下輸入qa開始錄製宏(其中a是寄存器的名字,也能夠是其餘英文字母或0-9的數字)。

      • 執行你的操做(光標操做、編輯操做等),這些操做都會被錄製下來。

      • 若是錄製的操做已經完成了,按q結束錄製。

      • 經過@aa是剛纔使用的寄存器的名字)播放宏,若是要屢次執行宏能夠在前面加數字,例如100@a表示將宏播放100次。

      • 能夠試一試下面的例子來體驗錄製宏的操做,該例子來源於Harttle Land網站,該網站上提供了不少關於vim的使用技巧,有興趣的能夠了解一下。

軟件安裝和配置

使用包管理工具

  1. yum - Yellowdog Updater Modified。
    • yum search:搜索軟件包,例如yum search nginx
    • yum list installed:列出已經安裝的軟件包,例如yum list installed | grep zlib
    • yum install:安裝軟件包,例如yum install nginx
    • yum remove:刪除軟件包,例如yum remove nginx
    • yum update:更新軟件包,例如yum update能夠更新全部軟件包,而yum update tar只會更新tar。
    • yum check-update:檢查有哪些能夠更新的軟件包。
    • yum info:顯示軟件包的相關信息,例如yum info nginx
  2. rpm - Redhat Package Manager。
    • 安裝軟件包:rpm -ivh <packagename>.rpm
    • 移除軟件包:rpm -e <packagename>
    • 查詢軟件包:rpm -qa,例如能夠用rpm -qa | grep mysql來檢查是否安裝了MySQL相關的軟件包。

下面以Nginx爲例,演示如何使用yum安裝軟件。

[root ~]# yum -y install nginx
...
Installed:
  nginx.x86_64 1:1.12.2-2.el7
Dependency Installed:
  nginx-all-modules.noarch 1:1.12.2-2.el7
  nginx-mod-http-geoip.x86_64 1:1.12.2-2.el7
  nginx-mod-http-image-filter.x86_64 1:1.12.2-2.el7
  nginx-mod-http-perl.x86_64 1:1.12.2-2.el7
  nginx-mod-http-xslt-filter.x86_64 1:1.12.2-2.el7
  nginx-mod-mail.x86_64 1:1.12.2-2.el7
  nginx-mod-stream.x86_64 1:1.12.2-2.el7
Complete!
[root ~]# yum info nginx
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
Installed Packages
Name        : nginx
Arch        : x86_64
Epoch       : 1
Version     : 1.12.2
Release     : 2.el7
Size        : 1.5 M
Repo        : installed
From repo   : epel
Summary     : A high performance web server and reverse proxy server
URL         : http://nginx.org/
License     : BSD
Description : Nginx is a web server and a reverse proxy server for HTTP, SMTP, POP3 and
            : IMAP protocols, with a strong focus on high concurrency, performance and low
            : memory usage.
[root ~]# nginx -v
nginx version: nginx/1.12.2

移除Nginx。

[root ~]# yum -y remove nginx

下面以MySQL爲例,演示如何使用rpm安裝軟件。要安裝MySQL須要先到MySQL官方網站下載對應的RPM文件,固然要選擇和你使用的Linux系統對應的版本。MySQL如今是Oracle公司旗下的產品,在MySQL被收購後,MySQL的做者從新制做了一個MySQL的分支MariaDB,能夠經過yum進行安裝。

[root mysql]# ls
mysql-community-client-5.7.22-1.el7.x86_64.rpm
mysql-community-common-5.7.22-1.el7.x86_64.rpm
mysql-community-libs-5.7.22-1.el7.x86_64.rpm
mysql-community-server-5.7.22-1.el7.x86_64.rpm
[root mysql]# yum -y remove mariadb-libs
[root mysql]# yum -y install libaio
[root mysql]#rpm -ivh mysql-community-common-5.7.26-1.el7.x86_64.rpm
...
[root mysql]#rpm -ivh mysql-community-libs-5.7.26-1.el7.x86_64.rpm
...
[root mysql]#rpm -ivh mysql-community-client-5.7.26-1.el7.x86_64.rpm
...
[root mysql]#rpm -ivh mysql-community-server-5.7.26-1.el7.x86_64.rpm
...

說明:因爲MySQL和MariaDB的底層依賴庫是有衝突的,因此上面咱們首先用yum移除了名爲mariadb-libs的依賴庫並安裝了名爲libaio支持異步I/O操做的依賴庫。關於MySQL和MariaDB之間的關係,能夠閱讀維基百科上關於MariaDB的介紹。

移除安裝的MySQL。

[root ~]# rpm -qa | grep mysql | xargs rpm -e

下載解壓配置環境變量

下面以安裝MongoDB爲例,演示這類軟件應該如何安裝。

[root ~]# wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.5.tgz
--2018-06-21 18:32:53--  https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-3.6.5.tgz
Resolving fastdl.mongodb.org (fastdl.mongodb.org)... 52.85.83.16, 52.85.83.228, 52.85.83.186, ...
Connecting to fastdl.mongodb.org (fastdl.mongodb.org)|52.85.83.16|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 100564462 (96M) [application/x-gzip]
Saving to: ‘mongodb-linux-x86_64-rhel70-3.6.5.tgz’
100%[==================================================>] 100,564,462  630KB/s   in 2m 9s
2018-06-21 18:35:04 (760 KB/s) - ‘mongodb-linux-x86_64-rhel70-3.6.5.tgz’ saved [100564462/100564462]
[root ~]# gunzip mongodb-linux-x86_64-rhel70-3.6.5.tgz
[root ~]# tar -xvf mongodb-linux-x86_64-rhel70-3.6.5.tar
mongodb-linux-x86_64-rhel70-3.6.5/README
mongodb-linux-x86_64-rhel70-3.6.5/THIRD-PARTY-NOTICES
mongodb-linux-x86_64-rhel70-3.6.5/MPL-2
mongodb-linux-x86_64-rhel70-3.6.5/GNU-AGPL-3.0
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongodump
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongorestore
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoexport
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoimport
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongostat
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongotop
mongodb-linux-x86_64-rhel70-3.6.5/bin/bsondump
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongofiles
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoreplay
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongoperf
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongod
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongos
mongodb-linux-x86_64-rhel70-3.6.5/bin/mongo
mongodb-linux-x86_64-rhel70-3.6.5/bin/install_compass
[root ~]# vim .bash_profile
...
PATH=$PATH:$HOME/bin:$HOME/mongodb-linux-x86_64-rhel70-3.6.5/bin
export PATH
...
[root ~]# source .bash_profile
[root ~]# mongod --version
db version v3.6.5
git version: a20ecd3e3a174162052ff99913bc2ca9a839d618
OpenSSL version: OpenSSL 1.0.1e-fips 11 Feb 2013
allocator: tcmalloc
modules: none
build environment:
    distmod: rhel70
    distarch: x86_64
    target_arch: x86_64
[root ~]# mongo --version
MongoDB shell version v3.6.5
git version: a20ecd3e3a174162052ff99913bc2ca9a839d618
OpenSSL version: OpenSSL 1.0.1e-fips 11 Feb 2013
allocator: tcmalloc
modules: none
build environment:
    distmod: rhel70
    distarch: x86_64
    target_arch: x86_64

說明:固然也能夠經過yum來安裝MongoDB,具體能夠參照官方網站上給出的說明。

源碼包與二進制包安裝

  1. 安裝Python 3.6。

    先確保python須要的依賴已經裝好
    yum install -y openssl*
    yum install -y gcc*
    [root ~]# yum install gcc [root ~]# wget https://www.python.org/ftp/python/3.6.5/Python-3.6.5.tgz [root ~]# gunzip Python-3.6.5.tgz [root ~]# tar -xvf Python-3.6.5.tar [root ~]# cd Python-3.6.5 [root ~]# ./configure --prefix=/usr/local/python36 --enable-optimizations [root ~]# yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel [root ~]# make && make install ... [root ~]# ln -s /usr/local/python36/bin/python3.6 /usr/bin/python3 [root ~]# python3 --version Python 3.6.5 [root ~]# python3 -m pip install -U pip
    添加環境變量 [root ~]# vi /etc/profile export PATH="/usr/local/python36/bin:$PATH"
    加載環境變量
    [root ~]# source /etc/profile
    [root ~]#

    說明:上面在安裝好Python以後還須要註冊PATH環境變量,將Python安裝路徑下bin文件夾的絕對路徑註冊到PATH環境變量中。註冊環境變量能夠修改用戶主目錄下的.bash_profile或者/etc目錄下的profile文件,兩者的區別在於前者至關因而用戶環境變量,然後者至關因而系統環境變量。

  2. 安裝Redis-3.2.12。

    [root ~]# wget http://download.redis.io/releases/redis-3.2.12.tar.gz
    [root ~]# gunzip redis-3.2.12.tar.gz
    [root ~]# tar -xvf redis-3.2.12.tar
    [root ~]# cd redis-3.2.12
    [root ~]# make && make install
    [root ~]# redis-server --version
    Redis server v=3.2.12 sha=00000000:0 malloc=jemalloc-4.0.3 bits=64 build=5bc5cd3c03d6ceb6
    [root ~]# redis-cli --version
    redis-cli 3.2.12
    修改環境變量 vim /etc/profile 添加如下一行: export PATH=/opt/redis-3.2.10/src:$PATH

    生效配置 source /etc/profile

    後臺啓動Redis redis-server &
    查看有沒有啓動 netstat -tulnp

3.#安裝Nginx

1) 使用官方Nginx yum源

[root@nginx ~]# vim /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1

#安裝Nginx
[root@nginx ~]# yum install nginx -y
2) 啓動Nginx,並將Nginx加入開機自啓

systemctl start nginx
systemctl enable nginx

 

3.#Django框架和uwsgi

vim re.txt
asn1crypto==0.24.0
beautifulsoup4==4.6.3
bs4==0.0.1
certifi==2018.4.16
cffi==1.11.5
chardet==3.0.4
Click==7.0
cryptography==2.3.1
Django==1.11.9
Flask==1.0.2
Flask-Cors==3.0.6
gevent==1.3.6
greenlet==0.4.15
idna==2.7
ItsDangerous==1.1.0
Jinja2==2.10
lxml==4.2.6
MarkupSafe==1.0
numpy==1.15.3
Pillow==5.3.0
pycparser==2.18
PyMySQL==0.9.2
pytz==2018.7
requests==2.19.1
selenium==3.141.0
six==1.11.0
urllib3==1.23
virtualenv==16.1.0
Werkzeug==0.14.1
wordcloud==1.5.0


pip3 install -i https://pypi.doubanio.com/simple/ -r re.txt
pip3 install -i https://pypi.doubanio.com/simple/ uwsgi

 

 

3.1測試uwsgi是否正常,新建 test.py文件,內容以下:
[root@web01 ~]# vim test.py
def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return [b"Hello Django"]


#而後在終端運行:
[普通用戶]uwsgi --http :8001 --wsgi-file test.py &

查看進程
ps -ef |grep uwsgi
殺死進程
pkill uwsgi

3.2測試django是否正常,運行:
[root@web01 ~]# django-admin.py startproject demosite
[root@web01 ~]# cd demosite
[root@web01 demosite]# python3 manage.py runserver 0.0.0.0:8002
在瀏覽器內輸入:http://127.0.0.1:8002,檢查django是否運行正常。


3.3配置uwsgi
[root@web01 demosite]# vim /root/demosite/uwsgi.ini
[uwsgi]
socket = 127.0.0.1:9999
master = true
workers = 2
max-requests = 1000
buffer-size = 30000
pidfile = /run/uwsgi.pid
daemonize = /var/log/uwsgi.log


uwsgi --ini /root/demosite/uwsgi.ini &

3.4配置Nginx
[root@web01 demosite]# vim /etc/nginx/conf.d/py.conf
server {
listen 80;
server_name 10.0.0.100;
client_max_body_size 100M;

location / {
index index.html;
include uwsgi_params;
uwsgi_pass 127.0.0.1:9999;
uwsgi_param UWSGI_SCRIPT demosite.wsgi;
uwsgi_param UWSGI_CHDIR /root/demosite;
}
}

重啓nginx

 

3.安裝MySQL,並完成主從複製

  

二進制安裝MySQL
1.下載
[root@web01 ~]# wget https://downloads.mysql.com/archives/get/file/mysql-5.6.40-linux-glibc2.12-x86_64.tar.gz

2.解壓
[root@oldboy ~]# tar xf mysql-5.6.40-linux-glibc2.12-x86_64.tar.gz

3.移動到安裝目錄
[root@oldboy ~]# mv mysql-5.6.40-linux-glibc2.12-x86_64 /usr/local/mysql-5.6.40

4.軟連接
[root@oldboy ~]# ln -s /usr/local/mysql-5.6.40 /usr/local/mysql

5.進入MySQL程序目錄
[root@oldboy ~]# cd /usr/local/mysql

6.拷貝配置文件
[root@oldboy /usr/local/mysql/support-files]# cp my-default.cnf /etc/my.cnf

7.拷貝啓動腳本
[root@oldboy /usr/local/mysql/support-files]# cp mysql.server /etc/init.d/mysqld

8.建立mysql用戶
[root@oldboy /usr/local/mysql/support-files]# useradd mysql -s /sbin/nologin -M

9.進入mysql初始化目錄
[root@oldboy /usr/local/mysql]# cd scripts/

10.安裝依賴包
[root@oldboy /usr/local/mysql/scripts]# yum install -y libaio-devel

11.初始化mysql
[root@oldboy /usr/local/mysql/scripts]# ./mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

12.添加環境變量
[root@oldboy /usr/local/mysql/scripts]# vi /etc/profile
export PATH="/usr/local/mysql/bin:$PATH"

13.加載環境變量
[root@oldboy /usr/local/mysql/scripts]# source /etc/profile

14.啓停MySQL
啓動:[root@oldboy /usr/local/mysql/scripts]# /etc/init.d/mysqld start
中止:[root@oldboy /usr/local/mysql/scripts]# /etc/init.d/mysqld stop

15.鏈接MySQL
[root@oldboy /usr/local/mysql/scripts]# mysql

16.設置MySQL密碼
[root@oldboy /usr/local/mysql/scripts]# mysqladmin -uroot -p password '123'

17.修改密碼
[root@oldboy /usr/local/mysql/scripts]# mysqladmin  -uroot -p123 password '1'

[root@oldboy /usr/local/mysql/scripts]# mysql -uroot -p1

  擴展:使用systemctl 管理mysql
  vim /etc/systemd/system/mysqld.service

  1 [Unit]
  2 Description=MySQL Server
  3 Documentation=man:mysqld(8)
  4 Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
  5 After=network.target
  6 After=syslog.target
  7
  8 [Install]
  9 WantedBy=multi-user.target
  10 [Service]
  11 User=mysql
  12 Group=mysql
  13 ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf
  14 LimitNOFILE = 5000

 

  systemctl restart mysqld

  netstat -tulnp |grep 3306

按照圖片來


  4.MySQL高可用MHA

一.MHA安裝部署
    1.MHA先決條件
        主從複製
        至少3臺MySQL
        
    2.傳統主從複製的條件
        1)主庫開啓binlog
        2)主庫開啓server_id
        3)從庫開啓server_id與主庫不一樣,從庫之間server_id能夠相同
        4)主庫要建立一個主從複製用戶
    3.MHA的主從複製
        1)主庫開啓binlog,從庫也要開啓binlog
        2)主庫開啓server_id
        3)從庫也要開啓server_id而且與主庫不相同,從庫之間,也不能相同
        4)主庫要建立一個主從複製用戶,從庫也要有
    4.MHA的工做原理
    當Master出現故障時,它能夠自動將最新數據的Slave提高爲新的Master,而後將全部其餘的Slave從新指向新的Master。
    
    5.部署MHA node
        1)安裝依賴 C/S結構  node
        yum install perl-DBD-MySQL -y
        2)安裝node包
        [root@oldboy ~]# rpm -ivh mha4mysql-node-0.56-0.el6.noarch.rpm
        3)建立mha管理用戶(主庫建立,從庫會複製)
        mysql> grant all on *.* to mha@'%' identified by 'mha';
        4)建立命令的軟連接
        [root@web01 /usr/local/mysql/data]# ln -s /usr/local/mysql/bin/mysql /usr/bin/
        [root@web01 /usr/local/mysql/data]# ln -s /usr/local/mysql/bin/mysqlbinlog /usr/bin/

    6.部署MHA manager
        建議:不要裝在主庫上,能夠裝在任意一臺從庫上,最好是單獨裝一臺機器上
        1)安裝依賴
        yum install -y perl-Config-Tiny epel-release perl-Log-Dispatch perl-Parallel-ForkManager perl-Time-HiRes
        2)安裝manager節點
        [root@web02 ~]# rpm -ivh mha4mysql-manager-0.56-0.el6.noarch.rpm 
        
二.配置MHA
        1.建立MHA配置文件存放目錄
        [root@web02 ~]# mkdir /etc/mha
        2.建立MHA日誌存放目錄
        [root@web02 ~]# mkdir -p /var/log/mha/app1
        3.編輯MHA配置文件
        [root@web02 ~]# vim /etc/mha/app1.cnf
        [server default]
        manager_log=/var/log/mha/app1/manager.log
        manager_workdir=/var/log/mha/app1
        master_binlog_dir=/usr/local/mysql/data
        user=mha
        password=mha
        ping_interval=2
        repl_password=123
        repl_user=egon
        ssh_user=root
        
        [server1]
        hostname=10.0.0.200
        port=3306
        
        [server2]
        hostname=10.0.0.98
        port=3306
        
        [server3]
        hostname=10.0.0.99
        port=3306

        4.建立密鑰對,分發祕鑰
        #建立祕鑰對
        [root@mysql-db01 ~]# ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa >/dev/null 2>&1
        #發送公鑰,包括本身
        [root@mysql-db01 ~]# ssh-copy-id -i /root/.ssh/id_dsa.pub root@10.0.0.200
        [root@mysql-db01 ~]# ssh-copy-id -i /root/.ssh/id_dsa.pub root@10.0.0.98
        [root@mysql-db01 ~]# ssh-copy-id -i /root/.ssh/id_dsa.pub root@10.0.0.99
        
        5.檢測ssh
        [root@web02 ~]# masterha_check_ssh --conf=/etc/mha/app1.cnf
        
        6.檢測replication
        [root@web02 ~]# masterha_check_repl --conf=/etc/mha/app1.cnf
        
        7.啓動MHA
        nohup masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf --ignore_last_failover < /dev/null > /var/log/mha/app1/manager.log 2>&1 &
        
        8.檢測MHA的啓動狀態
        [root@web02 ~]# masterha_check_status --conf=/etc/mha/app1.cnf
        app1 (pid:10300) is running(0:PING_OK), master:10.0.0.200

        9.查看mha的日誌
        [root@web02 ~]# tail -f /var/log/mha/app1/manager.log 
        
        10.將舊主庫加入集羣,變成從庫
        [root@web02 ~]# grep -i 'change master to' /var/log/mha/app1/manager.log
        
        Fri Jun 21 16:17:55 2019 - [info]  All other slaves should start replication from here. Statement should be: CHANGE MASTER TO MASTER_HOST='10.0.0.98', MASTER_PORT=3306, MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=120, MASTER_USER='egon', MASTER_PASSWORD='xxx';
        
三.MHA設置VIP漂移
    1.修改配置文件
    [root@web02 /usr/local/bin]# vim /etc/mha/app1.cnf
    master_ip_failover_script=/usr/local/bin/master_ip_failover
    
    2.將腳本放到/usr/local/bin下
    [root@web02 /usr/local/bin]# cd /usr/local/bin
    [root@web02 /usr/local/bin]# wget http://download.driverzeng.com/master_ip_failover
    
    3.受權腳本執行權限
    [root@web02 /usr/local/bin]# chmod +x master_ip_failover
        1)權限,必須有執行權限
        2)格式,必須是Linux(unix)格式
        3)語法,必須是perl語法

    4.轉換文件格式爲unix
    [root@web02 ~]# dos2unix /usr/local/bin/master_ip_failover 
    dos2unix: converting file /usr/local/bin/master_ip_failover to Unix format ...
    若是沒有dos2unix命令:[root@web02 ~]# yum install -y dos2unix
    
    5.在主庫上綁定vip
    [root@web01 ~]# ifconfig eth0:0 10.0.0.250/24


四.MHA報錯,及解決
    1.沒有跳過反向解析
        Fri Jun 21 16:05:43 2019 - [error][/usr/share/perl5/vendor_perl/MHA/ServerManager.pm, ln301] Got MySQL error when connecting 10.0.0.99(10.0.0.99:3306) :1045:Access denied for user 'mha'@'web02' (using password: YES), but this is not a MySQL crash. Check MySQL server settings.

        跳過反向解析
        [root@oldboy ~]# vim /etc/my.cnf
        [mysqld]
        skip-name-resolve

        重啓MySQL
        [root@oldboy ~]# /etc/init.d/mysqld restart
    
    2.從庫上沒有主從複製用戶
        Fri Jun 21 16:09:37 2019 - [error][/usr/share/perl5/vendor_perl/MHA/Server.pm, ln393] 10.0.0.98(10.0.0.98:3306): User egon does not exist or does not have REPLICATION SLAVE privilege! Other slaves can not start replication from this host.
    
        鏈接主庫
        mysql> grant replication slave on *.* to egon@'%' identified by '123';
    
    
    3.沒有作mysqlbinlog和mysql命令的軟連接
        Fri Jun 21 16:12:04 2019 - [info]   Connecting to root@10.0.0.99(10.0.0.99:22).. 
        Can't exec "mysqlbinlog": No such file or directory at /usr/share/perl5/vendor_perl/MHA/BinlogManager.pm line 106.
        mysqlbinlog version command failed with rc 1:0, please verify PATH, LD_LIBRARY_PATH, and client options
        
        全部MySQL服務器,作命令的軟連接
        [root@web02 ~]# ln -s /usr/local/mysql/bin/mysqlbinlog /usr/bin/
        [root@web02 ~]# ln -s /usr/local/mysql/bin/mysql /usr/bin/

        
        
五.數據備份和恢復
    mysqldump:作數據備份
    -A:全庫備份
    [root@oldboy ~]# mysqldump -uroot -p1 -A > /tmp/full.sql
    -B:指定庫備份
    [root@oldboy ~]# mysqldump -uroot -p1 -B zls > /tmp/zls.sql
    不加參數,備份單表
    --master-data=2:備份的時候打位置點
                  1:不加註釋
                  0:關閉
    --single-transaction:快照備份,(熱備)
    -R:備份函數,和存儲過程
    --triggers:備份觸發器
    
    冷備:停服務備份
    熱備:不中止服務備份,也不阻塞寫入數據
    溫備:不中止服務備份,可是阻塞寫入數據
    
    mysqldump -uroot -p1 -A -R --triggers --master-data=2 --single-transaction |gzip > /tmp/$(date +%F)_full.sql.gz

配置服務

咱們能夠Linux系統下安裝和配置各類服務,也就是說咱們能夠把Linux系統打形成數據庫服務器、Web服務器、緩存服務器、文件服務器、消息隊列服務器等等。Linux下的大多數服務都被設置爲守護進程(駐留在系統後臺運行,但不會由於服務還在運行而致使Linux沒法中止運行),因此咱們安裝的服務一般名字後面都有一個字母d,它是英文單詞daemon的縮寫,例如:防火牆服務叫firewalld,咱們以前安裝的MySQL服務叫mysqld,Apache服務器叫httpd等。在安裝好服務以後,可使用systemctl命令或service命令來完成對服務的啓動、中止等操做,具體操做以下所示。

  1. 啓動防火牆服務。

    [root ~]# systemctl start firewalld
  2. 終止防火牆服務。

    [root ~]# systemctl stop firewalld
  3. 重啓防火牆服務。

    [root ~]# systemctl restart firewalld
  4. 查看防火牆服務狀態。

    [root ~]# systemctl status firewalld
  5. 設置/禁用防火牆服務開機自啓。

    [root ~]# systemctl enable firewalld
    Created symlink from /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service to /usr/lib/systemd/system/firewalld.service.
    Created symlink from /etc/systemd/system/multi-user.target.wants/firewalld.service to /usr/lib/systemd/system/firewalld.service.
    [root ~]# systemctl disable firewalld
    Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
    Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

計劃任務

  1. 在指定的時間執行命令

    • at - 將任務排隊,在指定的時間執行。
    • atq - 查看待執行的任務隊列。
    • atrm - 從隊列中刪除待執行的任務。

    指定3天之後下午5點要執行的任務。

    [root ~]# at 5pm+3days
    at> rm -f /root/*.html
    at> <EOT>
    job 9 at Wed Jun  5 17:00:00 2019

    查看待執行的任務隊列。

    [root ~]# atq
    9       Wed Jun  5 17:00:00 2019 a root

    從隊列中刪除指定的任務。

    [root ~]$ atrm 9
  2. 計劃任務表 - crontab

    [root ~]# crontab -e
    * * * * * echo "hello, world!" >> /root/hello.txt
    59 23 * * * rm -f /root/*.log

    說明:輸入crontab -e命令會打開vim來編輯Cron表達式並指定觸發的任務,上面咱們定製了兩個計劃任務,一個是每分鐘向/root目錄下的hello.txt中追加輸出hello, world!;另外一個是天天23時59分執行刪除/root目錄下以log爲後綴名的文件。若是不知道Cron表達式如何書寫,能夠參照/etc/crontab文件中的提示(下面會講到)或者用搜索引擎找一下「Cron表達式在線生成器」來生成Cron表達式。

    和crontab相關的文件在/etc目錄下,經過修改/etc目錄下的crontab文件也可以定製計劃任務。

    [root ~]# cd /etc
    [root etc]# ls -l | grep cron
    -rw-------.  1 root root      541 Aug  3  2017 anacrontab
    drwxr-xr-x.  2 root root     4096 Mar 27 11:56 cron.d
    drwxr-xr-x.  2 root root     4096 Mar 27 11:51 cron.daily
    -rw-------.  1 root root        0 Aug  3  2017 cron.deny
    drwxr-xr-x.  2 root root     4096 Mar 27 11:50 cron.hourly
    drwxr-xr-x.  2 root root     4096 Jun 10  2014 cron.monthly
    -rw-r--r--   1 root root      493 Jun 23 15:09 crontab
    drwxr-xr-x.  2 root root     4096 Jun 10  2014 cron.weekly
    [root etc]# vim crontab
      1 SHELL=/bin/bash
      2 PATH=/sbin:/bin:/usr/sbin:/usr/bin
      3 MAILTO=root
      4
      5 # For details see man 4 crontabs
      6
      7 # Example of job definition:
      8 # .---------------- minute (0 - 59)
      9 # |  .------------- hour (0 - 23)
     10 # |  |  .---------- day of month (1 - 31)
     11 # |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
     12 # |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
     13 # |  |  |  |  |
     14 # *  *  *  *  * user-name  command to be executed

網絡訪問和管理

  1. 安全遠程鏈接 - ssh

    [root ~]$ ssh root@120.77.222.217
    The authenticity of host '120.77.222.217 (120.77.222.217)' can't be established.
    ECDSA key fingerprint is SHA256:BhUhykv+FvnIL03I9cLRpWpaCxI91m9n7zBWrcXRa8w.
    ECDSA key fingerprint is MD5:cc:85:e9:f0:d7:07:1a:26:41:92:77:6b:7f:a0:92:65.
    Are you sure you want to continue connecting (yes/no)? yes
    Warning: Permanently added '120.77.222.217' (ECDSA) to the list of known hosts.
    root@120.77.222.217's password: 
  2. 經過網絡獲取資源 - wget

    • -b 後臺下載模式
    • -O 下載到指定的目錄
    • -r 遞歸下載
  3. 發送和接收郵件 - mail

  4. 網絡配置工具(舊) - ifconfig

    [root ~]# ifconfig eth0
    eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 172.18.61.250  netmask 255.255.240.0  broadcast 172.18.63.255
            ether 00:16:3e:02:b6:46  txqueuelen 1000  (Ethernet)
            RX packets 1067841  bytes 1296732947 (1.2 GiB)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 409912  bytes 43569163 (41.5 MiB)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 
  5. 網絡配置工具(新) - ip

    [root ~]# ip address
    1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1
        link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
        inet 127.0.0.1/8 scope host lo
           valid_lft forever preferred_lft forever
    2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
        link/ether 00:16:3e:02:b6:46 brd ff:ff:ff:ff:ff:ff
        inet 172.18.61.250/20 brd 172.18.63.255 scope global eth0
           valid_lft forever preferred_lft forever
  6. 網絡可達性檢查 - ping

    [root ~]# ping www.baidu.com -c 3
    PING www.a.shifen.com (220.181.111.188) 56(84) bytes of data.
    64 bytes from 220.181.111.188 (220.181.111.188): icmp_seq=1 ttl=51 time=36.3 ms
    64 bytes from 220.181.111.188 (220.181.111.188): icmp_seq=2 ttl=51 time=36.4 ms
    64 bytes from 220.181.111.188 (220.181.111.188): icmp_seq=3 ttl=51 time=36.4 ms
    --- www.a.shifen.com ping statistics ---
    3 packets transmitted, 3 received, 0% packet loss, time 2002ms
    rtt min/avg/max/mdev = 36.392/36.406/36.427/0.156 ms
  7. 顯示或管理路由表 - route

  8. 查看網絡服務和端口 - netstat / ss

    [root ~]# netstat -nap | grep nginx
  9. 網絡監聽抓包 - tcpdump

  10. 安全文件拷貝 - scp

[root ~]# scp root@1.2.3.4:/root/guido.jpg hellokitty@4.3.2.1:/home/hellokitty/pic.jpg
  1. 文件同步工具 - rsync

    說明:使用rsync能夠實現文件的自動同步,這個對於文件服務器來講至關重要。關於這個命令的用法,咱們在後面講項目部署的時候爲你們詳細說明。

  2. 安全文件傳輸 - sftp

    [root ~]# sftp root@1.2.3.4
    root@1.2.3.4's password:
    Connected to 1.2.3.4.
    sftp>
    • help:顯示幫助信息。

    • ls/lls:顯示遠端/本地目錄列表。

    • cd/lcd:切換遠端/本地路徑。

    • mkdir/lmkdir:建立遠端/本地目錄。

    • pwd/lpwd:顯示遠端/本地當前工做目錄。

    • get:下載文件。

    • put:上傳文件。

    • rm:刪除遠端文件。

    • bye/exit/quit:退出sftp。

進程管理

  1. 查看進程 - ps

    [root ~]# ps -ef
    UID        PID  PPID  C STIME TTY          TIME CMD
    root         1     0  0 Jun23 ?        00:00:05 /usr/lib/systemd/systemd --switched-root --system --deserialize 21
    root         2     0  0 Jun23 ?        00:00:00 [kthreadd]
    ...
    [root ~]# ps -ef | grep mysqld
    root      4943  4581  0 22:45 pts/0    00:00:00 grep --color=auto mysqld
    mysql    25257     1  0 Jun25 ?        00:00:39 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid
  2. 顯示進程狀態樹 - pstree

    [root ~]# pstree
    systemd─┬─AliYunDun───18*[{AliYunDun}]
            ├─AliYunDunUpdate───3*[{AliYunDunUpdate}]
            ├─2*[agetty]
            ├─aliyun-service───2*[{aliyun-service}]
            ├─atd
            ├─auditd───{auditd}
            ├─dbus-daemon
            ├─dhclient
            ├─irqbalance
            ├─lvmetad
            ├─mysqld───28*[{mysqld}]
            ├─nginx───2*[nginx]
            ├─ntpd
            ├─polkitd───6*[{polkitd}]
            ├─rsyslogd───2*[{rsyslogd}]
            ├─sshd───sshd───bash───pstree
            ├─systemd-journal
            ├─systemd-logind
            ├─systemd-udevd
            └─tuned───4*[{tuned}]
  3. 查找與指定條件匹配的進程 - pgrep

    [root ~]$ pgrep mysqld
    3584
  4. 經過進程號終止進程 - kill

    [root ~]$ kill -l
     1) SIGHUP       2) SIGINT       3) SIGQUIT      4) SIGILL       5) SIGTRAP
     6) SIGABRT      7) SIGBUS       8) SIGFPE       9) SIGKILL     10) SIGUSR1
    11) SIGSEGV     12) SIGUSR2     13) SIGPIPE     14) SIGALRM     15) SIGTERM
    16) SIGSTKFLT   17) SIGCHLD     18) SIGCONT     19) SIGSTOP     20) SIGTSTP
    21) SIGTTIN     22) SIGTTOU     23) SIGURG      24) SIGXCPU     25) SIGXFSZ
    26) SIGVTALRM   27) SIGPROF     28) SIGWINCH    29) SIGIO       30) SIGPWR
    31) SIGSYS      34) SIGRTMIN    35) SIGRTMIN+1  36) SIGRTMIN+2  37) SIGRTMIN+3
    38) SIGRTMIN+4  39) SIGRTMIN+5  40) SIGRTMIN+6  41) SIGRTMIN+7  42) SIGRTMIN+8
    43) SIGRTMIN+9  44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
    48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12
    53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9  56) SIGRTMAX-8  57) SIGRTMAX-7
    58) SIGRTMAX-6  59) SIGRTMAX-5  60) SIGRTMAX-4  61) SIGRTMAX-3  62) SIGRTMAX-2
    63) SIGRTMAX-1  64) SIGRTMAX
    [root ~]# kill 1234
    [root ~]# kill -9 1234

    例子:用一條命令強制終止正在運行的Redis進程。

    ps -ef | grep redis | grep -v grep | awk '{print $2}' | xargs kill
  5. 經過進程名終止進程 - killall / pkill

    結束名爲mysqld的進程。

    [root ~]# pkill mysqld

    結束hellokitty用戶的全部進程。

    [root ~]# pkill -u hellokitty

    說明:這樣的操做會讓hellokitty用戶和服務器斷開鏈接。

  6. 將進程置於後臺運行。

    • Ctrl+Z - 快捷鍵,用於中止進程並置於後臺。
    • & - 將進程置於後臺運行。
    [root ~]# mongod &
    [root ~]# redis-server
    ...
    ^Z
    [4]+  Stopped                 redis-server
  7. 查詢後臺進程 - jobs

    [root ~]# jobs
    [2]   Running                 mongod &
    [3]-  Stopped                 cat
    [4]+  Stopped                 redis-server
  8. 讓進程在後臺繼續運行 - bg

    [root ~]# bg %4
    [4]+ redis-server &
    [root ~]# jobs
    [2]   Running                 mongod &
    [3]+  Stopped                 cat
    [4]-  Running                 redis-server &
  9. 將後臺進程置於前臺 - fg

    [root ~]# fg %4
    redis-server

    說明:置於前臺的進程可使用Ctrl+C來終止它。

  10. 調整程序/進程運行時優先級 - nice / renice

  11. 用戶登出後進程繼續工做 - nohup

    [root ~]# nohup ping www.baidu.com > result.txt &
  12. 跟蹤進程系統調用狀況 - strace

    [root ~]# pgrep mysqld
    8803
    [root ~]# strace -c -p 8803
    strace: Process 8803 attached
    ^Cstrace: Process 8803 detached
    % time     seconds  usecs/call     calls    errors syscall
    ------ ----------- ----------- --------- --------- ----------------
     99.18    0.005719        5719         1           restart_syscall
      0.49    0.000028          28         1           mprotect
      0.24    0.000014          14         1           clone
      0.05    0.000003           3         1           mmap
      0.03    0.000002           2         1           accept
    ------ ----------- ----------- --------- --------- ----------------
    100.00    0.005766                     5           total

    說明:這個命令的用法和參數都比較複雜,建議你們在真正用到這個命令的時候再根據實際須要進行了解。

  13. 查看當前運行級別 - runlevel

    [root ~]# runlevel
    N 3
  14. 實時監控進程佔用資源情況 - top

    [root ~]# top
    top - 23:04:23 up 3 days, 14:10,  1 user,  load average: 0.00, 0.01, 0.05
    Tasks:  65 total,   1 running,  64 sleeping,   0 stopped,   0 zombie
    %Cpu(s):  0.3 us,  0.3 sy,  0.0 ni, 99.3 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
    KiB Mem :  1016168 total,   191060 free,   324700 used,   500408 buff/cache
    KiB Swap:        0 total,        0 free,        0 used.   530944 avail Mem
    ...
    • -c - 顯示進程的整個路徑。
    • -d - 指定兩次刷屏之間的間隔時間(秒爲單位)。
    • -i - 不顯示閒置進程或殭屍進程。
    • -p - 顯示指定進程的信息。

系統診斷

  1. 系統啓動異常診斷 - dmesg

  2. 查看系統活動信息 - sar

    [root ~]# sar -u -r 5 10
    Linux 3.10.0-957.10.1.el7.x86_64 (izwz97tbgo9lkabnat2lo8z)      06/02/2019      _x86_64_        (2 CPU)
    
    06:48:30 PM     CPU     %user     %nice   %system   %iowait    %steal     %idle
    06:48:35 PM     all      0.10      0.00      0.10      0.00      0.00     99.80
    
    06:48:30 PM kbmemfree kbmemused  %memused kbbuffers  kbcached  kbcommit   %commit  kbactive   kbinact   kbdirty
    06:48:35 PM   1772012   2108392     54.33    102816   1634528    784940     20.23    793328   1164704         0
    • -A - 顯示全部設備(CPU、內存、磁盤)的運行情況。
    • -u - 顯示全部CPU的負載狀況。
    • -d - 顯示全部磁盤的使用狀況。
    • -r - 顯示內存的使用狀況。
    • -n - 顯示網絡運行狀態。
  3. 查看內存使用狀況 - free

    [root ~]# free
                  total        used        free      shared  buff/cache   available
    Mem:        1016168      323924      190452         356      501792      531800
    Swap:             0           0           0
  4. 虛擬內存統計 - vmstat

    [root ~]# vmstat
    procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
     r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
     2  0      0 204020  79036 667532    0    0     5    18  101   58  1  0 99  0  0
  5. CPU信息統計 - mpstat

    [root ~]# mpstat
    Linux 3.10.0-957.5.1.el7.x86_64 (iZ8vba0s66jjlfmo601w4xZ)       05/30/2019      _x86_64_        (1 CPU)
    
    01:51:54 AM  CPU    %usr   %nice    %sys %iowait    %irq   %soft  %steal  %guest  %gnice   %idle
    01:51:54 AM  all    0.71    0.00    0.17    0.04    0.00    0.00    0.00    0.00    0.00   99.07
  6. 查看進程使用內存情況 - pmap

    [root ~]# ps
      PID TTY          TIME CMD
     4581 pts/0    00:00:00 bash
     5664 pts/0    00:00:00 ps
    [root ~]# pmap 4581
    4581:   -bash
    0000000000400000    884K r-x-- bash
    00000000006dc000      4K r---- bash
    00000000006dd000     36K rw--- bash
    00000000006e6000     24K rw---   [ anon ]
    0000000001de0000    400K rw---   [ anon ]
    00007f82fe805000     48K r-x-- libnss_files-2.17.so
    00007f82fe811000   2044K ----- libnss_files-2.17.so
    ...
  7. 報告設備CPU和I/O統計信息 - iostat

    [root ~]# iostat
    Linux 3.10.0-693.11.1.el7.x86_64 (iZwz97tbgo9lkabnat2lo8Z)      06/26/2018      _x86_64_       (1 CPU)
    avg-cpu:  %user   %nice %system %iowait  %steal   %idle
               0.79    0.00    0.20    0.04    0.00   98.97
    Device:            tps    kB_read/s    kB_wrtn/s    kB_read    kB_wrtn
    vda               0.85         6.78        21.32    2106565    6623024
    vdb               0.00         0.01         0.00       2088          0
  8. 顯示全部PCI設備 - lspci

    [root ~]# lspci
    00:00.0 Host bridge: Intel Corporation 440FX - 82441FX PMC [Natoma] (rev 02)
    00:01.0 ISA bridge: Intel Corporation 82371SB PIIX3 ISA [Natoma/Triton II]
    00:01.1 IDE interface: Intel Corporation 82371SB PIIX3 IDE [Natoma/Triton II]
    00:01.2 USB controller: Intel Corporation 82371SB PIIX3 USB [Natoma/Triton II] (rev 01)
    00:01.3 Bridge: Intel Corporation 82371AB/EB/MB PIIX4 ACPI (rev 03)
    00:02.0 VGA compatible controller: Cirrus Logic GD 5446
    00:03.0 Ethernet controller: Red Hat, Inc. Virtio network device
    00:04.0 Communication controller: Red Hat, Inc. Virtio console
    00:05.0 SCSI storage controller: Red Hat, Inc. Virtio block device
    00:06.0 SCSI storage controller: Red Hat, Inc. Virtio block device
    00:07.0 Unclassified device [00ff]: Red Hat, Inc. Virtio memory balloon
  9. 顯示進程間通訊設施的狀態 - ipcs

    [root ~]# ipcs
    
    ------ Message Queues --------
    key        msqid      owner      perms      used-bytes   messages    
    
    ------ Shared Memory Segments --------
    key        shmid      owner      perms      bytes      nattch     status      
    
    ------ Semaphore Arrays --------
    key        semid      owner      perms      nsems

相關資源

  1. Linux命令行經常使用快捷鍵

    快捷鍵 功能說明
    tab 自動補全命令或路徑
    Ctrl+a 將光標移動到命令行行首
    Ctrl+e 將光標移動到命令行行尾
    Ctrl+f 將光標向右移動一個字符
    Ctrl+b 將光標向左移動一個字符
    Ctrl+k 剪切從光標到行尾的字符
    Ctrl+u 剪切從光標到行首的字符
    Ctrl+w 剪切光標前面的一個單詞
    Ctrl+y 複製剪切命名剪切的內容
    Ctrl+c 中斷正在執行的任務
    Ctrl+h 刪除光標前面的一個字符
    Ctrl+d 退出當前命令行
    Ctrl+r 搜索歷史命令
    Ctrl+g 退出歷史命令搜索
    Ctrl+l 清除屏幕上全部內容在屏幕的最上方開啓一個新行
    Ctrl+s 鎖定終端使之暫時沒法輸入內容
    Ctrl+q 退出終端鎖定
    Ctrl+z 將正在終端執行的任務停下來放到後臺
    !! 執行上一條命令
    !數字 執行數字對應的歷史命令
    !字母 執行最近的以字母打頭的命令
    !$ / Esc+. 得到上一條命令最後一個參數
    Esc+b 移動到當前單詞的開頭
    Esc+f 移動到當前單詞的結尾
  2. man查閱命令手冊的內容說明

    手冊中的標題 功能說明
    NAME 命令的說明和介紹
    SYNOPSIS 使用該命令的基本語法
    DESCRIPTION 使用該命令的詳細描述,各個參數的做用,有時候這些信息會出如今OPTIONS中
    OPTIONS 命令相關參數選項的說明
    EXAMPLES 使用該命令的參考例子
    EXIT STATUS 命令結束的退出狀態碼,一般0表示成功執行
    SEE ALSO 和命令相關的其餘命令或信息
    BUGS 和命令相關的缺陷的描述
    AUTHOR 該命令的做者介紹
[root ~]# pip3 --version
相關文章
相關標籤/搜索