mirror of
https://github.com/raymond999999/shell.git
synced 2026-03-12 17:51:35 +08:00
Changes to the reset_openeuler script on December 10, 2024
This commit is contained in:
@@ -1,688 +0,0 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
#**********************************************************************************
|
||||
#Author: Raymond
|
||||
#QQ: 88563128
|
||||
#Date: 2024-12-10
|
||||
#FileName: reset_anolisos.sh
|
||||
#MIRROR: raymond.blog.csdn.net
|
||||
#Description: The reset linux system initialization script supports
|
||||
# “Anolis OS 8.9 and 23“ operating systems.
|
||||
#Copyright (C): 2024 All rights reserved
|
||||
#**********************************************************************************
|
||||
COLOR="echo -e \\033[01;31m"
|
||||
END='\033[0m'
|
||||
|
||||
os(){
|
||||
OS_ID=`sed -rn '/^NAME=/s@.*="([[:alpha:]]+).*"$@\1@p' /etc/os-release`
|
||||
OS_RELEASE=`sed -rn '/^VERSION_ID=/s@.*="?([0-9.]+)"?@\1@p' /etc/os-release`
|
||||
OS_RELEASE_VERSION=`sed -rn '/^VERSION_ID=/s@.*="?([0-9]+)\.?.*"?@\1@p' /etc/os-release`
|
||||
}
|
||||
|
||||
check_ip(){
|
||||
local IP=$1
|
||||
VALID_CHECK=$(echo ${IP}|awk -F. '$1<=255&&$2<=255&&$3<=255&&$4<=255{print "yes"}')
|
||||
if echo ${IP}|grep -E "^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$" >/dev/null; then
|
||||
if [ ${VALID_CHECK} == "yes" ]; then
|
||||
echo "IP ${IP} available!"
|
||||
return 0
|
||||
else
|
||||
echo "IP ${IP} not available!"
|
||||
return 1
|
||||
fi
|
||||
else
|
||||
echo "IP format error!"
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
set_network(){
|
||||
ETHNAME=`ip addr | awk -F"[ :]" '/^2/{print $3}'`
|
||||
CONNECTION_NAME=`nmcli dev | awk 'NR==2{print $4,$5,$6}'`
|
||||
while true; do
|
||||
read -p "请输入IP地址: " IP
|
||||
check_ip ${IP}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
read -p "请输入子网掩码位数: " PREFIX
|
||||
while true; do
|
||||
read -p "请输入网关地址: " GATEWAY
|
||||
check_ip ${GATEWAY}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
while true; do
|
||||
read -p "请输入主DNS地址(例如:阿里:223.5.5.5,腾讯:119.29.29.29,公共:114.114.114.114,google:8.8.8.8等): " PRIMARY_DNS
|
||||
check_ip ${PRIMARY_DNS}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
while true; do
|
||||
read -p "请输入备用DNS地址(例如:阿里:223.6.6.6,腾讯:119.28.28.28,公共:114.114.115.115,google:8.8.4.4等): " BACKUP_DNS
|
||||
check_ip ${BACKUP_DNS}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 网络已设置成功,请使用新IP重新登录!"${END}
|
||||
nmcli connection delete ${ETHNAME} >& /dev/null && \
|
||||
nmcli connection add type ethernet con-name ${ETHNAME} ifname ${ETHNAME} ipv4.method manual ipv4.address "${IP}/${PREFIX}" ipv4.gateway "${GATEWAY}" ipv4.dns "${PRIMARY_DNS},${BACKUP_DNS}" autoconnect yes >& /dev/null && \
|
||||
nmcli con reload && nmcli dev up ${ETHNAME} >& /dev/null
|
||||
}
|
||||
|
||||
set_dual_network(){
|
||||
ETHNAME=`ip addr | awk -F"[ :]" '/^2/{print $3}'`
|
||||
ETHNAME2=`ip addr | awk -F"[ :]" '/^3/{print $3}'`
|
||||
CONNECTION_NAME1=`nmcli dev | awk 'NR==2{print $4,$5,$6}'`
|
||||
CONNECTION_NAME2=`nmcli dev | awk 'NR==3{print $4,$5,$6}'`
|
||||
while true; do
|
||||
read -p "请输入第一块网卡IP地址: " IP
|
||||
check_ip ${IP}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
read -p "请输入子网掩码位数: " PREFIX
|
||||
while true; do
|
||||
read -p "请输入网关地址: " GATEWAY
|
||||
check_ip ${GATEWAY}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
while true; do
|
||||
read -p "请输入主DNS地址(例如:阿里:223.5.5.5,腾讯:119.29.29.29,公共:114.114.114.114,google:8.8.8.8等): " PRIMARY_DNS
|
||||
check_ip ${PRIMARY_DNS}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
while true; do
|
||||
read -p "请输入备用DNS地址(例如:阿里:223.6.6.6,腾讯:119.28.28.28,公共:114.114.115.115,google:8.8.4.4等): " BACKUP_DNS
|
||||
check_ip ${BACKUP_DNS}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
while true; do
|
||||
read -p "请输入第二块网卡IP地址: " IP2
|
||||
check_ip ${IP2}
|
||||
[ $? -eq 0 ] && break
|
||||
done
|
||||
read -p "请输入子网掩码位数: " PREFIX2
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 网络已设置成功,请使用新IP重新登录!"${END}
|
||||
nmcli connection delete ${ETHNAME} >& /dev/null && \
|
||||
nmcli connection add type ethernet con-name ${ETHNAME} ifname ${ETHNAME} ipv4.method manual ipv4.address "${IP}/${PREFIX}" ipv4.gateway "${GATEWAY}" ipv4.dns "${PRIMARY_DNS},${BACKUP_DNS}" autoconnect yes >& /dev/null && \
|
||||
nmcli connection modify "${CONNECTION_NAME2}" con-name ${ETHNAME2} && nmcli connection delete ${ETHNAME2} >& /dev/null && \
|
||||
nmcli connection add type ethernet con-name ${ETHNAME2} ifname ${ETHNAME2} ipv4.method manual ipv4.address "${IP2}/${PREFIX2}" autoconnect yes >& /dev/null && \
|
||||
nmcli con reload && nmcli dev up ${ETHNAME} ${ETHNAME2} >& /dev/null
|
||||
}
|
||||
|
||||
set_hostname(){
|
||||
read -p "请输入主机名: " HOST
|
||||
hostnamectl set-hostname ${HOST}
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 主机名设置成功,请重新登录生效!"${END}
|
||||
}
|
||||
|
||||
aliyun(){
|
||||
MIRROR=mirrors.aliyun.com
|
||||
}
|
||||
|
||||
nju(){
|
||||
MIRROR=mirrors.nju.edu.cn
|
||||
}
|
||||
|
||||
iscas(){
|
||||
MIRROR=mirror.iscas.ac.cn
|
||||
}
|
||||
|
||||
set_yum(){
|
||||
OLD_MIRROR=$(awk -F'/' '/^baseurl=/{print $3}' /etc/yum.repos.d/AnolisOS*.repo | head -1)
|
||||
OLD_MIRROR_URL=`echo ${OLD_MIRROR} | awk -F"." '{print $2}'`
|
||||
if [ ${OLD_MIRROR_URL} == "openanolis" ];then
|
||||
sed -i.bak -e 's|http.*://'${OLD_MIRROR}'|https://'${MIRROR}'|g' /etc/yum.repos.d/AnolisOS*.repo
|
||||
else
|
||||
sed -i -e 's|'${OLD_MIRROR}'|'${MIRROR}'|g' /etc/yum.repos.d/AnolisOS*.repo
|
||||
fi
|
||||
${COLOR}"更新镜像源中,请稍等..."${END}
|
||||
dnf clean all &> /dev/null && dnf makecache &> /dev/null
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} YUM源设置完成!"${END}
|
||||
}
|
||||
|
||||
base_menu(){
|
||||
while true;do
|
||||
echo -e "\E[$[RANDOM%7+31];1m"
|
||||
cat <<-EOF
|
||||
1)阿里镜像源
|
||||
2)南京大学镜像源
|
||||
3)中国科学院软件研究所镜像源
|
||||
4)退出
|
||||
EOF
|
||||
echo -e '\E[0m'
|
||||
|
||||
read -p "请输入镜像源编号(1-4): " NUM
|
||||
case ${NUM} in
|
||||
1)
|
||||
aliyun
|
||||
set_yum
|
||||
;;
|
||||
2)
|
||||
nju
|
||||
set_yum
|
||||
;;
|
||||
3)
|
||||
iscas
|
||||
set_yum
|
||||
;;
|
||||
4)
|
||||
break
|
||||
;;
|
||||
*)
|
||||
${COLOR}"输入错误,请输入正确的数字(1-4)!"${END}
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
minimal_install(){
|
||||
${COLOR}'开始安装“Minimal安装建议安装软件包”,请稍等......'${END}
|
||||
yum -y install gcc make autoconf gcc-c++ glibc glibc-devel pcre pcre-devel openssl openssl-devel systemd-devel zlib-devel vim lrzsz tree tmux lsof tcpdump wget net-tools iotop bc bzip2 zip unzip nfs-utils man-pages &> /dev/null
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} Minimal安装建议安装软件包已安装完成!"${END}
|
||||
}
|
||||
|
||||
disable_firewalls(){
|
||||
rpm -q firewalld &> /dev/null && { systemctl disable --now firewalld &> /dev/null; ${COLOR}"${OS_ID} ${OS_RELEASE} Firewall防火墙已关闭!"${END}; } || ${COLOR}"${OS_ID} ${OS_RELEASE} iptables防火墙已关闭!"${END}
|
||||
}
|
||||
|
||||
disable_selinux(){
|
||||
if [ `getenforce` == "Enforcing" ];then
|
||||
sed -ri.bak 's/^(SELINUX=).*/\1disabled/' /etc/selinux/config
|
||||
setenforce 0
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} SELinux已禁用,请重新启动系统后才能永久生效!"${END}
|
||||
else
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} SELinux已被禁用,不用设置!"${END}
|
||||
fi
|
||||
}
|
||||
|
||||
set_swap(){
|
||||
sed -ri 's/.*swap.*/#&/' /etc/fstab
|
||||
swapoff -a
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 禁用swap成功!"${END}
|
||||
}
|
||||
|
||||
set_localtime(){
|
||||
timedatectl set-timezone Asia/Shanghai
|
||||
echo 'Asia/Shanghai' >/etc/timezone
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 系统时区已设置成功,请重启系统后生效!"${END}
|
||||
}
|
||||
|
||||
set_limits(){
|
||||
cat >> /etc/security/limits.conf <<-EOF
|
||||
root soft core unlimited
|
||||
root hard core unlimited
|
||||
root soft nproc 1000000
|
||||
root hard nproc 1000000
|
||||
root soft nofile 1000000
|
||||
root hard nofile 1000000
|
||||
root soft memlock 32000
|
||||
root hard memlock 32000
|
||||
root soft msgqueue 8192000
|
||||
root hard msgqueue 8192000
|
||||
EOF
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 优化资源限制参数成功!"${END}
|
||||
}
|
||||
|
||||
set_kernel(){
|
||||
modprobe br_netfilter
|
||||
cat > /etc/sysctl.conf <<-EOF
|
||||
# Controls source route verification
|
||||
net.ipv4.conf.default.rp_filter = 1
|
||||
net.ipv4.ip_nonlocal_bind = 1
|
||||
net.ipv4.ip_forward = 1
|
||||
|
||||
# Do not accept source routing
|
||||
net.ipv4.conf.default.accept_source_route = 0
|
||||
|
||||
# Controls the System Request debugging functionality of the kernel
|
||||
kernel.sysrq = 0
|
||||
|
||||
# Controls whether core dumps will append the PID to the core filename.
|
||||
# Useful for debugging multi-threaded applications.
|
||||
kernel.core_uses_pid = 1
|
||||
|
||||
# Controls the use of TCP syncookies
|
||||
net.ipv4.tcp_syncookies = 1
|
||||
|
||||
# Disable netfilter on bridges.
|
||||
net.bridge.bridge-nf-call-ip6tables = 0
|
||||
net.bridge.bridge-nf-call-iptables = 0
|
||||
net.bridge.bridge-nf-call-arptables = 0
|
||||
|
||||
# Controls the default maxmimum size of a mesage queue
|
||||
kernel.msgmnb = 65536
|
||||
|
||||
# Controls the maximum size of a message, in bytes
|
||||
kernel.msgmax = 65536
|
||||
|
||||
# Controls the maximum shared segment size, in bytes
|
||||
kernel.shmmax = 68719476736
|
||||
|
||||
# Controls the maximum number of shared memory segments, in pages
|
||||
kernel.shmall = 4294967296
|
||||
|
||||
# TCP kernel paramater
|
||||
net.ipv4.tcp_mem = 786432 1048576 1572864
|
||||
net.ipv4.tcp_rmem = 4096 87380 4194304
|
||||
net.ipv4.tcp_wmem = 4096 16384 4194304
|
||||
net.ipv4.tcp_window_scaling = 1
|
||||
net.ipv4.tcp_sack = 1
|
||||
|
||||
# socket buffer
|
||||
net.core.wmem_default = 8388608
|
||||
net.core.rmem_default = 8388608
|
||||
net.core.rmem_max = 16777216
|
||||
net.core.wmem_max = 16777216
|
||||
net.core.netdev_max_backlog = 262144
|
||||
net.core.somaxconn = 20480
|
||||
net.core.optmem_max = 81920
|
||||
|
||||
# TCP conn
|
||||
net.ipv4.tcp_max_syn_backlog = 262144
|
||||
net.ipv4.tcp_syn_retries = 3
|
||||
net.ipv4.tcp_retries1 = 3
|
||||
net.ipv4.tcp_retries2 = 15
|
||||
|
||||
# tcp conn reuse
|
||||
net.ipv4.tcp_tw_reuse = 1
|
||||
net.ipv4.tcp_fin_timeout = 30
|
||||
net.ipv4.tcp_timestamps = 0
|
||||
|
||||
net.ipv4.tcp_max_tw_buckets = 20000
|
||||
net.ipv4.tcp_max_orphans = 3276800
|
||||
net.ipv4.tcp_synack_retries = 1
|
||||
net.ipv4.tcp_syncookies = 1
|
||||
|
||||
# keepalive conn
|
||||
net.ipv4.tcp_keepalive_time = 300
|
||||
net.ipv4.tcp_keepalive_intvl = 30
|
||||
net.ipv4.tcp_keepalive_probes = 3
|
||||
net.ipv4.ip_local_port_range = 10001 65000
|
||||
|
||||
# swap
|
||||
vm.overcommit_memory = 0
|
||||
vm.swappiness = 10
|
||||
|
||||
#net.ipv4.conf.eth1.rp_filter = 0
|
||||
#net.ipv4.conf.lo.arp_ignore = 1
|
||||
#net.ipv4.conf.lo.arp_announce = 2
|
||||
#net.ipv4.conf.all.arp_ignore = 1
|
||||
#net.ipv4.conf.all.arp_announce = 2
|
||||
EOF
|
||||
MAIN_KERNEL=`uname -r | cut -d. -f1`
|
||||
SUB_KERNEL=`uname -r | cut -d. -f2`
|
||||
if [ ${MAIN_KERNEL} -lt "4" -a ${SUB_KERNEL} -lt "12" ];then
|
||||
cat >> /etc/sysctl.conf <<-EOF
|
||||
net.ipv4.tcp_tw_recycle = 0
|
||||
EOF
|
||||
fi
|
||||
sysctl -p &> /dev/null
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 优化内核参数成功!"${END}
|
||||
}
|
||||
|
||||
optimization_ssh(){
|
||||
sed -ri.bak -e 's/^#(UseDNS).*/\1 no/' -e 's/^(GSSAPIAuthentication).*/\1 no/' /etc/ssh/sshd_config
|
||||
systemctl restart sshd
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} SSH已优化完成!"${END}
|
||||
}
|
||||
|
||||
set_ssh_port(){
|
||||
disable_selinux
|
||||
disable_firewalls
|
||||
read -p "请输入端口号: " PORT
|
||||
sed -i 's/#Port 22/Port '${PORT}'/' /etc/ssh/sshd_config
|
||||
systemctl restart sshd
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 更改SSH端口号已完成,请重新登陆后生效!"${END}
|
||||
}
|
||||
|
||||
set_base_alias(){
|
||||
ETHNAME=`ip addr | awk -F"[ :]" '/^2/{print $3}'`
|
||||
ETHNAME2=`ip addr | awk -F"[ :]" '/^3/{print $3}'`
|
||||
IP_NUM=`ip addr | awk -F"[: ]" '{print $1}' | grep -v '^$' | wc -l`
|
||||
if [ ${IP_NUM} == "2" ];then
|
||||
if [ ${OS_RELEASE_VERSION} == "8" ];then
|
||||
cat >>~/.bashrc <<-EOF
|
||||
alias cdnet="cd /etc/sysconfig/network-scripts"
|
||||
alias cdrepo="cd /etc/yum.repos.d"
|
||||
alias vie0="vim /etc/sysconfig/network-scripts/ifcfg-${ETHNAME}"
|
||||
EOF
|
||||
else
|
||||
cat >>~/.bashrc <<-EOF
|
||||
alias cdnet="cd /etc/NetworkManager/system-connections"
|
||||
alias cdrepo="cd /etc/yum.repos.d"
|
||||
alias vie0="vim /etc/NetworkManager/system-connections/${ETHNAME}.nmconnection"
|
||||
EOF
|
||||
fi
|
||||
else
|
||||
if [ -o ${OS_RELEASE_VERSION} == "8" ];then
|
||||
cat >>~/.bashrc <<-EOF
|
||||
alias cdnet="cd /etc/sysconfig/network-scripts"
|
||||
alias cdrepo="cd /etc/yum.repos.d"
|
||||
alias vie0="vim /etc/sysconfig/network-scripts/ifcfg-${ETHNAME}"
|
||||
alias vie1="vim /etc/sysconfig/network-scripts/ifcfg-${ETHNAME2}"
|
||||
EOF
|
||||
else
|
||||
cat >>~/.bashrc <<-EOF
|
||||
alias cdnet="cd /etc/NetworkManager/system-connections"
|
||||
alias cdrepo="cd /etc/yum.repos.d"
|
||||
alias vie0="vim /etc/NetworkManager/system-connections/${ETHNAME}.nmconnection"
|
||||
alias vie1="vim /etc/NetworkManager/system-connections/${ETHNAME2}.nmconnection"
|
||||
EOF
|
||||
fi
|
||||
fi
|
||||
DISK_NAME=`lsblk|awk -F" " '/disk/{printf $1}' | cut -c1-4`
|
||||
if [ ${DISK_NAME} == "sda" ];then
|
||||
cat >>~/.bashrc <<-EOF
|
||||
alias scandisk="echo '- - -' > /sys/class/scsi_host/host0/scan;echo '- - -' > /sys/class/scsi_host/host1/scan;echo '- - -' > /sys/class/scsi_host/host2/scan"
|
||||
EOF
|
||||
fi
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 系统别名已设置成功,请重新登陆后生效!"${END}
|
||||
}
|
||||
|
||||
set_alias(){
|
||||
if grep -Eqi "(.*cdnet|.*cdrepo|.*vie0|.*vie1|.*scandisk)" ~/.bashrc;then
|
||||
sed -i -e '/.*cdnet/d' -e '/.*cdrepo/d' -e '/.*vie0/d' -e '/.*vie1/d' -e '/.*scandisk/d' ~/.bashrc
|
||||
set_base_alias
|
||||
else
|
||||
set_base_alias
|
||||
fi
|
||||
}
|
||||
|
||||
set_vimrc(){
|
||||
read -p "请输入作者名: " AUTHOR
|
||||
read -p "请输入QQ号: " QQ
|
||||
read -p "请输入网址: " V_MIRROR
|
||||
cat >~/.vimrc <<-EOF
|
||||
set ts=4
|
||||
set expandtab
|
||||
set ignorecase
|
||||
set cursorline
|
||||
set autoindent
|
||||
autocmd BufNewFile *.sh exec ":call SetTitle()"
|
||||
func SetTitle()
|
||||
if expand("%:e") == 'sh'
|
||||
call setline(1,"#!/bin/bash")
|
||||
call setline(2,"#")
|
||||
call setline(3,"#*********************************************************************************************")
|
||||
call setline(4,"#Author: ${AUTHOR}")
|
||||
call setline(5,"#QQ: ${QQ}")
|
||||
call setline(6,"#Date: ".strftime("%Y-%m-%d"))
|
||||
call setline(7,"#FileName: ".expand("%"))
|
||||
call setline(8,"#MIRROR: ${V_MIRROR}")
|
||||
call setline(9,"#Description: The test script")
|
||||
call setline(10,"#Copyright (C): ".strftime("%Y")." All rights reserved")
|
||||
call setline(11,"#*********************************************************************************************")
|
||||
call setline(12,"")
|
||||
endif
|
||||
endfunc
|
||||
autocmd BufNewFile * normal G
|
||||
EOF
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} vimrc设置完成,请重新系统启动才能生效!"${END}
|
||||
}
|
||||
|
||||
set_mail(){
|
||||
rpm -q postfix &> /dev/null || { ${COLOR}"安装postfix服务,请稍等..."${END};yum -y install postfix &> /dev/null; systemctl enable --now postfix &> /dev/null; }
|
||||
rpm -q mailx &> /dev/null || { ${COLOR}"安装mailx服务,请稍等..."${END};yum -y install mailx &> /dev/null; }
|
||||
read -p "请输入邮箱地址: " MAIL
|
||||
read -p "请输入邮箱授权码: " AUTH
|
||||
SMTP=`echo ${MAIL} |awk -F"@" '{print $2}'`
|
||||
cat >~/.mailrc <<-EOF
|
||||
set from=${MAIL}
|
||||
set smtp=smtp.${SMTP}
|
||||
set smtp-auth-user=${MAIL}
|
||||
set smtp-auth-password=${AUTH}
|
||||
set smtp-auth=login
|
||||
set ssl-verify=ignore
|
||||
EOF
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 邮件设置完成,请重新登录后才能生效!"${END}
|
||||
}
|
||||
|
||||
red(){
|
||||
P_COLOR=31
|
||||
}
|
||||
|
||||
green(){
|
||||
P_COLOR=32
|
||||
}
|
||||
|
||||
yellow(){
|
||||
P_COLOR=33
|
||||
}
|
||||
|
||||
blue(){
|
||||
P_COLOR=34
|
||||
}
|
||||
|
||||
violet(){
|
||||
P_COLOR=35
|
||||
}
|
||||
|
||||
cyan_blue(){
|
||||
P_COLOR=36
|
||||
}
|
||||
|
||||
random_color(){
|
||||
P_COLOR="$[RANDOM%7+31]"
|
||||
}
|
||||
|
||||
set_base_ps1(){
|
||||
C_PS1=$(echo "PS1='\[\e[1;${P_COLOR}m\][\u@\h \W]\\$ \[\e[0m\]'" >> ~/.bashrc)
|
||||
}
|
||||
|
||||
set_ps1_env(){
|
||||
if grep -Eqi "^PS1" ~/.bashrc;then
|
||||
sed -i '/^PS1/d' ~/.bashrc
|
||||
set_base_ps1
|
||||
else
|
||||
set_base_ps1
|
||||
fi
|
||||
}
|
||||
|
||||
set_ps1(){
|
||||
TIPS="${COLOR}${OS_ID} ${OS_RELEASE} PS1设置成功,请重新登录生效!${END}"
|
||||
while true;do
|
||||
echo -e "\E[$[RANDOM%7+31];1m"
|
||||
cat <<-EOF
|
||||
1)31 红色
|
||||
2)32 绿色
|
||||
3)33 黄色
|
||||
4)34 蓝色
|
||||
5)35 紫色
|
||||
6)36 青色
|
||||
7)随机颜色
|
||||
8)退出
|
||||
EOF
|
||||
echo -e '\E[0m'
|
||||
|
||||
read -p "请输入颜色编号(1-8): " NUM
|
||||
case ${NUM} in
|
||||
1)
|
||||
red
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
2)
|
||||
green
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
3)
|
||||
yellow
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
4)
|
||||
blue
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
5)
|
||||
violet
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
6)
|
||||
cyan_blue
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
7)
|
||||
random_color
|
||||
set_ps1_env
|
||||
${TIPS}
|
||||
;;
|
||||
8)
|
||||
break
|
||||
;;
|
||||
*)
|
||||
${COLOR}"输入错误,请输入正确的数字(1-8)!"${END}
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
set_vim(){
|
||||
echo "export EDITOR=vim" >> ~/.bashrc
|
||||
}
|
||||
|
||||
set_vim_env(){
|
||||
if grep -Eqi ".*EDITOR" ~/.bashrc;then
|
||||
sed -i '/.*EDITOR/d' ~/.bashrc
|
||||
set_vim
|
||||
else
|
||||
set_vim
|
||||
fi
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 默认文本编辑器设置成功,请重新登录生效!"${END}
|
||||
}
|
||||
|
||||
set_history(){
|
||||
echo 'export HISTTIMEFORMAT="%F %T "' >> ~/.bashrc
|
||||
}
|
||||
|
||||
set_history_env(){
|
||||
if grep -Eqi ".*HISTTIMEFORMAT" ~/.bashrc;then
|
||||
sed -i '/.*HISTTIMEFORMAT/d' ~/.bashrc
|
||||
set_history
|
||||
else
|
||||
set_history
|
||||
fi
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} history格式设置成功,请重新登录生效!"${END}
|
||||
}
|
||||
|
||||
disable_restart(){
|
||||
if [ -f /usr/lib/systemd/system/ctrl-alt-del.target ];then
|
||||
cp /usr/lib/systemd/system/ctrl-alt-del.target{,.bak}
|
||||
rm -f /usr/lib/systemd/system/ctrl-alt-del.target
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 禁用ctrl+alt+del重启处理成功!"${END}
|
||||
else
|
||||
${COLOR}"${OS_ID} ${OS_RELEASE} 禁用ctrl+alt+del已处理!"${END}
|
||||
fi
|
||||
}
|
||||
|
||||
menu(){
|
||||
while true;do
|
||||
echo -e "\E[$[RANDOM%7+31];1m"
|
||||
cat <<-EOF
|
||||
*********************************************************
|
||||
* 系统初始化脚本菜单 *
|
||||
* 1.设置网络(单网卡) 13.更改SSH端口号 *
|
||||
* 2.设置网络(双网卡) 14.设置系统别名 *
|
||||
* 3.设置主机名 15.设置vimrc配置文件 *
|
||||
* 4.设置镜像仓库 16.安装邮件服务并配置邮件 *
|
||||
* 5.Minimal安装建议安装软件 17.设置PS1(请进入选择颜色 *
|
||||
* 6.关闭防火墙 18.设置默认文本编辑器为vim *
|
||||
* 7.禁用SELinux 19.设置history格式 *
|
||||
* 8.禁用SWAP 20.禁用ctrl+alt+del重启 *
|
||||
* 9.设置系统时区 21.重启系统 *
|
||||
* 10.优化资源限制参数 22.关机 *
|
||||
* 11.优化内核参数 23.退出 *
|
||||
* 12.优化SSH *
|
||||
*********************************************************
|
||||
EOF
|
||||
echo -e '\E[0m'
|
||||
|
||||
read -p "请选择相应的编号(1-23): " choice
|
||||
case ${choice} in
|
||||
1)
|
||||
set_network
|
||||
;;
|
||||
2)
|
||||
set_dual_network
|
||||
;;
|
||||
3)
|
||||
set_hostname
|
||||
;;
|
||||
4)
|
||||
base_menu
|
||||
;;
|
||||
5)
|
||||
minimal_install
|
||||
;;
|
||||
6)
|
||||
disable_firewalls
|
||||
;;
|
||||
7)
|
||||
disable_selinux
|
||||
;;
|
||||
8)
|
||||
set_swap
|
||||
;;
|
||||
9)
|
||||
set_localtime
|
||||
;;
|
||||
10)
|
||||
set_limits
|
||||
;;
|
||||
11)
|
||||
set_kernel
|
||||
;;
|
||||
12)
|
||||
optimization_ssh
|
||||
;;
|
||||
13)
|
||||
set_ssh_port
|
||||
;;
|
||||
14)
|
||||
set_alias
|
||||
;;
|
||||
15)
|
||||
set_vimrc
|
||||
;;
|
||||
16)
|
||||
set_mail
|
||||
;;
|
||||
17)
|
||||
set_ps1
|
||||
;;
|
||||
18)
|
||||
set_vim_env
|
||||
;;
|
||||
19)
|
||||
set_history_env
|
||||
;;
|
||||
20)
|
||||
disable_restart
|
||||
;;
|
||||
21)
|
||||
reboot
|
||||
;;
|
||||
22)
|
||||
shutdown -h now
|
||||
;;
|
||||
23)
|
||||
break
|
||||
;;
|
||||
*)
|
||||
${COLOR}"输入错误,请输入正确的数字(1-23)!"${END}
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
main(){
|
||||
os
|
||||
if [ ${OS_ID} == "Anolis" ];then
|
||||
menu
|
||||
else
|
||||
${COLOR}"此脚本不支持${OS_ID} ${OS_RELEASE} 系统!"${END}
|
||||
fi
|
||||
}
|
||||
|
||||
main
|
||||
Reference in New Issue
Block a user