代码拉取完成,页面将自动刷新
#!/bin/bash
#author: Sen Du
#email: dusen.me@gmail.com
#created: 2023-04-16 10:00:00
#updated: 2023-05-06 18:00:00
set -e
source 00_env
# 安装一些基础软件,便于后续操作
function install_base() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
system_version=$(ssh -n $ipaddr "cat /etc/centos-release | sed 's/ //g'")
echo -e "$CSTART>>>>$ipaddr>$system_version$CEND"
if [[ "$system_version" == RockyLinuxrelease8* ]]; then
scp rpms/rocky8/epel-release-8-19.el8.noarch.rpm $ipaddr:/tmp/
scp rpms/rocky8/htop-3.2.1-1.el8.x86_64.rpm $ipaddr:/tmp/
scp rpms/rocky8/iotop-0.6-17.el8.noarch.rpm $ipaddr:/tmp/
ssh -n $ipaddr "rpm -Uvh /tmp/epel-release-8-19.el8.noarch.rpm" || true
ssh -n $ipaddr "rpm -Uvh /tmp/htop-3.2.1-1.el8.x86_64.rpm" || true
ssh -n $ipaddr "rpm -Uvh /tmp/iotop-0.6-17.el8.noarch.rpm" || true
ssh -n $ipaddr "rm -rf /etc/yum.repos.d/epel*"
ssh -n $ipaddr "yum install -y vim wget net-tools" || true
elif [[ "$system_version" == CentOSLinuxrelease7* ]]; then
scp rpms/centos7/epel-release-7-14.noarch.rpm $ipaddr:/tmp/
scp rpms/centos7/htop-2.2.0-3.el7.x86_64.rpm $ipaddr:/tmp/
scp rpms/centos7/iotop-0.6-4.el7.noarch.rpm $ipaddr:/tmp/
ssh -n $ipaddr "rpm -Uvh /tmp/epel-release-7-14.noarch.rpm" || true
ssh -n $ipaddr "rpm -Uvh /tmp/htop-2.2.0-3.el7.x86_64.rpm" || true
ssh -n $ipaddr "rpm -Uvh /tmp/iotop-0.6-4.el7.noarch.rpm" || true
ssh -n $ipaddr "rm -rf /etc/yum.repos.d/epel*"
ssh -n $ipaddr "yum install -y vim wget net-tools" || true
else
echo "系统版本[$system_version]超出脚本处理范围" && false
fi
done
}
# 备份一些配置文件
function backup_configs() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "mkdir -p /opt/backup/configs_$(date '+%Y%m%d')"
done
}
# 设置时区为 Asia/Shanghai
function set_timezone() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
# 创建时区软链接
ssh -n $ipaddr "ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime" || true
# 如果软链接已经存在,修改它,避免第一步失败
ssh -n $ipaddr "ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime"
done
}
# 禁用 hugepage
function disable_hugepage() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "grubby --update-kernel=ALL --args='transparent_hugepage=never'"
ssh -n $ipaddr "sed -i '/^#RemoveIPC=no/cRemoveIPC=no' /etc/systemd/logind.conf"
ssh -n $ipaddr "systemctl restart systemd-logind.service"
done
}
# 关闭 selinux
function disable_selinux() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "cp /etc/selinux/config /opt/backup/configs_$(date '+%Y%m%d')/etc_selinux_config"
ssh -n $ipaddr "sed -i '/^SELINUX=/cSELINUX=disabled' /etc/selinux/config"
ssh -n $ipaddr "setenforce 0" || true
done
}
# 配置 ssh
function config_ssh() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "cp /etc/ssh/sshd_config /opt/backup/configs_$(date '+%Y%m%d')/etc_ssh_sshd_config"
ssh -n $ipaddr "sed -i '/^#UseDNS/cUseDNS no' /etc/ssh/sshd_config"
ssh -n $ipaddr "sed -i '/^GSSAPIAuthentication/cGSSAPIAuthentication no' /etc/ssh/sshd_config"
ssh -n $ipaddr "sed -i '/^GSSAPICleanupCredentials/cGSSAPICleanupCredentials no' /etc/ssh/sshd_config"
ssh -n $ipaddr "sed -i '/^#MaxStartups/cMaxStartups 10000:30:20000' /etc/ssh/sshd_config"
ssh -n $ipaddr "systemctl restart sshd || service sshd restart" || true
done
}
# 配置网络策略
function config_network() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "chkconfig iptables off; chkconfig ip6tables off; chkconfig postfix off" || true
ssh -n $ipaddr "systemctl disable postfix; systemctl disable libvirtd; systemctl disable firewalld" || true
ssh -n $ipaddr "systemctl stop postfix; systemctl stop libvirtd; systemctl stop firewalld" || true
done
}
# 调优 sysctl
function config_sysctl() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "cp /etc/sysctl.conf /opt/backup/configs_$(date '+%Y%m%d')"
scp config/sysctl.conf $ipaddr:/etc/sysctl.conf
ssh -n $ipaddr "sysctl -p"
done
}
# 调优 limits
function config_limits() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "cp /etc/security/limits.conf /opt/backup/configs_$(date '+%Y%m%d')"
scp config/limits.conf $ipaddr:/etc/security/limits.conf
done
}
# 关闭 swap
function disable_swap() {
cat config/vm_info | grep -v "^#" | grep -v "^$" | while read ipaddr name passwd
do
echo -e "$CSTART>>>>$ipaddr [$(date +'%Y-%m-%d %H:%M:%S')]$CEND"
ssh -n $ipaddr "cp /etc/fstab /opt/backup/configs_$(date '+%Y%m%d')"
ssh -n $ipaddr "sed -i '/swap / s/^\(.*\)$/#\1/g' /etc/fstab"
ssh -n $ipaddr "swapoff -a"
done
}
function main() {
echo -e "$CSTART>03_init.sh$CEND"
echo -e "$CSTART>>install_base$CEND"
install_base
echo -e "$CSTART>>backup_configs$CEND"
backup_configs
echo -e "$CSTART>>set_timezone$CEND"
set_timezone
echo -e "$CSTART>>disable_hugepage$CEND"
disable_hugepage || true
echo -e "$CSTART>>disable_selinux$CEND"
disable_selinux
echo -e "$CSTART>>config_ssh$CEND"
config_ssh
echo -e "$CSTART>>config_network$CEND"
config_network
echo -e "$CSTART>>config_sysctl$CEND"
config_sysctl
echo -e "$CSTART>>config_limits$CEND"
config_limits
echo -e "$CSTART>>disable_swap$CEND"
disable_swap
}
main
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。