目錄:
(一)sodu用戶切換
(二)Linux和Linux之間互相傳輸文件
(三)Linux和Windows之間互相傳輸文件
(四)find文件查找
(五)其餘查找工具算法
(一)sodu用戶切換
(1.1)咱們在系統中切換用戶時候,是必需要知道對方的密碼才能夠切換的,可是不少時候root密碼不可能讓每一個人都知道。爲了解決這個問題,可使用root用戶去設置哪些用戶擁有執行哪些命令的權限,而對應的用戶使用「sudo」命令進行用戶切換。
(1.2)咱們在vms002主機上進行操做,咱們使用root用戶打開/etc/sudoers配置文件,其中配置文件的格式能夠參考圖1-2。
# gedit /etc/sudoers
(1.3)因爲/etc/sudoers文件中的內容已經比較多了,咱們能夠在/etc/sudoers.d/目錄中進行編輯,而/etc/sudoers配置文件則會將/etc/sudoers.d/目錄中的文件做爲本身的一部分(圖1-3),表示的是jerry用戶在vms002.example.com主機上執行mount和umount命令的時候,將會按照root用戶的權限進行執行(圖1-4)。
# gedit /etc/sudoers.d/jerry
(1.4)此時咱們發如今沒有建立/etc/sudoers.d/jerry文件以前咱們使用jerry用戶是沒法執行mount掛載命令的,接着咱們編輯/etc/sudoers.d/jerry文件容許jerry用戶執行mount和umount命令,此時咱們登陸式切換到jerry用戶後,使用sudo命令發現已經能夠正常的使用mount掛載命令了(圖1-5)。注意:咱們在使用jerry用戶執行sudo命令的時候,須要執行一次jerry用戶的密碼,系統保存密碼默認爲5分鐘,若是須要清除保存的密碼咱們可使用「sudo -k」命令(圖1-6)。
# sudo mount /dev/cdrom /mnt/
# sudo -k---清除系統保存的密碼
# sudo -l---列出系統中全部容許執行的權限信息
(1.5)若是咱們但願jerry用戶在執行mount或者umount命令的時候不須要執行密碼,則能夠加上「NOPASSWD」參數,表示當jerry用戶在vms002.example.com主機上執行mount和umount命令的時候,會按照root用戶的權限執行命令,而且不須要輸入密碼信息(圖1-8)。此時咱們執行的時候會發現jerry用戶直接執行了mount命令,而且掛載成功了(圖1-9)。
(1.6)若是咱們但願jerry用戶可以按照root用戶的權限執行全部命令,則咱們可使用「ALL」參數,表示全部命令都是按照root用戶的權限進行執行(圖1-10),此時咱們使用「sudo -i」命令即可以切換到管理員root下,執行全部的命令了(圖1-11)。
# sudo -i---切換到管理員權限
(1.7)通常咱們能夠將sudo和網絡用戶進行和配合使用,例如咱們有一臺目錄服務主機存放的都是帳戶信息,還有多臺成員服務器,當網絡用戶的服務搭建好以後,例如如今咱們有一個tom網絡用戶,通常狀況下咱們是能夠從任意一臺成員服務器使用tom網絡用戶名登陸到系統中的。而如今咱們在sudo的配置文件中設置,vms001主機上tom用戶登陸時能夠執行的相關權限,其餘成員服務器主機上使用tom用戶登陸時都沒有任何的權限,這樣就能夠很好的進行權限的管理了。shell
(二)Linux和Linux之間互相傳輸文件
(2.1)在系統中有時候咱們須要傳輸一些小文件或者一些零散的文件,此時咱們須要一些傳輸的工具進行文件傳輸,一般在Linux系統和Linux系統之間傳輸文件的工具主要有scp和rsync兩種工具可使用,這兩種工具都是基於ssh服務創建起來的工具。
(2.2)scp使用方法
(2.2.1)首先咱們來了解scp工具,scp工具的語法以下:「scp -選項 /path1/file remoteIP:/path2」,表示將當前主機下目錄中的文件拷貝到遠端主機下的目錄中。
(2.2.2)咱們嘗試將vms001主機上的hosts文件拷貝到vms002主機的/opt/目錄下,咱們能夠按照以下的方式操做,發現能夠正常的將vms001主機的文件拷貝傳送到vms002主機上了(圖2-3)。
# scp /etc/hosts vms002:/opt/
(2.2.3)接着咱們在vms001主機上切換到tom用戶,而後一樣嘗試將/etc/hosts文件拷貝到vms002主機的/opt/目錄中,咱們發現並不能拷貝傳送文件成功,這是因爲咱們在vms001主機上咱們沒有指定用戶名,因此此時默認使用的是當前的用戶名tom傳送文件(圖2-4),查詢/opt/目錄的權限信息,咱們發現目錄中其餘用戶並無可寫的權限,所以咱們是沒法拷貝傳送文件成功的(圖2-5)。而當咱們指定使用root用戶傳輸到vms002主機的/opt目錄下(圖2-6),此時咱們發如今vms002主機的/opt目錄能夠正常的查看到hosts文件了(圖2-7)。
# useradd tom---建立一個tom用戶
# echo redhat | passwd --stdin tom---給tom用戶建立密碼
# ls -ld /opt/---查看opt目錄的權限
(2.2.4)接着咱們在vms001主機上先會生成一個不須要輸入密碼的密鑰對(圖2-8),而後將公鑰對從vms001主機拷貝到vms002主機上,此時咱們發現從vms001主機能夠直接鏈接到vms002主機而不用輸入密碼(圖2-9),同時咱們從vms001主機傳送/etc/hosts文件到vms002主機時,也是不須要輸入密碼就能夠傳輸成功的(圖2-10)。
# ls .ssh/
# ssh-keygen -N ""---生成一個不須要輸入密碼的密鑰對
# ssh-copy-id vms002---將公鑰對從vms001主機拷貝到vms002主機上
# scp /etc/hosts vms002:/opt/---將vms001主機的文件拷貝到vms002主機上
(2.2.5)如今咱們的需求是將當前vms001主機的/boot目錄下的文件拷貝到vms002主機的/opt目錄下,此時咱們可使用scp -r遞歸的方式將目錄中的文件進行拷貝(圖2-11),此時咱們在vms002主機上看到/opt目錄下已經產生了一個boot目錄了(圖2-12)。
# scp -r /boot/ vms002:/opt/
(2.2.6)咱們也是能夠反過來操做的,便可以把遠端主機的文件拷貝到本地的,例如咱們把vms002主機上的vms002.txt文件拷貝到vms001主機上,此時咱們發現vms001主機上能夠看到vms002.txt的文件了。
# scp vms002:~/vms002.txt .---將vms002主機上的文件拷貝到本地
(2.3)rsync使用方法
(2.3.1)rsync命令是一個遠程數據同步工具,可經過LAN/WAN快速同步多臺主機間的文件。rsync使用所謂的「rsync算法」來使本地和遠程兩個主機之間的文件達到同步,這個算法只傳送兩個文件的不一樣部分,而不是每次都整份傳送,所以速度至關快。其中rsync的語法爲:「rsync -選項 /path1/file remoteIP:/path2」,表示將當前主機的文件拷貝到遠端主機的目錄中。
(2.3.2)咱們嘗試將/etc/hosts文件拷貝到vms002主機的/opt目錄,此時咱們發現vms002主機上便已經有了vms001主機上的hosts文件了(圖2-16)。
# rsync /etc/hosts vms002:/opt/---將/etc/hosts文件拷貝到vms002主機的/opt目錄
(2.3.3)若是咱們想要將vms001主機的/boot/目錄下的全部文件都拷貝到vms002主機的/opt目錄下,則可使用rsync -r命令(圖2-17),注意此處咱們使用的是「/boot/」表示的是boot目錄下的全部的文件。此時咱們在vms002主機上發現/opt目錄下已經存在了boot目錄中的全部的文件了(圖2-18)。
# rsync -r /boot/ vms002:/opt/---將/boot/目錄下的全部文件都拷貝到vms002主機的/opt目錄下
(2.3.4)若是咱們但願將vms001主機的/boot/目錄和目錄下的全部文件總體拷貝到vms002主機的/opt目錄下(圖2-19),注意此處咱們使用的是「/boot」表示的是將目錄及目錄下文件做爲一個總體進行拷貝,此時在vms002主機上發現/opt目錄下已經產生了一個boot目錄了,且boot目錄中也有vms001傳輸過來的全部文件了(圖2-20)。
# rsync -r /boot vms002:/opt/
(2.3.5)若是咱們但願對文件的時間、屬主、屬組等全部信息都進行統一的拷貝傳輸,此時咱們可使用rsync -a命令實現這樣的需求。
# rsync -a /boot vms002:/opt/
(2.3.6)有時候爲了能夠更好的使用rsync的服務,咱們也可使用圖形化界面的工具grsync,常見的grsync版本爲grsync-1.2.4-3.el7.nux.x86_64.rpm軟件包。數據庫
(三)Linux和Windows之間互相傳輸文件
(3.1)lrzsz使用方法
(3.1.1)在Linux和Windows系統之間進行文件傳輸,一般咱們是有不少小的工具可使用的,例如咱們常見的lrzsz,咱們首先要確保在服務器上已經安裝了lrzsz,若是咱們使用的是圖形化界面的安裝方式,則lrzsz默認是已經安裝好了的;若是咱們使用的是最小化安裝系統的方式,則是沒有默認安裝lrzsz工具的。
(3.1.2)咱們能夠在vms001主機上輸入rz命令,這樣就能夠將Windows主機上的文件傳輸到Linux系統了。
(3.1.3)若是咱們但願將Linux系統的文件傳輸到Windows主機時,咱們能夠在vms001主機使用sz命令,即可以實現這個需求。
# sz vms002.txt
(3.1.4)咱們須要知道的是lrzsz工具是能夠經過xshell、secureCRT等工具鏈接到服務器上的,可是若是咱們使用的是putty客戶端時,則是不支持使用lrzsz工具的。
(3.2)通常來講咱們上面使用的lrzsz是用來傳輸小文件比較便捷的,若是咱們想要傳輸大文件通常是不建議使用lrzsz的。此時咱們可使用xshell客戶端提供的工具,咱們能夠點擊「新建文件傳輸」或者是經過快捷鍵「Ctrl+Alt+F」即可以將工具打開,此時咱們即可以使用很是快的速率傳輸大文件了。
(3.3)有時候咱們也可使用其餘的一些工具實現Linux和Windows系統之間的文件傳輸,例如WinSCP 或者FileZilla,也是能夠實現咱們的需求的。vim
(四)find文件查找
(4.1)通常咱們使用find命令進行文件的查找,find命令的格式爲:「find 目錄 -屬性 值」,其中若是沒有指明目錄則默認是在當前目錄下進行查詢,其中屬性主要包括:name、iname、user、group、nouser、nogroup、uid、gid、size、mtime、mmin、type、perm
(4.2)接着咱們在vms002主機上建立一個rh124目錄,而後建立相關的文件,並給建立的文件設置對應的屬主和屬組信息。
# chown jerry aa---修改aa的屬主爲jerry
# chown jerry.jerry bb---修改bb的屬主和屬組爲jerry
# chown .users cc---修改cc的屬組爲users
# chown 101.users dd---修改dd的屬主爲101屬組爲users
# chown .103 ee---修改ee的屬組爲103
(4.3)若是咱們想在系統中找到名字爲lwang的文件,則可使用「-name」參數;若是咱們但願在查詢名字的時候忽略大小寫,則可使用「-iname」參數。
# find / -name lwang---找到名字爲lwang的文件,則可使用「-name」參數
# find / -iname lwang---查詢名字的時候忽略大小寫,則可使用「-iname」參數
(4.4)若是咱們想要查詢屬主爲jerry用戶的文件,則可使用「-user」參數;若是咱們想要查詢屬組爲jerry的文件,則可使用「-group」參數查詢。
# find -user jerry---查詢屬主爲jerry用戶的文件
# find -group jerry---查詢屬組爲jerry用戶的文件
(4.5)由於jerry用戶的uid爲1000,若是咱們想要查詢uid爲1000的文件,則可使用「-uid」參數;若是咱們想要查詢gid爲1000的文件,則可使用「-gid參數」
# find -uid 1000---查詢uid爲1000的文件
# find -gid 1000---查詢gid爲1000的文件
(4.6)若是想要查詢沒有所屬主的文件,則可使用「-nouser」參數;若是想要查詢沒有所屬組的文件,則可使用「-nogroup」參數。
# find -nouser---查詢沒有所屬主的文件
# find -nogroup---查詢沒有所屬組的文件
(4.7)若是咱們想要查詢屬主和屬組都是jerry用戶的文件,則咱們可使用「-a」參數進行鏈接,表示兩個條件都要同時知足;而若是咱們想要查詢屬主是jerry或者屬組是jerry用戶的文件,則可使用「-o」參數,表示全部的條件只要有一個知足,都是符合條件的。
# find -user jerry -a -group jerry---查詢屬主和屬組都是jerry用戶的文件
# find -user jerry -o -group jerry---查詢屬主是jerry或者屬組是jerry用戶的文件
(4.8)接着咱們在vms002主機上從新建立以下的7個文件,若是咱們但願查詢文件大小正好等於3M的文件,則直接使用「3M」便可,若是咱們但願查詢大於3M的全部文件則可使用「+3M」參數,此時咱們即可以根據文件的大小size進行查詢。
# rm -rf [a-z]*---刪除rh124目錄中的全部文件
# dd if=/dev/zero of=file1 bs=1M count=1---建立一個1M的文件file1
# find -size 3M---查詢文件大小正好爲3M的文件
# find -size +3M---查詢文件大小大於3M的全部文件
# find -size +3M -o -size 3M---查詢文件大小大於且等於3M的全部文件
(4.9)咱們還能夠根據文件的時間屬性進行查詢,咱們能夠查詢建立的文件的時間間隔爲1天的文件,建立的文件的時間間隔大於1天的文件,建立的文件的時間間隔小於1天的文件。
# find -mtime 1---查詢所建立的文件的時間間隔爲1天的
# find -mtime +1---查詢所建立的文件的時間間隔大於1天的
# find -mtime -1---查詢所建立的文件的時間間隔小於1天的
(4.10)咱們還能夠經過mmin參數以分鐘的精度查詢文件的建立時間狀態。
# find -mmin 44---查詢文件的建立時間爲44分鐘的
# find -mmin -44---查詢文件的建立時間少於44分鐘的
# find -mmin +44---查詢文件的建立時間超過44分鐘的
(4.11)咱們還能夠經過文件的類型type進行查詢,咱們先在系統中建立一個目錄rh124,再建立一個軟鏈接從file6文件鏈接指向lwang文件(圖4-15)。咱們知道在查詢文件屬性的時候「d」參數表示目錄文件,「-」表示的普通文件,「l」表示的軟鏈接,「b」表示的是塊設備及block文件,「c」表示的是字符設備。若是咱們想要查詢一個塊設備類型的文件,則可使用「-b」參數,若是咱們想查詢一個普通類型的文件設備,則可使用「-f」參數(圖4-16)。
# ln -s lwang file6---建立一個軟鏈接,file6鏈接到lwang文件上
# find -type b---查詢塊設備類型的文件
# find -type f---查詢普通文件類型的設備
(4.12)咱們也能夠經過權限perm來進行查詢,例如咱們如今設計一個權限ugo=364(圖4-17),同時咱們將file1文件的權限設置爲364,而後咱們查詢當前目錄下權限徹底符合364設置的全部文件,此時發現全部文件中只有file1文件是符合權限要求的(圖4-18)。
# chmod 364 file1---修改file文件的權限爲364
# find -perm 364---查詢當前目錄下權限徹底符合364設置的全部文件
# find -perm +364
(4.13)咱們將權限至少爲364的文件都挑選出來,所以發現file一、file二、file6三個文件是符合要求的。
# find -perm -364---查詢的權限能夠比364的權限多,可是不能夠少
(4.14)咱們可使用/364表示只要文件的ugo三個權限中有任意一個位置的權限含於咱們查詢的364三個位置上的一個權限,那麼此文件就是符合要求的。此時咱們發現除了lwang的權限是不符合要求的,其餘的文件都是符合要求的。
# chmod 200 file3---將file3文件設置爲200
# chmod 004 file4---將file4文件設置爲004
# chmod 020 file5---將file5文件設置爲020
# chmod 411 lwang---將lwang文件設置爲411
# find -perm /364---查詢ugo三個權限中有任意一個位置的權限含於咱們查詢的364三個位置上的一個權限的文件
(4.15)若是咱們想查詢對應的文件的屬性,可使用xargs命令進行操做,將查詢出的file開頭的文件經過xargs參數傳遞給ls命令,此時即可以查看查找出來的文件的屬性信息了(圖4-21)。同時咱們也可使用xargs參數執行刪除的操做(圖4-21-1)。
# find -name "file*" | xargs ls -l---查詢file開頭的全部文件的屬性
# touch file{1..10}---建立10個file開頭的文件
# find -name "file*" | xargs rm -rf---將file開頭的文件所有刪除
(4.16)第二種方式咱們也可使用「-exec」命令查看查詢出來的文件的屬性信息,經過使用「-exec」將查詢出來的file開頭的全部文件所有刪除。
# find -name "file*" -exec rm -rf {} \;---將查詢出來的file開頭的全部文件所有刪除
(4.17)若是咱們當前目錄中除了文件還有目錄,而且目錄下還包含子文件夾,那麼此時咱們在執行「# find -name lwang」的命令時,會自動的到子文件夾中作遞歸查詢。若是如今咱們並不想作深層的查詢,只但願是作1層的查詢,此時咱們可使用「# man find」進行查詢,而後查找「maxdepth」關鍵字便可。遞歸查找
# find -maxdepth 1 -name lwang---在當前目錄的第一層查找文件名爲lwang的文件
瀏覽器
(五)其餘查找工具
(5.1)在Linux系統中咱們還有其餘的經常使用工具用來進行查詢操做,例如which命令,咱們想要查詢date命令具體是在哪一個路徑下執行的,則可使用「# which date」進行查詢。
# which date---查詢date命令具體是在哪一個路徑
# which vim
# which ifconfig
(5.2)咱們還可使用locate命令,例如咱們想要查詢系統中關於ceph關鍵字的全部文件信息,咱們可使用「# locate ceph」命令,此時咱們能夠查詢出系統中關於ceph關鍵字的全部文件信息(圖5-2)。可是咱們若是在系統中臨時建立一個文件ceph.txt,此時咱們發現並不能搜索到新建立的文件(圖5-3),這是因爲locate命令在查詢的時候使用的是一個數據庫中的信息,而這個數據庫是在一週左右更新一次,因此此時咱們搜索剛剛建立的文件的時候是查詢不到任何信息的,此時咱們須要作的就是更新數據庫便可,此時咱們發現已經能夠搜索到剛剛建立的根目錄下的ceph.txt文件了(圖5-4)。
# locate ceph---查詢系統中關於ceph關鍵字的全部文件信息
# updatedb---更新數據庫
(5.3)有時候咱們在使用locate命令的時候,很容易和locale命令混淆,由於它們長得太像了像雙胞胎同樣。其中locale命令是來設置咱們系統的默認編碼的。咱們在xshell中使用ssh登陸的時候,系統的編碼是UTF-8,所以咱們必需要保證ssh客戶端的編碼和系統編碼保持一致,不然就會出現亂碼的問題。
(5.4)例如咱們在打開瀏覽器的時候,當前系統默認是使用「LANG=zh_CN.UTF-8」即中文打開的,可是咱們想要以美式英語的方式打開,此時咱們可使用在執行firefox命令以前使用LANG命令指明美式英語編碼便可(圖5-7)。若是咱們想修改系統默認的編碼,則應該在/etc/locale.conf配置文件中進行修改(圖5-8)。
注意:在RHEL 6系統中,系統的默認編碼是在/etc/sysconfig/i18n文件中進行配置的。
# LANG=en-us firefox &---使用美式英語的方式打開瀏覽器
# cat /etc/locale.conf
服務器
—————— 本文至此結束,感謝閱讀 ——————網絡