51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

centos7系统安全配置脚本

init_7.sh

#!/bin/bash
[ -f  /etc/init.d/functions ]&& . /etc/init.d/functions

status_check() {
	printf "\033[37m$1\033[0m%-40s\033[32;40m[ $2 ]\033[0m\n"
}

stat() {
	if [ $? -eq 0 ];then
		action "$1" /bin/true
	else
		action "$1" /bin/false
	fi
}

ok() {
	action "$1" /bin/true
}

fail() {
	action "$1" /bin/false
}

user_root() {
	if [ $UID -ne 0 ];then
		user=`whoami`
		fail "$user"
	else
		ok "use root or admin"
	fi
}

network_chk() {
	count=1
	num=0
	while [ $count -le 2 ]
	do
		ping -c 2 www.baidu.com &>/dev/null
		if [ $? -ne 0 ];then
			let count++
			let num++
			action "Network is wrong" /bin/false
		else
			ok "network"
			break
		fi
	done	
}

set_all() {
	user_root
	sleep 1
	network_chk
	sleep 1
	HostName
	sleep 1
	yum_update
	sleep 1
	ntp_date
	sleep 1
	ulimt_change
	sleep 1
	add_user
	sleep 1
	optimize_ssh
	sleep 1
	bash_mode
	sleep 1
	history_message
	sleep 1
	sysctl_optimize
	sleep 1
	iptables_add
	sleep 1
	other_optimize
	
}

HostName() {
	read -p 'pls enter your hostname: ' name
	hostnamectl set-hostname $name
	hostname $name && stat "hostname: $name"
}

yum_update() {
	\cp -a /etc/yum.repos.d /etc/yum.repos.d_backup &>/dev/null && stat "backup yum.repos.d"
	yum -y install wget &>/dev/null && stat "yum wget"
	wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo &>/dev/null && stat "wget Centos-7.repo"
	yum clean all &>/dev/null
	yum makecache &>/dev/null
	yum install -y vim-enhanced iproute net-tools util-linux-ng gcc-c++ make cmake libxml2-devel openssl-devel \
		screen git mailx dos2unix lrzsz dstat xinetd rsync tree bind-utils ncurses-devel autoconf automake zlib* fiex* libxml* \
		ntpdate curl wget zip unzip gcc man perl-Net-SSLeay perl-IO-Socket-SSL libmcrypt* libtool-ltdl-devel* \
		dstat tcpdump telnet salt-minion iptables-services bind-utils mtr python-devel &>/dev/null && stat "yum all packages"
}

ntp_date() {
	if [ `grep -c "aliyun.com" /etc/crontab` -eq 0 ];then
		echo "*/5 * * * * root /usr/sbin/ntpdate time1.aliyun.com &>/dev/null" >> /etc/crontab
		ok "add ntpdate"
	else
		fail "add ntpdate"
	fi		
}

ulimt_change() {
cat >> /etc/security/limits.conf <<EOF
root soft nofile 65535
root hard nofile 65535
* soft nproc 65535
* hard nproc 65535
* soft nofile 65535
* hard nofile 65535
EOF
echo "ulimit -SH 65535" >> /etc/rc.local
ulimit -SH 65535
n=`ulimit -n`
if [ $n -eq 65535 ];then
	ok "Ulimit: 65535"
else
	fail "ulimit: 65535"
fi
}

#shutdown_service() {
#services=(
#nfs \
#portreserve \
#restorecond \
#rpcgssd \
#rpcsvcgssd \
#rpcidmapd \
#abrt-ccpp \
#abrt-oops \
#abrtd \
#acpid \
#bluetooth \
#dund \
#hidd \
#pand \
#)
#for line in ${services[@]}
#do
#	chkconfig $line off &>/dev/null
#done
#	ok "Shutdown service"
#
#}

add_user() {
read -p "Pls enter your name and password: " name pass
useradd "$name" &>/dev/null
echo "$pass" | passwd "$name" --stdin &>/dev/null
usermod -G wheel $name
cat > /etc/pam.d/su << EOF
#%PAM-1.0
auth            sufficient      pam_rootok.so
# Uncomment the following line to implicitly trust users in the "wheel" group.
auth            sufficient      pam_wheel.so trust use_uid
# Uncomment the following line to require a user to be in the "wheel" group.
#auth           required        pam_wheel.so use_uid
auth            substack        system-auth
auth            include         postlogin
account         sufficient      pam_succeed_if.so uid = 0 use_uid quiet
account         include         system-auth
password        include         system-auth
session         include         system-auth
session         include         postlogin
session         optional        pam_xauth.so
EOF
stat=$(grep -v "^#" /etc/pam.d/su | grep ^auth | grep "trust use_uid" | wc -l)
if [ $stat -eq 1 ];then
	ok "add: $name"
else
	fail "add: $name"
fi
}

