日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

??

Linux其實是前后端都必會的技能,前端目前很多童鞋都再走大前端路線,后端就更不用說了,小編給大家盤了上萬字(由于字數限制本文已刪減)關于Linux的實戰基礎命令,可以說這些都是必須掌握的,當然這些也是不夠的,后面小編還會繼續更新,大家可以關注我的動態,盤起來,這波可以收藏起來了。

??


ls

最高使用頻率的命令之一。

命令格式: ?ls [OPTION]… [FILE]… 單純的輸入:

[root@iz2ze76ybn73dvwmdij06zz /]# lsbin   dev  home  lib64       media  opt    proc  run   srv  tmp  varboot  etc  lib   lost+found  mnt    patch  root  sbin  sys  usr  www

登錄后復制

加 option -l 它展示了權限,屬主,屬組,大小,時間,文件名稱
[root@iz2ze76ybn73dvwmdij06zz /]# ls -l總用量 68lrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/bindr-xr-xr-x.   5 root root  4096 8月  26 22:39 bootdrwxr-xr-x   19 root root  2960 4月  11 12:59 devdrwxr-xr-x.  81 root root  4096 9月   5 17:09 etcdrwxr-xr-x.   2 root root  4096 4月  11 12:59 homelrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/liblrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64drwx------.   2 root root 16384 10月 15 2017 lost+founddrwxr-xr-x.   2 root root  4096 4月  11 12:59 mediadrwxr-xr-x.   2 root root  4096 4月  11 12:59 mntdrwxr-xr-x.   3 root root  4096 8月  26 22:40 optdrwxr-xr-x    2 root root  4096 8月  26 23:00 patchdr-xr-xr-x  110 root root     0 4月  11 12:59 procdr-xr-x---.  12 root root  4096 9月  11 20:59 rootdrwxr-xr-x   26 root root   760 9月   7 21:50 runlrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbindrwxr-xr-x.   2 root root  4096 4月  11 12:59 srvdr-xr-xr-x   13 root root     0 4月  11 12:59 sysdrwxrwxrwt.   9 root root  4096 9月  15 03:19 tmpdrwxr-xr-x.  13 root root  4096 8月  26 22:36 usrdrwxr-xr-x.  19 root root  4096 8月  26 22:55 vardrwxr-xr-x    6 root root  4096 8月  26 22:39 www

登錄后復制

ls -a (all) linux '.'(點)開頭的文件默認是隱藏的,-a可以查詢所有的文件。
[root@iz2ze76ybn73dvwmdij06zz /]# ls -a.             bin   etc   lib64       mnt    .pearrc  run   sys    usr..            boot  home  lost+found  opt    proc     sbin  .test  var.autorelabel  dev   lib   media       patch  root     srv   tmp    www

登錄后復制

ls -F 以"/"結尾的方式展示文件夾。
[root@iz2ze76ybn73dvwmdij06zz /]# ls -Fbin@   dev/  home/  lib64@       media/  opt/    proc/  run/   srv/  tmp/  var/boot/  etc/  lib@   lost+found/  mnt/    patch/  root/  sbin@  sys/  usr/  www/

登錄后復制

ls -r 倒敘展示,默認的順序是(a,b,c,d)正序這樣展示
[root@iz2ze76ybn73dvwmdij06zz /]# ls -rwww  usr  sys  sbin  root  patch  mnt    lost+found  lib   etc  bootvar  tmp  srv  run   proc  opt    media  lib64       home  dev  bin

登錄后復制

ls -R ()遞歸展示子目錄
[root@iz2ze76ybn73dvwmdij06zz test]# ls -R.:data./data:img./data/img:car  product  user./data/img/car:./data/img/product:./data/img/user:

登錄后復制

ls -lS 按照文件大小降序顯示
[root@iz2ze76ybn73dvwmdij06zz /]# ls -lS總用量 72drwx------.   2 root root 16384 10月 15 2017 lost+founddr-xr-xr-x.   5 root root  4096 8月  26 22:39 bootdrwxr-xr-x.  81 root root  4096 9月   5 17:09 etcdrwxr-xr-x.   2 root root  4096 4月  11 12:59 homedrwxr-xr-x.   2 root root  4096 4月  11 12:59 mediadrwxr-xr-x.   2 root root  4096 4月  11 12:59 mntdrwxr-xr-x.   3 root root  4096 8月  26 22:40 optdrwxr-xr-x    2 root root  4096 8月  26 23:00 patchdr-xr-x---.  12 root root  4096 9月  15 22:03 rootdrwxr-xr-x.   2 root root  4096 4月  11 12:59 srvdrwxr-xr-x    3 root root  4096 9月  15 22:10 testdrwxrwxrwt.   9 root root  4096 9月  15 03:19 tmpdrwxr-xr-x.  13 root root  4096 8月  26 22:36 usrdrwxr-xr-x.  19 root root  4096 8月  26 22:55 vardrwxr-xr-x    6 root root  4096 8月  26 22:39 wwwdrwxr-xr-x   19 root root  2960 4月  11 12:59 devdrwxr-xr-x   26 root root   760 9月   7 21:50 runlrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64lrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbinlrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/binlrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/libdr-xr-xr-x  110 root root     0 4月  11 12:59 procdr-xr-xr-x   13 root root     0 4月  11 12:59 sys

登錄后復制

ls -g 不輸出所有者(屬主)信息
[root@iz2ze76ybn73dvwmdij06zz /]# ls -g總用量 72lrwxrwxrwx    1 root     7 8月  26 22:36 bin -> usr/bindr-xr-xr-x.   5 root  4096 8月  26 22:39 boot-rw-r--r--    1 root     0 9月  15 22:20 cdrwxr-xr-x   19 root  2960 4月  11 12:59 devdrwxr-xr-x.  81 root  4096 9月   5 17:09 etcdrwxr-xr-x.   2 root  4096 4月  11 12:59 homelrwxrwxrwx    1 root     7 8月  26 22:36 lib -> usr/liblrwxrwxrwx    1 root     9 8月  26 22:36 lib64 -> usr/lib64drwx------.   2 root 16384 10月 15 2017 lost+founddrwxr-xr-x.   2 root  4096 4月  11 12:59 mediadrwxr-xr-x.   2 root  4096 4月  11 12:59 mntdrwxr-xr-x.   3 root  4096 8月  26 22:40 optdrwxr-xr-x    2 root  4096 8月  26 23:00 patchdr-xr-xr-x  110 root     0 4月  11 12:59 procdr-xr-x---.  12 root  4096 9月  15 22:18 rootdrwxr-xr-x   26 root   760 9月   7 21:50 runlrwxrwxrwx    1 root     8 8月  26 22:36 sbin -> usr/sbindrwxr-xr-x.   2 root  4096 4月  11 12:59 srvdr-xr-xr-x   13 root     0 4月  11 12:59 sysdrwxr-xr-x    3 root  4096 9月  15 22:18 testdrwxrwxrwt.   9 root  4096 9月  15 03:19 tmpdrwxr-xr-x.  13 root  4096 8月  26 22:36 usrdrwxr-xr-x.  19 root  4096 8月  26 22:55 vardrwxr-xr-x    6 root  4096 8月  26 22:39 www

