溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

linux安全加固腳本怎么寫

發(fā)布時間:2022-10-19 14:51:06 來源:億速云 閱讀:93 作者:iii 欄目:建站服務(wù)器

這篇文章主要講解了“l(fā)inux安全加固腳本怎么寫”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“l(fā)inux安全加固腳本怎么寫”吧!

代碼如下:

#linux加固腳本
#!/bin/bash
#
#version1.0;
#write at 2021-08-27;
#write by jiangzhehao;
#只在centos7上測試過
#1、賬號安全
#1.1 賬號加固
#備份文件
cp /etc/login.defs /etc/login.defs.bak
echo "對密碼安全策略進行加固,設(shè)置密碼存在時間、密碼長度、密碼過期提醒!"
read -p "設(shè)置密碼有效時間(建議90天):" A
read -p "設(shè)置密碼最短長度(建議8位):" C
read -p "設(shè)置密碼過期提醒(建議15天):" D
sed -i '/^PASS_MAX_DAYS/c\PASS_MAX_DAYS   '$A /etc/login.defs
sed -i '/^PASS_MIN_DAYS/c\PASS_MIN_DAYS   '0 /etc/login.defs
sed -i '/^PASS_MIN_LEN/c\PASS_MIN_LEN    '$C /etc/login.defs
sed -i '/^PASS_WARN_AGE/c\PASS_WARN_AGE   '$D /etc/login.defs
echo "加固已完成。"
echo "*****************************************************************************************"
#
echo "對密碼安全策略進行加固,新用戶不得和舊密碼相同,且新密碼必須同時包含大寫字母、小寫字母、數(shù)字!"
#備份文件
cp /etc/pam.d/system-auth /etc/pam.d/system-auth.bak
sed -i '/pam_pwquality.so/c\password 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 "加固已完成。"
echo "*****************************************************************************************"
#
echo "對密碼進行加固,如果輸入錯誤密碼超過3次,則鎖定賬戶!"
sed -i '/^auth        required      pam_deny.so/i\auth        required      pam_tally.so onerr=fail deny=10 unlock_time=300' /etc/pam.d/system-auth
echo "被鎖定的用戶可以使用 faillog -u root -r  解除鎖定。"
echo "加固已完成。"
echo "*****************************************************************************************"
#
echo "禁止root用戶ssh遠程登錄,需要root用時,使用su切換!"
#備份文件
cp /etc/ssh/sshd_config /etc/ssh/sshd_config.bak 
sed -i '/PermitRootLogin/c\PermitRootLogin no' /etc/ssh/sshd_config
echo "加固已完成。"
echo "*****************************************************************************************"
#
echo "限制遠程登錄主機地址!"
read -p "設(shè)置遠程登錄地址段(格式為10.1.*.*):" E
sed -i '/ListenAddress /i\ALLOWUSERS *@'$E'' /etc/ssh/sshd_config
echo "加固已完成。"
echo "*****************************************************************************************"
#
echo "清除信任主機列表(信任主機登錄不需要驗證)!"
echo "" > /etc/hosts.equiv
echo "" > /$home/.rhosts
echo "加固已完成。"
echo "*****************************************************************************************"
#
echo "history設(shè)置優(yōu)化(建議保存條數(shù)1000條,超時時間為300秒)!"
read -p "設(shè)置歷史命令保存條數(shù)(建議1000):" F
read -p "設(shè)置賬戶自動注銷時間(建議300):" G
sed -i '/^HISTSIZE/c\HISTSIZE='$F'' /etc/profile
sed -i '/^HISTSIZE/a\TMOUT='$G'' /etc/profile
echo "加固已完成。"
echo "*****************************************************************************************"
#
#1.2用戶檢查
echo "即將對系統(tǒng)中的賬戶進行檢查......"
echo "系統(tǒng)中有登錄權(quán)限的用戶有:"
awk -F: '($7=="/bin/bash"){print $1}' /etc/passwd
echo "********************************************"
echo "系統(tǒng)中UID=0的特權(quán)用戶有:"
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)中無空密碼用戶?。?quot;
 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
 let N--
 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
#
#2、文件系統(tǒng)安全加固
#設(shè)置umask值
echo "設(shè)置umask值為077!"
sed -i '/^UMASK/c\UMASK           077' /etc/login.defs
echo "加固已完成。"
echo "*****************************************************************************************"
#
#3、禁用不需要的服務(wù)
/sbin/chkconfig ip6tables off
/sbin/chkconfig avahi-daemon off
/sbin/chkconfig avahi-dnsconfd off
#
#4、設(shè)置需要開啟的端口
#yum install iptables-services -y
#systemctl start iptables
#iptables -F
#iptables -P INPUT DROP
#iptables -A INPUT -p tcp --dport 22

感謝各位的閱讀,以上就是“l(fā)inux安全加固腳本怎么寫”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對linux安全加固腳本怎么寫這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI