前言
#! /bin/bash # Function: 根據(jù)用戶輸入的PID,過濾出該PID所有的信息 read-p"請輸入要查詢的PID: "P n=`ps -aux| awk'$2~/^'$P'$/{print $11}'|wc -l` if[$n-eq 0 ];then echo"該PID不存在??!" exit fi echo"--------------------------------" echo"進程PID:$P" echo"進程命令:`ps -aux| awk '$2~/^'$P'$/{print$11}'`" echo"進程所屬用戶: `ps -aux| awk '$2~/^'$P'$/{print$1}'`" echo"CPU占用率:`ps -aux| awk '$2~/^'$P'$/{print$3}'`%" echo"內(nèi)存占用率:`ps -aux| awk '$2~/^'$P'$/{print$4}'`%" echo"進程開始運行的時刻:`ps -aux| awk '$2~/^'$P'$/{print$9}'`" echo"進程運行的時間:`ps -aux| awk '$2~/^'$P'$/{print$10}'`" echo"進程狀態(tài):`ps -aux| awk '$2~/^'$P'$/{print$8}'`" echo"進程虛擬內(nèi)存:`ps -aux| awk '$2~/^'$P'$/{print$5}'`" echo"進程共享內(nèi)存:`ps -aux| awk '$2~/^'$P'$/{print$6}'`" echo"--------------------------------"
二、根據(jù)進程名過濾進程信息
會顯示出該進程名包含的所有線程
#! /bin/bash # Function: 根據(jù)輸入的程序的名字過濾出所對應(yīng)的PID,并顯示出詳細信息,如果有幾個PID,則全部顯示 read-p"請輸入要查詢的進程名:"NAME N=`ps -aux | grep$NAME| grep -v grep | wc -l`##統(tǒng)計進程總數(shù) if[$N-le 0 ];then echo"該進程名沒有運行!" fi i=1 while[$N-gt 0 ] do echo"進程PID: `ps -aux | grep$NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$2}'`" echo"進程命令:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$11}'`" echo"進程所屬用戶: `ps -aux | grep$NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$1}'`" echo"CPU占用率:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$3}'`%" echo"內(nèi)存占用率:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$4}'`%" echo"進程開始運行的時刻:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$9}'`" echo"進程運行的時間:` ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$11}'`" echo"進程狀態(tài):`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$8}'`" echo"進程虛擬內(nèi)存:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$5}'`" echo"進程共享內(nèi)存:`ps -aux | grep $NAME| grep -v grep | awk 'NR=='$i'{print$0}'| awk '{print$6}'`" echo"***************************************************************" letN-- i++ done
三、根據(jù)用戶名查詢該用戶的相關(guān)信息
#! /bin/bash # Function:根據(jù)用戶名查詢該用戶的所有信息 read-p"請輸入要查詢的用戶名:"A echo"------------------------------" n=`cat /etc/passwd | awk -F:'$1~/^'$A'$/{print}'| wc -l` if[$n-eq 0 ];then echo"該用戶不存在" echo"------------------------------" else echo"該用戶的用戶名:$A" echo"該用戶的UID:`cat /etc/passwd | awk -F: '$1~/^'$A'$/{print}'|awk -F: '{print$3}'`" echo"該用戶的組為:`id $A| awk {'print$3'}`" echo"該用戶的GID為:`cat /etc/passwd | awk -F: '$1~/^'$A'$/{print}'|awk -F: '{print$4}'`" echo"該用戶的家目錄為:`cat /etc/passwd | awk -F: '$1~/^'$A'$/{print}'|awk -F: '{print$6}'`" Login=`cat /etc/passwd | awk -F:'$1~/^'$A'$/{print}'|awk -F:'{print $7}'` if[$Login=="/bin/bash"];then echo"該用戶有登錄系統(tǒng)的權(quán)限??!" echo"------------------------------" elif[$Login=="/sbin/nologin"];then echo"該用戶沒有登錄系統(tǒng)的權(quán)限??!" echo"------------------------------" fi fi
四、加固系統(tǒng)的一些配置
#! /bin/bash # Function:對賬戶的密碼的一些加固 read-p"設(shè)置密碼最多可多少天不修改:"A read-p"設(shè)置密碼修改之間最小的天數(shù):"B read-p"設(shè)置密碼最短的長度:"C read-p"設(shè)置密碼失效前多少天通知用戶:"D sed -i'/^PASS_MAX_DAYS/cPASS_MAX_DAYS '$A''/etc/login.defs sed -i'/^PASS_MIN_DAYS/cPASS_MIN_DAYS '$B''/etc/login.defs sed -i'/^PASS_MIN_LEN/cPASS_MIN_LEN '$C''/etc/login.defs sed -i'/^PASS_WARN_AGE/cPASS_WARN_AGE '$D''/etc/login.defs echo"已對密碼進行加固,新用戶不得和舊密碼相同,且新密碼必須同時包含數(shù)字、小寫字母,大寫字母?。? sed -i'/pam_pwquality.so/cpassword requisite pam_pwquality.so try_first_pass local_users_only retry=3 authtok_type= difok=1 minlen=8 ucredit=-1 lcredit=-1 dcredit=-1'/etc/pam.d/system-auth echo"已對密碼進行加固,如果輸入錯誤密碼超過3次,則鎖定賬戶!!" n=`cat /etc/pam.d/sshd | grep"auth required pam_tally2.so "|wc -l` if[$n-eq 0 ];then sed -i'/%PAM-1.0/aauth required pam_tally2.so deny=3 unlock_time=150 even_deny_root root_unlock_time300'/etc/pam.d/sshd fi echo"已設(shè)置禁止root用戶遠程登錄!!" sed -i'/PermitRootLogin/cPermitRootLogin no'/etc/ssh/sshd_config read-p"設(shè)置歷史命令保存條數(shù):"E read-p"設(shè)置賬戶自動注銷時間:"F sed -i'/^HISTSIZE/cHISTSIZE='$E''/etc/profile sed -i'/^HISTSIZE/aTMOUT='$F''/etc/profile echo"已設(shè)置只允許wheel組的用戶可以使用su命令切換到root用戶!" sed -i'/pam_wheel.so use_uid/cauth required pam_wheel.so use_uid '/etc/pam.d/su n=`cat /etc/login.defs | grep SU_WHEEL_ONLY | wc -l` if[$n-eq 0 ];then echoSU_WHEEL_ONLY yes >> /etc/login.defs fi echo"即將對系統(tǒng)中的賬戶進行檢查...." echo"系統(tǒng)中有登錄權(quán)限的用戶有:" awk -F:'($7=="/bin/bash"){print $1}'/etc/passwd echo"********************************************" echo"系統(tǒng)中UID=0的用戶有:" awk -F:'($3=="0"){print $1}'/etc/passwd echo"********************************************" N=`awk -F:'($2==""){print $1}'/etc/shadow|wc -l` echo"系統(tǒng)中空密碼用戶有:$N" if[$N-eq 0 ];then echo"恭喜你,系統(tǒng)中無空密碼用戶!!" echo"********************************************" else i=1 while[$N-gt 0 ] do None=`awk -F:'($2==""){print $1}'/etc/shadow|awk'NR=='$i'{print}'` echo"------------------------" echo$None echo"必須為空用戶設(shè)置密碼!!" passwd$None letN-- done M=`awk -F:'($2==""){print $1}'/etc/shadow|wc -l` if[$M-eq 0 ];then echo"恭喜,系統(tǒng)中已經(jīng)沒有空密碼用戶了!" else echo"系統(tǒng)中還存在空密碼用戶:$M" fi fi echo"即將對系統(tǒng)中重要文件進行鎖定,鎖定后將無法添加刪除用戶和組" read-p"警告:此腳本運行后將無法添加刪除用戶和組?。〈_定輸入Y,取消輸入N;Y/N:"i case$iin [Y,y]) chattr +i /etc/passwd chattr +i /etc/shadow chattr +i /etc/group chattr +i /etc/gshadow echo"鎖定成功!" ;; [N,n]) chattr -i /etc/passwd chattr -i /etc/shadow chattr -i /etc/group chattr -i /etc/gshadow echo"取消鎖定成功!!" ;; *) echo"請輸入Y/y or N/n" esac
審核編輯:彭靜
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
Linux
+關(guān)注
關(guān)注
87文章
11209瀏覽量
208721 -
PID
+關(guān)注
關(guān)注
35文章
1469瀏覽量
85193 -
Shell腳本
+關(guān)注
關(guān)注
0文章
36瀏覽量
7960
原文標(biāo)題:【經(jīng)典shell腳本分享】幾個Linux高效運維shell腳本!
文章出處:【微信號:浩道linux,微信公眾號:浩道linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
幾個經(jīng)典高效的linux腳本
今天浩道跟大家分享硬核shell干貨,以下幾個腳本皆為經(jīng)典高效的linux腳本,拿來即用!
發(fā)表于 10-21 09:04
?1439次閱讀
Linux中常用的MySQL運維腳本
在Linux中,使用MySQL進行常見的運維任務(wù)時,可以編寫一些腳本來簡化操作。以下是一些常用的MySQL
發(fā)表于 09-07 09:49
?722次閱讀
100個Linux Shell腳本總結(jié)
不知道大家有沒有發(fā)現(xiàn),會編寫shell腳本的運維,工資不會低,并且他的工作會很輕松!今天浩道跟大家分享每一個Linux
Linux運維都要會哪些shell技能
在充斥著各種的互聯(lián)網(wǎng)+的數(shù)字時代,Linux運維也越來越趨于自動化方向發(fā)展,越來越多的運維工作者奔跑在了自動化
發(fā)表于 11-30 17:38
shell腳本的相關(guān)資料分享
腳本提供數(shù)組、循環(huán)、條件判斷的等功能shell腳本一般是Linux運維或者系統(tǒng)管理員要掌握的,作
發(fā)表于 12-23 06:17
Linux常見調(diào)用shell腳本的三種方法
編寫Linux下的應(yīng)用程序時有時需要調(diào)用Linux的相關(guān)shell腳本,在這些腳本中通過調(diào)用Linux
Linux Shell腳本編程基礎(chǔ)和相關(guān)資料合集免費下載
本文檔的主要內(nèi)容詳細介紹的是Linux Shell腳本編程基礎(chǔ)和相關(guān)資料合集免費下載。
發(fā)表于 05-24 17:53
?26次下載
運維常用的34個Linux Shell腳本
Shell 腳本編程是在 Linux 下學(xué)習(xí)或練習(xí)編程的最簡單的方式。尤其對運維工程師處理著自動化任務(wù),且要開發(fā)新的簡單的實用程序或工具等(
Linux開發(fā)_Makefile規(guī)則與Shell腳本語言
介紹Linux下Makefile編程知識點,Shell腳本知識點。
Linux Shell腳本經(jīng)典案例分享
? 作為一名 Linux 運維工程師,會寫好的腳本不僅能提高工作效率,還能有更多的時間做自己的事。最近在網(wǎng)上沖浪的時候,發(fā)現(xiàn)大家對Shell
發(fā)表于 06-16 14:03
?625次閱讀
評論