一、根據(jù)PID過濾進(jìn)程所有信息
#!/bin/bash
#Function:根據(jù)用戶輸入的PID,過濾出該P(yáng)ID所有的信息
read-p"請輸入要查詢的PID:"P
n=`ps-aux|awk'$2~/^'$P'$/{print$11}'|wc-l`
if[$n-eq0];then
echo"該P(yáng)ID不存在??!"
exit
fi
echo"--------------------------------"
echo"進(jìn)程PID:$P"
echo"進(jìn)程命令:`ps -aux| awk '$2~/^'$P'$/{print$11}'`"
echo"進(jìn)程所屬用戶:`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"進(jìn)程開始運(yùn)行的時刻:`ps -aux| awk '$2~/^'$P'$/{print$9}'`"
echo"進(jìn)程運(yùn)行的時間:`ps -aux| awk '$2~/^'$P'$/{print$10}'`"
echo"進(jìn)程狀態(tài):`ps -aux| awk '$2~/^'$P'$/{print$8}'`"
echo"進(jìn)程虛擬內(nèi)存:`ps -aux| awk '$2~/^'$P'$/{print$5}'`"
echo"進(jìn)程共享內(nèi)存:`ps -aux| awk '$2~/^'$P'$/{print$6}'`"
echo"--------------------------------"

二、根據(jù)進(jìn)程名過濾進(jìn)程信息
會顯示出該進(jìn)程名包含的所有線程
#!/bin/bash
#Function:根據(jù)輸入的程序的名字過濾出所對應(yīng)的PID,并顯示出詳細(xì)信息,如果有幾個PID,則全部顯示
read-p"請輸入要查詢的進(jìn)程名:"NAME
N=`ps-aux|grep$NAME|grep-vgrep|wc-l`##統(tǒng)計進(jìn)程總數(shù)
if[$N-le0];then
echo"該進(jìn)程名沒有運(yùn)行!"
fi
i=1
while[$N-gt0]
do
echo"進(jìn)程PID:`ps-aux|grep$NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$2}'`"
echo"進(jìn)程命令:`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$11}'`"
echo"進(jìn)程所屬用戶:`ps-aux|grep$NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$1}'`"
echo"CPU占用率:`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$3}'`%"
echo"內(nèi)存占用率:`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$4}'`%"
echo"進(jìn)程開始運(yùn)行的時刻:`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$9}'`"
echo"進(jìn)程運(yùn)行的時間:` ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$11}'`"
echo"進(jìn)程狀態(tài):`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$8}'`"
echo"進(jìn)程虛擬內(nèi)存:`ps -aux | grep $NAME|grep-vgrep|awk'NR=='$i'{print$0}'|awk'{print$5}'`"
echo"進(jìn)程共享內(nèi)存:`ps -aux | grep $NAME|grep-vgrep|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-eq0];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"已對密碼進(jìn)行加固,新用戶不得和舊密碼相同,且新密碼必須同時包含數(shù)字、小寫字母,大寫字母??!"
sed-i'/pam_pwquality.so/cpasswordrequisitepam_pwquality.sotry_first_passlocal_users_onlyretry=3authtok_type=difok=1minlen=8ucredit=-1lcredit=-1dcredit=-1'/etc/pam.d/system-auth
echo"已對密碼進(jìn)行加固,如果輸入錯誤密碼超過3次,則鎖定賬戶!!"
n=`cat/etc/pam.d/sshd|grep"authrequiredpam_tally2.so"|wc-l`
if[$n-eq0];then
sed-i'/%PAM-1.0/aauthrequiredpam_tally2.sodeny=3unlock_time=150even_deny_rootroot_unlock_time300'/etc/pam.d/sshd
fi
echo"已設(shè)置禁止root用戶遠(yuǎn)程登錄?。?
sed-i'/PermitRootLogin/cPermitRootLoginno'/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.souse_uid/cauthrequiredpam_wheel.souse_uid'/etc/pam.d/su
n=`cat/etc/login.defs|grepSU_WHEEL_ONLY|wc-l`
if[$n-eq0];then
echoSU_WHEEL_ONLYyes>>/etc/login.defs
fi
echo"即將對系統(tǒng)中的賬戶進(jìn)行檢查...."
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-eq0];then
echo"恭喜你,系統(tǒng)中無空密碼用戶!!"
echo"********************************************"
else
i=1
while[$N-gt0]
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-eq0];then
echo"恭喜,系統(tǒng)中已經(jīng)沒有空密碼用戶了!"
else
echo"系統(tǒng)中還存在空密碼用戶:$M"
fi
fi
echo"即將對系統(tǒng)中重要文件進(jìn)行鎖定,鎖定后將無法添加刪除用戶和組"
read-p"警告:此腳本運(yùn)行后將無法添加刪除用戶和組!!確定輸入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/yorN/n"
esac

-
PID
+關(guān)注
關(guān)注
37文章
1489瀏覽量
90025 -
腳本
+關(guān)注
關(guān)注
1文章
407瀏覽量
29048 -
運(yùn)維
+關(guān)注
關(guān)注
1文章
281瀏覽量
8496
原文標(biāo)題:優(yōu)秀運(yùn)維腳本鑒賞
文章出處:【微信號:良許Linux,微信公眾號:良許Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄

優(yōu)秀運(yùn)維腳本鑒賞
評論