optimize_ssh() {
read -p "pls enter ssh port: " port
echo "Port $port" >> /etc/ssh/sshd_config
sed -i 's/#UseDNS yes/UseDNS no/g' /etc/ssh/sshd_config &>/dev/null
sed -i 's/#PermitEmptyPasswords no/PermitEmptyPasswords no/g' /etc/ssh/sshd_config &>/dev/null
egrep -v "^#|^$" /etc/ssh/sshd_config | grep "$port"
if [ $? -eq 0 ];then
	ok "SSH: $port"
	systemctl restart sshd &>/dev/null
else
	action "SSH: faild" /bin/false
fi
}

bash_mode() {
echo 'PS1="\[\e[37;40m\][\[\e[32;40m\]\u\[\e[37;40m\]@\h \[\e[36;40m\]\w\[\e[0m\]]\\$ "' >> /root/.bashrc
source /root/.bashrc && stat "bash mode"
}

history_message() {
export PROMPT_COMMAND=\
'{ msg=$(history 1 | { read x y ; echo $y ;});\
logger "[euid=$(whoami)]":$(who am i):[`pwd`]" $msg";}'
stat "history: message"
}

sysctl_optimize() {
sed -i 's/net.ipv4.tcp_syncookies.*$/net.ipv4.tcp_syncookies = 1/g' /etc/sysctl.conf &>/dev/null
cat >> /etc/sysctl.conf << ENDF
net.ipv4.tcp_max_syn_backlog = 65536
net.core.netdev_max_backlog =  32768
net.core.somaxconn = 32768
net.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216
net.ipv4.tcp_timestamps = 0
net.ipv4.tcp_synack_retries = 2
net.ipv4.tcp_syn_retries = 2
net.ipv4.tcp_tw_recycle = 1
#net.ipv4.tcp_tw_len = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_mem = 94500000 915000000 927000000
net.ipv4.tcp_max_orphans = 3276800
net.ipv4.ip_local_port_range = 1024  65535
ENDF
sysctl -p &>/dev/null && stat "add: sysctl"
}

iptables_add() {
port=$(grep "^Port" /etc/ssh/sshd_config | awk '{print $2}')
if [ $port != 22 ];then
	sed -i "/dport 22/a\-A INPUT -p tcp -m state --state NEW -m tcp --dport $port -j ACCEPT" /etc/sysconfig/iptables
	sed -i "/dport 22/d"  /etc/sysconfig/iptables
	systemctl restart iptables &>/dev/null && stat "iptables"
fi
}

other_optimize() {
echo "alias net-pf-10 off" >> /etc/modprobe.conf && stat "modprobe net-pf-10 off"
echo "alias ipv6 off" >> /etc/modprobe.conf && stat "ipv6 off"
sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config && stat "selinux off"
echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all && stat "icmp off"
}

menu_list ( ) {
   echo "#########################################"
   echo "#            系统安全选项               #"
   echo "#########################################"
   echo "   [ 0 ]   默认所有安全设置               "  
   echo "   [ 1 ]   检测网络                       "  
   echo "   [ 2 ]   设置主机名                     "  
   echo "   [ 3 ]   更换yum源                      "  
   echo "   [ 4 ]   时间同步                       "  
   echo "   [ 5 ]   文件打开数修改                 "  
   echo "   [ 6 ]   添加普通用户                   "  
   echo "   [ 7 ]   优化ssh链接慢问题              "  
   echo "   [ 8 ]   修改bash提示符                 "
   echo "   [ 9 ]   记录命令到messages中           "
   echo "   [ 10 ]   优化内核参数                   "
   echo "   [ 11 ]   放通ssh登陆端口                "
   echo "   [ 12 ]   其他一些配置                   "
   echo "   [ 13 ]   退出配置选项                   "  
   echo "##########################################"
   read  -p  "请输入您的选择【0-13】:" number;
   }

menu() {
while [ 1 -eq 1 ]
do
    menu_list;
    case $number in
    0)
       set_all;;
    1)
       network_chk;;
    2)
       HostName;;
    3)
       yum_update;;
    4)
       ntp_date;;
    5)
       ulimt_change;;
    6)
       add_user;;
    7)
       optimize_ssh;;    
    8)
       bash_mode;;
    9)
       history_message;;
    10)
       sysctl_optimize;;
    11)
       iptables_add;;
    12)
       other_optimize;;
   13)
      break;;
   esac
done
}
helplist(){
    echo " 使用menu选项 打开菜单 选择安装项 ";
    echo " 使用all选项  默认安装 所有安全项 ";
    echo " 使用向导 sh safe.sh menu ";
}

setall() {
   if [ -z $1 ]
   then
      echo "参数错误"
      helplist;
   elif [ $1 = "menu" ]
   then 
       menu;
   elif [ $1 = "all" ]
   then  
       set_all;
   fi
}

setall $1  
赞(8)
未经允许不得转载:工具盒子 » centos7系统安全配置脚本