登錄后復制

ls -lG 隱藏所有組(屬組)信息
[root@iz2ze76ybn73dvwmdij06zz /]# ls -lG總用量 72lrwxrwxrwx    1 root     7 8月  26 22:36 bin -> usr/bindr-xr-xr-x.   5 root  4096 8月  26 22:39 boot-rw-r--r--    1 root     0 9月  15 22:20 cdrwxr-xr-x   19 root  2960 4月  11 12:59 devdrwxr-xr-x.  81 root  4096 9月   5 17:09 etcdrwxr-xr-x.   2 root  4096 4月  11 12:59 homelrwxrwxrwx    1 root     7 8月  26 22:36 lib -> usr/liblrwxrwxrwx    1 root     9 8月  26 22:36 lib64 -> usr/lib64drwx------.   2 root 16384 10月 15 2017 lost+founddrwxr-xr-x.   2 root  4096 4月  11 12:59 mediadrwxr-xr-x.   2 root  4096 4月  11 12:59 mntdrwxr-xr-x.   3 root  4096 8月  26 22:40 optdrwxr-xr-x    2 root  4096 8月  26 23:00 patchdr-xr-xr-x  110 root     0 4月  11 12:59 procdr-xr-x---.  12 root  4096 9月  15 22:18 rootdrwxr-xr-x   26 root   760 9月   7 21:50 runlrwxrwxrwx    1 root     8 8月  26 22:36 sbin -> usr/sbindrwxr-xr-x.   2 root  4096 4月  11 12:59 srvdr-xr-xr-x   13 root     0 4月  11 12:59 sysdrwxr-xr-x    3 root  4096 9月  15 22:18 testdrwxrwxrwt.   9 root  4096 9月  15 03:19 tmpdrwxr-xr-x.  13 root  4096 8月  26 22:36 usrdrwxr-xr-x.  19 root  4096 8月  26 22:55 vardrwxr-xr-x    6 root  4096 8月  26 22:39 www10.ls -li 顯示文件的索引號[root@iz2ze76ybn73dvwmdij06zz /]# ls -li

登錄后復制

ls -li 顯示文件的索引號
[root@iz2ze76ybn73dvwmdij06zz /]# ls -li總用量 72  7628 lrwxrwxrwx    1 root root     7 8月  26 22:36 bin -> usr/bin1179650 dr-xr-xr-x.   5 root root  4096 8月  26 22:39 boot  4923 -rw-r--r--    1 root root     0 9月  15 22:20 c  1026 drwxr-xr-x   19 root root  2960 4月  11 12:59 dev917505 drwxr-xr-x.  81 root root  4096 9月   5 17:09 etc655362 drwxr-xr-x.   2 root root  4096 4月  11 12:59 home    17 lrwxrwxrwx    1 root root     7 8月  26 22:36 lib -> usr/lib    13 lrwxrwxrwx    1 root root     9 8月  26 22:36 lib64 -> usr/lib64    11 drwx------.   2 root root 16384 10月 15 2017 lost+found786434 drwxr-xr-x.   2 root root  4096 4月  11 12:59 media131074 drwxr-xr-x.   2 root root  4096 4月  11 12:59 mnt393219 drwxr-xr-x.   3 root root  4096 8月  26 22:40 opt1966081 drwxr-xr-x    2 root root  4096 8月  26 23:00 patch     1 dr-xr-xr-x  110 root root     0 4月  11 12:59 proc131073 dr-xr-x---.  12 root root  4096 9月  15 22:18 root   218 drwxr-xr-x   26 root root   760 9月   7 21:50 run    15 lrwxrwxrwx    1 root root     8 8月  26 22:36 sbin -> usr/sbin393220 drwxr-xr-x.   2 root root  4096 4月  11 12:59 srv     1 dr-xr-xr-x   13 root root     0 4月  11 12:59 sys2097153 drwxr-xr-x    3 root root  4096 9月  15 22:18 test393217 drwxrwxrwt.   9 root root  4096 9月  15 03:19 tmp1048578 drwxr-xr-x.  13 root root  4096 8月  26 22:36 usr262145 drwxr-xr-x.  19 root root  4096 8月  26 22:55 var1441793 drwxr-xr-x    6 root root  4096 8月  26 22:39 www

登錄后復制

ls -lt 按照修改時間排序(倒序)依次創建文件 a b
[root@iz2ze76ybn73dvwmdij06zz test]# ls -lt總用量 0-rw-r--r-- 1 root root 0 9月  15 22:18 b-rw-r--r-- 1 root root 0 9月  15 22:18 a

登錄后復制

ls -version
[root@iz2ze76ybn73dvwmdij06zz test]# ls --versionls (GNU coreutils) 8.22Copyright (C) 2013 Free Software Foundation, Inc.許可證:GPLv3+:GNU 通用公共許可證第3 版或更新版本<http://gnu.org/licenses/gpl.html>。本軟件是自由軟件:您可以自由修改和重新發布它。在法律范圍內沒有其他保證。由Richard M. Stallman 和David MacKenzie 編寫。

登錄后復制

cat

cat,又是一個相對高頻率的命令。比較官方的說法是命令用于鏈接文件并打印到標準輸出設備上。這個文本輸出命令可以用來查看文件內容,創建內容等,下面我們介紹幾個比較實用的用法。命令格式 : cat [選項]… [文件]…

cat -n 查看并顯示行號
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat -n a    1  this is a txt    2  hello every body    3  hello world    4  hahaha

登錄后復制

cat 創建一個空文件 b
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >b <<EOF> EOF[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# lsa  b

登錄后復制

cat 清空文件內容
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >a<<EOF> EOF[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a

登錄后復制

cat 寫入內容(如果原來有內容將被覆蓋)
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat >a<<EOF> today is a good day> because off work> hahaha> EOF[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat atoday is a good daybecause off workhahaha

登錄后復制

cat 同時顯示多個文件內容( b中寫出happy)
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a > b[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat btoday is a good daybecause off workhahaha

登錄后復制

追加內容 可以看到用了連個>以后內容是追加的
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat a >> b[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat btoday is a good daybecause off workhahahatoday is a good daybecause off workhahaha

登錄后復制

cat –help (如想學習更多,可以自己動手嘗試)
[root@iz2ze76ybn73dvwmdij06zz linuxdemo]# cat --help用法:cat [選項]... [文件]...將[文件]或標準輸入組合輸出到標準輸出。 -A, --show-all           等于-vET -b, --number-nonblank    對非空輸出行編號 -e                       等于-vE -E, --show-ends          在每行結束處顯示"$" -n, --number             對輸出的所有行編號 -s, --squeeze-blank      不輸出多行空行 -t                       與-vT 等價 -T, --show-tabs          將跳格字符顯示為^I -u                       (被忽略) -v, --show-nonprinting   使用^ 和M- 引用,除了LFD和 TAB 之外     --help    顯示此幫助信息并退出     --version    顯示版本信息并退出如果沒有指定文件,或者文件為"-",則從標準輸入讀取。示例: cat f - g  先輸出f 的內容,然后輸出標準輸入的內容,最后輸出g 的內容。 cat        將標準輸入的內容復制到標準輸出。GNU coreutils online help: <http://www.gnu.org/software/coreutils/>請向<http://translationproject.org/team/zh_CN.html> 報告cat 的翻譯錯誤要獲取完整文檔,請運行:info coreutils 'cat invocation'

登錄后復制


用戶權限

大家都知道linux是一個多任務,多用戶的操作系統。多個用戶可以在同一時間操作系統執行不同的任務,一個用戶也可以多個人登陸操作。一般來說root的權限最大,我們經常使用的數據庫一般會用一個mysql的用戶,網頁相關的我們可能用一個www的賬號,大家都是知道刪除跑路的故事,因此有一些操作權限是要交給一些專人管理的。為了系統的學習,我覺得有必要了解一下它的基本知識。

linux角色分類

超級用戶:root (user id –UID) 0 最高的管理權限。

普通用戶:

    系統用戶 UID:1-999(rhel7  centos7) 1-499(rhel6)        本地用戶 UID:1000+(rhel7 centos7)  500+(rhel6)

登錄后復制

UID:用戶身份標示,唯一標示。

linux組分類

組:

組分類:

根據賬號的功能分類:           超級用戶組:root GID:0           普通用戶組 :                               系統用戶組: GID 1---999                                本地用戶組: GID 1000+

登錄后復制

linux用戶和組的關系

一個用戶屬于一個組,也可以屬于多個組,多個用戶可以在一個組,可以在多個組。

linux用戶和組的相關配置文件

1./etc/passwd:用戶 and 屬性信息。

2./etc/group: 組 and 屬性信息。

3./etc/shadow: 用戶密碼 and 屬性信息。

4./etc/gshadow:組密碼 and 屬性信息。

5./etc/default/useradd: 設置添加用戶規則文件。

6./etc/login.defs:設置用戶賬號限制。

linux用戶信息文件

用戶管理中最重要的一個文件,這個文件是對所有用戶開放的,每一行存一個用戶的信息,每個屬性之間用冒號分割。

cat /etc/passwdroot:x:0:0:root:/root:/bin/zshbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

登錄后復制

舉例: root:x:0:0:root:/root:/bin/zsh

1.登陸用戶名:root

2.用戶密碼占位符:x

3.用戶UID:0

4.用戶組GID:0

5.對用戶賬戶的描述:root

6.用戶家目錄位置:/root

7.用戶默認的shell:/bin/zsh (默認是/bin/bash)

linux密碼信息文件

該文件只有root用戶有讀權限,每一行存一個用戶的記錄,每個屬性用冒號分割。

cat /etc/shadowroot:$6$LxE7qiaZ$ZZXf/aCO1Zqs1oOS9WDutUk9rFOq4MOoSG9IeXq2f5sduGrgfYvzOWHZmJZFGC.0Of1DjCna0M.oQZTY8r00/.:17769:0:99999:7:::bin:*:17110:0:99999:7:::daemon:*:17110:0:99999:7:::

登錄后復制

舉例: bin:*:17110:0:99999:7::: 1.登錄用戶名: bin

2.加密的密碼: * 號代表密碼被鎖定

3.最近更改密碼的日期: 17110代表到1970-1-1密碼不可改的天數

4.密碼修改期限:99999 代表永遠不用改,如果是其他數字則表示從1970-1-1內的多少天必須修改密碼。

5.更改密碼最大有效天數: 代表密碼保持有效的最大天數。

6.密碼過期警告:密碼到正式失效前有多少天(-1,永遠不提示)

7.密碼過期后多少天禁用用戶:可登陸,單不能操作。

8.用戶被禁用日期:多少天后賬號過期,不能登陸。

9.保留參數

linux組信息文件

用戶組的組信息存放在這,一行存一個組記錄,屬性用冒號分割。

?  ~ cat /etc/grouproot:x:0:bin:x:1:daemon:x:2:sys:x:3:adm:x:4:tty:x:5:disk:x:6:lp:x:7:mem:x:8:kmem:x:9:

登錄后復制

舉例: root:x:0:

1.組名:root

2.組密碼占位符: x

3.組GID: 0


安裝包管理基礎

相信大部分人應該和我一樣,最開始都是用 windows上手的,那在windows平臺的安裝包就再熟悉不過了,比如.exe,是不是太常見了,一般在windows安裝過mysql的,相信.msi也是見過的。大多數的服務器都是linux的,因此我們來學習一下linux的安裝包基礎知識。不同發行版的系統用的工具也是不相同的。目前大多數的公司服務器是基于centos,因此后續會以centos為例比較多。

基于redhat

yum

zypper

rpm

基于centos

yum

rpm

rpm

全稱: Redhat Package Manager

下載網址: http://rpmfind.net

先來看下包的命名格式,以 rpm-5.4.10-10.i586.rpm 為例。

rpm : 軟件包名

5 : 主版本號

4 : 次版本號

10 : 修訂號

i586 : cpu架構平臺

rpm : 包后綴

yum

解決軟件包安裝的依賴關系問題,自動下載軟件包,基于c/s架構。repo文件是yum源的配置文件,改文件定義軟件倉庫的信息。為什么說它是c/s架構,原來rpm軟件的頭(header)里會記錄改軟件的依賴信息,因此可以對頭內容進行分析,就可以知道其相關的依賴,并將這些信息記錄下來。那么服務端是提供這些rpm的軟件包,然后分析包的依賴關系,將記錄存在服務器某目錄上。客戶端在安裝軟件時下載其記錄依賴關系文件并分析,最后一次性下載。


進程管理基礎

一般來說程序分為兩類,一種是系統程序,一種是應用程序。一個運行了程序,就可以說是一個進程了,進程是占用內存空間的,而當你殺掉進城時,資源也會隨之釋放。

進程的類型

用戶進程:用戶自己的程序,用戶可以控制他的開啟和關閉。

交互進程: 與用戶進行交互操作的進程。

批處理進程:是一個進程集合,按順序啟動其他進程。

守護進程:一直運行的進程.crond。

進程的屬性

進程ID : (pid) 唯一的數字標示,區分不同的進程。

進程有父進程和子進程。

啟動進程的用戶ID(uid)和用戶的屬組。

進程的三種狀態:

  • 運行 — R

  • 休眠 — S

  • 僵尸 — Z

    進程的優先級: 取值范圍(-20,19) ,數值越小優先級越大,默認為0。

    進程鏈接的終端。

    進程占用資源情況。

    父子進程的關系

    父子進程的關系,父親管理兒子。父進程終止時子進程一定終止,而子進程終止時父進程不一定終止。

    進程管理工具
        ps:   查看進程。    top:  可以查看進程的動態信息。    kill:  殺進程。    pstree:  查看進程樹。    pgrep:  搜進程。    lsof:  查看進程打開的文件。

    登錄后復制


    進程管理實踐

    ps

    靜態的顯示當前進程的信息 。

    命令: ps

    語法: ps 參數

    常用參數:

                   a      顯示所有用戶的進程               r       顯示運行中的進程               l        長格式輸出               u        按用戶名和啟動時間的順序來顯示進程               f         用樹形格式來顯示進程               x        顯示沒有控制終端的進程

    登錄后復制

    操作: BSD格式來顯示進程

    ?  ~ ps auxUSER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMANDroot         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/systroot         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0Hroot         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]root        12  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/1]root        13  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/1]root        15  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/1:0H

    登錄后復制

    標準格式顯示進程unix風格

    搜索公眾號頂級算法回復“算法心得”,送你一份驚喜禮包。

     ~ ps -efUID        PID  PPID  C STIME TTY          TIME CMDroot         1     0  0 11月03 ?      00:00:01 /usr/lib/systemd/systemd --systeroot         2     0  0 11月03 ?      00:00:00 [kthreadd]root         3     2  0 11月03 ?      00:00:00 [ksoftirqd/0]root         5     2  0 11月03 ?      00:00:00 [kworker/0:0H]root         7     2  0 11月03 ?      00:00:00 [migration/0]root         8     2  0 11月03 ?      00:00:00 [rcu_bh]root         9     2  0 11月03 ?      00:00:05 [rcu_sched]root        10     2  0 11月03 ?      00:00:00 [watchdog/0]root        11     2  0 11月03 ?      00:00:00 [watchdog/1]root        12     2  0 11月03 ?      00:00:00 [migration/1]root        13     2  0 11月03 ?      00:00:00 [ksoftirqd/1]root        15     2  0 11月03 ?      00:00:00 [kworker/1:0H]root        17     2  0 11月03 ?      00:00:00 [kdevtmpfs]root        18     2  0 11月03 ?      00:00:00 [netns]root        19     2  0 11月03 ?      00:00:00 [khungtaskd]root        20     2  0 11月03 ?      00:00:00 [writeback]root        21     2  0 11月03 ?      00:00:00 [kintegrityd]

    登錄后復制

    屬性詳解:

    USER: 進程的屬主

    PID: 進程的ID

    %CPU: 進程占cpu百分比

    %MEM: 進程占內存的百分比

    VSZ: 進程占用虛擬內存大小

    RSS: 固定內存使用數量

    STAT 進程狀態

           R    正在運行可中在隊列中可過行的; S    處于休眠狀態;   T    停止或被追蹤;   Z    僵尸進程;   N    優先級較低的進程   L    有些頁被鎖進內存;   s    進程的領導者(在它之下有子進程)

    登錄后復制

    START 啟動進程的時間;

    TIME 進程消耗CPU的時間;

    COMMAND 命令的名稱和參數;

    按照指定屬性排序:

    按照cpu從小到大排序。

    ?  ~ ps aux --sort %cpuUSER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMANDroot         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/systroot         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0Hroot         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]

    登錄后復制

    按照cpu從大到小排序。

    ?  ~ ps aux --sort -%cpuUSER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMANDroot     21342  0.3  0.4 137184 17112 ?        Ssl  03:24   1:16 /usr/local/aegiroot         1  0.0  0.0  43364  3596 ?        Ss   11月03   0:01 /usr/lib/systroot         2  0.0  0.0      0     0 ?        S    11月03   0:00 [kthreadd]root         3  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/0]root         5  0.0  0.0      0     0 ?        S<   11月03   0:00 [kworker/0:0Hroot         7  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/0]root         8  0.0  0.0      0     0 ?        S    11月03   0:00 [rcu_bh]root         9  0.0  0.0      0     0 ?        S    11月03   0:05 [rcu_sched]root        10  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/0]root        11  0.0  0.0      0     0 ?        S    11月03   0:00 [watchdog/1]root        12  0.0  0.0      0     0 ?        S    11月03   0:00 [migration/1]root        13  0.0  0.0      0     0 ?        S    11月03   0:00 [ksoftirqd/1]

    登錄后復制

    top

    與ps相反的是top命令可以查看進程的動態信息。

    命令: top

    語法: top 參數

    常用參數:

    操作:

    ?  ~ toptop - 11:38:42 up 13:15,  2 users,  load average: 0.01, 0.03, 0.05Tasks:  98 total,   1 running,  97 sleeping,   0 stopped,   0 zombie%Cpu(s):  0.2 us,  0.0 sy,  0.0 ni, 99.8 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 stKiB Mem :  3881688 total,   229264 free,   543932 used,  3108492 buff/cacheKiB Swap:  1049596 total,  1049596 free,        0 used.  3026944 avail Mem PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND   1 root      20   0   43364   3596   2340 S   0.0  0.1   0:01.79 systemd   2 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kthreadd   3 root      20   0       0      0      0 S   0.0  0.0   0:00.14 ksoftirqd/0   5 root       0 -20       0      0      0 S   0.0  0.0   0:00.00 kworker/0:+   7 root      rt   0       0      0      0 S   0.0  0.0   0:00.33 migration/0   8 root      20   0       0      0      0 S   0.0  0.0   0:00.00 rcu_bh   9 root      20   0       0      0      0 S   0.0  0.0   0:05.73 rcu_sched

    登錄后復制

    屬性解釋:

    前五行是數據的整理統計信息。

    第一行:

         11:38:42     當前時間           up 13:15     系統運行時間,格式為時:分            2 user         當前登陸用戶數量            load average: 0.01, 0.03, 0.05  系統負載,任務隊列平均長度 1分鐘,5分鐘,15分鐘前到現在的平均值。

    登錄后復制

    第二三行:

    98 total  進程總數量 1 running 正在運行的進程數量 97 sleeping 睡眠的進程數量 0 stopped  停止的進程數量 0 zombie   僵尸進程數量 %Cpu(s): 0.2 us 系統用戶進程使用cpu百分比 0.0 sy 內核進程占用cpu百分比 0.0 ni 用戶進程空間內改變過優先級的進程占用cpu百分比     99.8 id 空閑cpu百分比       0.0 wa 等待輸入輸出的cpu時間百分比       0.0 hi   硬件cpu中斷占用百分比       0.0  si   軟中斷占用百分比       0.0  st  虛擬機占用百分比

    登錄后復制

    第四五行:

    Mem : (單位K)

    3881688 total  物理內存總量229264 free    空閑內存總量543932 used    使用的物理內存總量3108492 buff/cache 內核緩存的內存量

    登錄后復制

    Swap: (單位K)

     1049596 total      交換區總量 1049596 free       空閑交換區總量 0 used             使用的交換區總量 3026944 avail Mem  可利用的內存量

    登錄后復制

    標題行:

    PID: 進程id

    USER: 進程所有者用戶名

    PR: 優先級

    NI: 進程優先級,nice值,負值 -> 高優先級,正值 -> 低優先級

    VIRT: 虛擬內存總量 virt=swap + res

    RES: 實際使用內存大小

    SHR: 共享內存大小

    S: 進程狀態

       d: 不可中斷的睡眠狀態   r: 運行   s: 睡眠   t: 跟蹤   z: 僵尸進程

    登錄后復制

    %CPU: 上次更新到現在cpu時間占用百分比

    %MEM: 進程使用物理內存百分比

    TIME+: 進程使用cpu的時間總計,單位 1/100秒

    COMMAND: 命令行

    kill

    命令: kill

    語法:

          kill [-s signal|-p] [-q sigval] [-a] [--] pid...      kill -l [signal]

    登錄后復制

    常用參數:

         -l 列出所有信號名稱     -s 指定發送信號(默認)     -u 指定用戶

    登錄后復制

    操作: 列出所有信號名稱

    ?  ~ kill -lHUP INT QUIT ILL TRAP ABRT BUS FPE KILL USR1 SEGV USR2 PIPE ALRM TERM STKFLT CHLD CONT STOP TSTP TTIN TTOU URG XCPU XFSZ VTALRM PROF WINCH POLL PWR SYS

    登錄后復制

    強制終止

    ?  ~ kill -9 23423

    登錄后復制

    終止?  ~ kill -15 22323

    登錄后復制

    殺死指定用戶的所有進程

    ?  ~ kill -u superh

    登錄后復制

    proc目錄

    這個目錄中有內核,進程運行狀態的信息。

    ?  /proc ls1      21320  21628  240   392   7          diskstats    loadavg       swaps10     21342  21976  242   42    722        dma          locks         sys10353  21465  21977  243   44    7561       driver       mdstat        sysrq-trigger10509  21613  21978  244   442   8          execdomains  meminfo       sysvipc107    21614  22     249   45    803        fb           misc          timer_list11     21615  220    26    46    8179       filesystems  modules       timer_stats11010  21616  22285  261   466   8307       fs           mounts        tty11102  21617  22287  262   467   8327       interrupts   mtrr          uptime12     21618  22361  267   469   9          iomem        net           version13     21619  22363  268   476   acpi       ioports      pagetypeinfo  vmallocinfo14461  21620  22396  3     477   buddyinfo  irq          partitions    vmstat15     21621  22467  31    485   bus        kallsyms     sched_debug   zoneinfo17     21622  225    3198  5     cgroups    kcore        schedstat18     21623  229    32    505   cmdline    keys         scsi19     21624  23     33    506   consoles   key-users    self2      21625  23884  336   5217  cpuinfo    kmsg         slabinfo20     21626  23885  34    5515  crypto     kpagecount   softirqs21     21627  24     357   65    devices    kpageflags   stat

    登錄后復制

    上面的每個標號即是用我們當前進程的pid所命名的目錄名。

    free

    查看系統使用和空閑的內存情況。

    命令: free

    語法: free 參數

    常用參數:

     -b, --bytes        byte為單位展示 -k, --kilo            k為單位展示 -m, --mega       m為單位展示 -g, --giga           g為單位展示

    登錄后復制

    操作:

    ?  ~ free -m             total        used        free      shared  buff/cache   availableMem:           3790         536         210           2        3043        2950Swap:          1024           0        1024

    登錄后復制

    單位為g顯示。

    ?  ~ free -h            total        used        free      shared  buff/cache   availableMem:           3.7G        538M        207M        2.4M        3.0G        2.9GSwap:          1.0G          0B        1.0G

    登錄后復制

    文件查找

    在做運維相關的事情時,我們少不了要查這樣那樣的文件,一般來說我們可能會查比如帶xxx.conf名字的文件在哪呢,查日志啊,某個可執行文件的位置啊。

    概覽
    which : 查看執行文件的位置。whereis : 查看可執行文件位置和相關文件。locate : 配合數據庫緩存,快速查看文件的位置。grep : 過濾匹配,他是一個文件搜索工具。find  :  可以根據條件查看文件。

    登錄后復制

    which

    命令:which

    語法: which 參數 查詢目標

    常用命令: 一般不加參數使用

              --all, -a      顯示所有的匹配路徑

    登錄后復制

    操作:

    ?  ~ which pwd/usr/bin/pwd

    登錄后復制


    whereis

    命令: whereis

    語法: whereis 參數 查詢目標

    常用命令:

               一般不加參數使用         -b         只搜索二進制文件         -B <目錄>  定義二進制文件查找路徑         -m         只搜索 man 手冊         -M <目錄>  定義 man 手冊查找路徑         -s         只搜索源代碼         -S <目錄>  定義源代碼查找路徑

    登錄后復制

    操作:

    ?  ~ whereis lsls: /usr/bin/ls /usr/share/man/man1/ls.1.gz

    登錄后復制

    locate

    命令: locate

    語法: locate 文件名

    常用參數: 無

    操作: locate和find命令功能差不多,但是搜索效率更高,因為locate查的是數據庫而find查找的是目錄文件。

    數據庫:

    ?  ~ ls /var/lib/mlocate/mlocate.db/var/lib/mlocate/mlocate.db

    登錄后復制

    相關配置文件:

    ?  ~ ls /etc/updatedb.conf/etc/updatedb.conf

    登錄后復制

    相關定時任務:

    ?  ~ ls /etc/cron.daily/mlocate/etc/cron.daily/mlocate

    登錄后復制

    舉例:

    ?  ~ touch shafa?  ~ locate shafa?  ~ updatedb?  ~ locate shafa/root/shafa

    登錄后復制

    注:如果我們當天新建的文件查找,需要手動updatedb。

    搜索公眾號Linux就該這樣學回復“權限系統”,送你一份驚喜禮包。

    grep

    命令:grep

    語法:grep 參數 目標值 文件

    常用參數:

                -v       取反            -i        忽略大小寫            -n        輸出的同時打印行號            ^*        以*開頭            *$         以*結尾            ^$         空行

    登錄后復制

    操作:

    查 /etc/passwd有root的行

    ?  ~ grep root /etc/passwdroot:x:0:0:root:/root:/bin/zshoperator:x:11:0:operator:/root:/sbin/nologin

    登錄后復制

    查 /etc/passwd 沒有root的行(內容較多,禁展示幾行)

    ?  ~ grep -v root /etc/passwdbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/sync

    登錄后復制

    查 /etc/passwd 有www的行并顯示行號

    ?  ~ grep -n www /etc/passwd23:www:x:1000:1000::/home/www:/sbin/nologin

    登錄后復制

    find

    命令:find

    語法:find 路徑 參數 輸出

    常用參數:

                路徑: 例如用 . 來表示當前目錄,用 / 來表示系統根目錄。           -print:顯示的時候”\n”做為定界符, 換行          -print0:與xargs配套使用,以“\0”做為定界符

    登錄后復制

    find常用命令選項:

    -name   按照文件名查找文件。“名稱”-perm   按照文件權限來查找文件。666 777 等-depth  在查找文件時,首先查找當前目錄中的文件,然后再在其子目錄中查找-user   按照文件屬主來查找文件 -atime  -ctime (單位是天) -mmin -cmin  -amin(單位是分鐘) -size n [c] 查找文件長度為n塊的文件,帶有c時表示文件長度以字節計 -follow  如果find命令遇到符號鏈接文件,就跟蹤至鏈接所指向的文件。

    登錄后復制

    操作:

    查看當前目錄下test.開頭的文件

    ?  ~ find . -name "test*"./test.txt./autojump/tests./test.1

    登錄后復制

    查看當前目錄下test.開頭的文件,輸出結果換行顯示(默認)

    ?  ~ find . -name "test*" -print./test.txt./autojump/tests./test.1

    登錄后復制

    查看當前目錄下test.開頭的文件,輸出結果不換行顯示

    ?  ~ find . -name "test*" -print0./test.txt./autojump/tests./test.1

    登錄后復制

    對查找的內容執行相應命令

    默認執行動作 : -print

    常用動作:

                  -exec  這個參數后可以跟自定義shell命令

    登錄后復制

    操作:

    查詢.txt結尾的文件并用ls查詢其更多屬性

    ?  test find . -name "*.txt" -exec ls -l {} \;-rw-r--r-- 1 root root 0 11月  4 14:56 ./xq1.txt-rw-r--r-- 1 root root 0 11月  4 14:56 ./xq.txt-rw-r--r-- 1 root root 0 11月  4 14:56 ./xq2.txt

    登錄后復制

    查詢.txt結尾的文件并變成.bak結尾的文件

    ?  test find . -name "*.txt" -exec mv {} {}.bak \;?  test lsxq1.txt.bak  xq2.txt.bak  xq.txt.bak

    登錄后復制

    邏輯查詢:

            -a  并且        -o  或者         +  高于         -   低于

    登錄后復制

    操作:查看 .sh或者.q結尾的文件。

    ?  test find . -name "*.sh" -o -name "*.q"./book.q./stop.sh./start.sh

    登錄后復制

    查看.sh結尾并且s開頭的文件。

    ?  test find . -name "*.sh" -a -name "s*"./stop.sh./start.sh

    登錄后復制

    在文件中插入內容后查看。

    ?  test ll總用量 12K-rw-r--r-- 1 root root  9 11月  4 15:10 book.q-rw-r--r-- 1 root root 13 11月  4 15:10 start.sh-rw-r--r-- 1 root root  4 11月  4 15:10 stop.sh-rw-r--r-- 1 root root  0 11月  4 14:56 xq1.txt.bak-rw-r--r-- 1 root root  0 11月  4 14:56 xq2.txt.bak-rw-r--r-- 1 root root  0 11月  4 14:56 xq.txt.bak

    登錄后復制

    查看/etc 大于40k小于50k的文件

    ?  test find /etc/ -size +40k -a -size  -50k/etc/selinux/targeted/active/modules/100/sysadm/hll/etc/selinux/targeted/contexts/files/file_contexts.homedirs.bin

    登錄后復制


    計劃任務

    說到計劃,聯想到的是時間,說到任務,聯想到的就是做什么。連起來就是什么時間做什么。每天幾點上班幾點下班。每年的國慶,元旦都在固定的時間節點發生。類似這些,我們可以稱之為定時任務。

    再比如,有的時候。快下班了,領導來個緊急任務,小王啊,加個班。明天心情好,請個假去面試。這種的屬于臨時任務。

    那么在linux中我們怎么來做這兩件事呢。

    任務類型

    定時: 按照一定的周期重復持續的做某個事。

    臨時: 執行一次以后任務就結束了,只一次。

    任務類型對應的命令

    crontab( 定時任務): 按照你 你規定的周期 循環窒息感。

    at (臨時任務): 執行一次就結束的任務。

    at的使用

    命令:at

    語法: at 時間

    常用參數:

             -l    查看任務列表         -c   查看任務詳情

    登錄后復制

    操作:查看服務是否開啟

    [root@iz2ze0ajic0vbv28hcdctpz ~]# systemctl status atd● atd.service - Job spooling tools  Loaded: loaded (/usr/lib/systemd/system/atd.service; enabled; vendor preset: enabled)  Active: active (running) since 二 2018-11-13 11:50:47 CST; 1 day 9h agoMain PID: 491 (atd)  CGroup: /system.slice/atd.service          └─491 /usr/sbin/atd -f11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Started Job spooling tools.11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Starting Job spooling tools...

    登錄后復制

    幾種設定任務的方法: 創建一個任務(默認是今天,如果時間大于當前時間會創建在下一天 )

    [root@iz2ze0ajic0vbv28hcdctpz ~]# lssoft[root@iz2ze0ajic0vbv28hcdctpz ~]# at 21:17at> mkdir skat> <EOT>job 6 at Wed Nov 14 21:17:00 2018

    登錄后復制

    指定時間創建:

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 20:00 2018-11-19at> mkdir happyat> <EOT>job 7 at Mon Nov 19 20:00:00 2018

    登錄后復制

    從現在開始加時間:

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at now + 3minat> mkdir helloat> <EOT>job 8 at Wed Nov 14 21:41:00 2018

    登錄后復制

    明天11:11 執行

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 11:11 tomorrowat> mkdir worldat> <EOT>job 9 at Thu Nov 15 11:11:00 2018

    登錄后復制

    2天后的下午3.24執行

    [root@iz2ze0ajic0vbv28hcdctpz ~]# at 3:24 pm +2 daysat> mkdir newat> <EOT>job 11 at Fri Nov 16 15:24:00 2018

    登錄后復制

    查看任務列表(顯示還未執行的任務 )

    [root@iz2ze0ajic0vbv28hcdctpz ~]# atq5  Thu Nov 15 21:11:00 2018 a root

    登錄后復制

    查看一個單個的任務信息:(由于內容較多去掉部分信息)

    [root@iz2ze0ajic0vbv28hcdctpz /]# at -c 7#!/bin/sh# atrun uid=0 gid=0# mail root 0umask 22XDG_SESSION_ID=243; export XDG_SESSION_IDHOSTNAME=iz2ze0ajic0vbv28hcdctpz; export HOSTNAMESHELL=/bin/bash; export SHELLHISTSIZE=1000; export HISTSIZESSH_CLIENT=113.46.167.195\ 17211\ 22; export SSH_CLIENTSSH_TTY=/dev/pts/0; export SSH_TTYUSER=root; export USERMAVEN_HOME=/usr/local/apache-maven-3.6.0; export MAVEN_HOMEMAIL=/var/spool/mail/root; export MAILPATH=/usr/local/apache-maven-3.6.0/bin:/usr/local/jdk1.8.0_191/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin; export PATHPWD=/root; export PWDJAVA_HOME=/usr/local/jdk1.8.0_191; export JAVA_HOMELANG=zh_CN.UTF-8; export LANGHISTCONTROL=ignoredups; export HISTCONTROLSHLVL=1; export SHLVLHOME=/root; export HOMELOGNAME=root; export LOGNAMECLASSPATH=.:/lib/dt.jar:/lib/tools.jar; export CLASSPATHSSH_CONNECTION=113.46.167.195\ 17211\ 172.17.187.244\ 22; export SSH_CONNECTIONLC_CTYPE=zh_CN.UTF-8; export LC_CTYPELESSOPEN=\|\|/usr/bin/lesspipe.sh\ %s; export LESSOPENXDG_RUNTIME_DIR=/run/user/0; export XDG_RUNTIME_DIRcd /root || {  echo 'Execution directory inaccessible' >&2  exit 1}${SHELL:-/bin/sh} << 'marcinDELIMITER550b4fbb'mkdir happymarcinDELIMITER550b4fbb

    登錄后復制

    參數解釋:

    5 : 任務編號

    Thu Nov 15 21:11:00 2018 : 時間

    a : 隊列

    root : 執行用戶

    刪除任務:

    先來查看一下有哪些任務

    [root@iz2ze0ajic0vbv28hcdctpz /]# atq7  Mon Nov 19 20:00:00 2018 a root5  Thu Nov 15 21:11:00 2018 a root11  Fri Nov 16 15:24:00 2018 a root9  Thu Nov 15 11:11:00 2018 a root12  Wed Nov 14 22:11:00 2018 a root

    登錄后復制

    刪除任務編號為12的任務

    [root@iz2ze0ajic0vbv28hcdctpz /]# atrm 12[root@iz2ze0ajic0vbv28hcdctpz /]# atq7  Mon Nov 19 20:00:00 2018 a root5  Thu Nov 15 21:11:00 2018 a root11  Fri Nov 16 15:24:00 2018 a root9  Thu Nov 15 11:11:00 2018 a root

    登錄后復制

    定時任務處理

    cron是linux的一個定時任務執行工具,而crondtab是周期性執行命令,crond則是定時任務的守護進程。

    服務啟動
     查看服務是否啟動

    登錄后復制

    [root@iz2ze0ajic0vbv28hcdctpz ~]# systemctl status crond● crond.service - Command Scheduler  Loaded: loaded (/usr/lib/systemd/system/crond.service; enabled; vendor preset: enabled)  Active: active (running) since 二 2018-11-13 11:50:47 CST; 1 day 10h agoMain PID: 489 (crond)  CGroup: /system.slice/crond.service          └─489 /usr/sbin/crond -n11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Started Command Scheduler.11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz systemd[1]: Starting Command Scheduler...11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz crond[489]: (CRON) INFO (RANDOM_DELAY will be scaled with factor 7...ed.)11月 13 11:50:47 iz2ze0ajic0vbv28hcdctpz crond[489]: (CRON) INFO (running with inotify support)Hint: Some lines were ellipsized, use -l to show in full.

    登錄后復制

    如果沒有啟動,執行systemctl start crondsystemctl enable crond

    登錄后復制

    crontab命令

    語法 : crontab 參數

    常用參數 :

            crontab -u   #指定用戶的cron信息        crontab -l   #列出當前用戶下的cron服務的信息        crontab -u user -l   #列出指定用戶的cron服務的信息        crontab -r   #刪除cron服務        crontab -e   #編輯cron服務        crontab -r -u user   #刪除指定用戶的定時任務

    登錄后復制

    操作:

    編輯cron服務

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -ecrontab: installing new crontab

    登錄后復制

    查看當前用戶下任務內容

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -l22 22 22 * * mkdir /linux/test

    登錄后復制

    刪除任務

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -r[root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -lno crontab for root

    登錄后復制

    查看qa這個用戶下的任務內容

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -l22 22 22 * * mkdir /linux/test

    登錄后復制

    刪除qa這個用戶下的定時任務

    [root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -r[root@iz2ze0ajic0vbv28hcdctpz ~]# crontab -u qa -lno crontab for qa

    登錄后復制

    系統任務

    系統的任務調度配置文件在/etc/crontab下

    [root@iz2ze0ajic0vbv28hcdctpz ~]# ll /etc/crontab-rw-r--r-- 1 root root 451 Nov 15 07:49 /etc/crontab

    登錄后復制

    可以直接在/etc/crontab下添加系統任務(不建議)

    [root@iz2ze0ajic0vbv28hcdctpz ~]# cat /etc/crontabSHELL=/bin/bashPATH=/sbin:/bin:/usr/sbin:/usr/binMAILTO=root# For details see man 4 crontabs# Example of job definition:# .---------------- minute (0 - 59)# |  .------------- hour (0 - 23)# |  |  .---------- day of month (1 - 31)# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat# |  |  |  |  |# *  *  *  *  * user-name  command to be executed

    登錄后復制

    定時任務相關的目錄

    [root@iz2ze0ajic0vbv28hcdctpz etc]# ll crcron.d/       cron.deny     cron.monthly/ cron.weekly/cron.daily/   cron.hourly/  crontab       crypttab

    登錄后復制

    目錄作用解釋:

    cron.d/       是系統自動定期需要做的任務(不是按照時,分,秒等時間周期執行的)cron.deny   在該文件內的用戶無法做計劃任務其他文件為不同周期的執行腳本。

    登錄后復制

    定時任務規則

    首先來看下任務的格式(如圖):

    時間的一些特殊符號:

    下面我們來舉一些例子:

    #每晚的20:30重加載nginx30 20 * * * /usr/local/nginx/sbin/nginx -s reload#每月1、10、15日的5:30重加載nginx30 5 1,10,15 * * /usr/local/nginx/sbin/nginx  -s reload#每天20: 00至22 : 00之間每隔30分鐘重加載nginx0,30 20-22 * * * /usr/local/nginx/sbin/nginx -s reload每星期六的10 : 00 pm 重加載nginx0 22* * 6 /usr/local/nginx/sbin/nginx  -s reload#每一小時重加載一次nginx0 */1 * * * /usr/local/nginx/sbin/nginx -s reload

    登錄后復制

    expect

    很多時候我們和linux的操作交互需要人工干預,有時候我們可能需要一種工具可以不需要人工干預的和linux交互,這里引入了一個工具expect,本小結我們主要來講如何使用expect。

    expect介紹

    TCL(tool command language)是一種類似shell腳本的語言,你可以使用他來完成許多操作,expect是在它的基礎上發展而來的,expect還提供了一些tcl沒有的命令。如果你要寫一個自動處理輸入輸出的腳本,我建議選擇expect。

    expect安裝

    yum install -y expect

    expect使用
    1.定義腳本執行使用的shell。     #!/usr/bin/expect2.設置超時時間,單位為秒,timeout -1 為永不超時。        set timeout 23.殼子       spawn需要在expect環境下運行,用來傳遞交互指令。 4.expect命令       判斷輸出結果是否包含某字符串,沒有立即返回,否則就等一段時間后返回,用timeout設置等待時間。5.send        執行交互動作,將交互要執行的動作進行輸入給交互指令。命令字符串結尾要加上"\r",如果出現異常等待的狀態可以進行核查。6.exp_continue         繼續執行接下來的交互操作。7.interact        執行后保持交互狀態,把控制權交給控制臺,如不加interact,交互完成會自動退出。

    登錄后復制

    免密碼通過ssh登陸服務器

    操作腳本

    ?  batch cat sf#!/usr/bin/expect -fspawn ssh  root@ipexpect {"yes/no" { send "yes\r";exp_continue}"*password:" { send "passwordstr\r" }}interact

    登錄后復制

    執行查看結果,登陸成功

    ?  batch ./35spawn ssh root@iproot@ip's password:Last login: Sat Jan  5 10:15:56 2019 from 113.46.187.213Welcome to Alibaba Cloud Elastic Compute Service !

    登錄后復制

    ??

    這些只是Linux的冰上一角,小編還在路上,持續更新。。。??

    ?

      聲明:本文部分素材轉載自互聯網,如有侵權立即刪除 。

    登錄后復制

    以上就是Linux常用命令 & 實用命令萬字總結的詳細內容,更多請關注www.92cms.cn其它相關文章!

分享到:
標簽:Linux 萬字 命令 實用 常用命令
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定