企业生产环境Shell脚本案例分享

对于初学者而言,因为没有实战经验,写不出来 很正常,如果工作了几年的运维老年还是写不出来,那就是没主动找需求,缺乏练习,缺乏经验,本篇文章重点为大家讲解一下企业生产环境Shell脚本案例。

1、MySQL数据库备份脚本,下面的脚本是Mysql全量备份+异地备份

一般Mysql数据库备份会采用在MYSQL从库上执行全量备份+增量备份方式。在从库备份避免Mysql主库备份的时候锁表造成业务影响。

shell> vim db_backup.sh

#!/bin/bash  # description:  MySQL buckup shell script  # author:       magedu.com# 192.168.10.10 为专门的备份服务器,需要做一下服务器之间免密码登录#备份的数据库名
DATABASES=(
           "magedu01"
           "magedu02"                    
)
USER="root"
PASSWORD="dbpwd123"

MAIL="[email protected]"  
BACKUP_DIR=/data/backup
LOGFILE=/data/backup/data_backup.log  
DATE=`date +%Y%m%d_%H%M`

cd $BACKUP_DIR#开始备份之前,将备份信息头写入日记文件    echo "--------------------" >> $LOGFILE    
echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE    
echo "-------------------" >> $LOGFILEfor DATABASE in ${DATABASES};do
 /usr/local/mysql/bin/mysqldump -u$USER -p$PASSWORD --events  -R --opt  $DATABASE |gzip >${BACKUP_DIR}\/${DATABASE}_${DATE}.sql.gz
 if [ $? == 0 ];then
   echo "$DATE--$DATABASE is backup succeed" >> $LOGFILE
 else
   echo "Database Backup Fail!" >> $LOGFILE    
done#判断数据库备份是否全部成功,全部成功就同步到异地备份f服务器if [ $? == 0 ];then
 /usr/bin/rsync -zrtopg   --delete  /data/backup/* [email protected]:/data/backup/  >/dev/null 2>&1
else
 echo "Database Backup Fail!" >> $LOGFILE    
 #备份失败后向管理者发送邮件提醒
 mail -s "database Daily Backup Fail!" $MAIL    
fi#删除30天以上的备份文件  
find $BACKUP_DIR  -type f -mtime +30 -name "*.gz" -exec rm -f {} \;
1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.

2、Nginx负载均衡服务器上监控Nginx进程的脚本

企业负载均衡层如果用到Nginx+Keepalived架构,而Keepalived无法进行Nginx服务的实时切换,所以这里用了一个监控脚本check_nginx_pid.sh,每隔5秒就监控一次Nginx的运行状态,如果发现有问题就关闭本机的Keepalived程序,让VIP切换到从Nginx负载均衡器上。

shell> vim check_nginx_pid.sh

#!/bin/bashwhile :
do
nginxpid='ps -C nginx --no-header | wc -l'if [$nginxpid -eq 0 ];then
  ulimit -SHn 65535
  /usr/local/nginx/sbin/nginx
sleep 5
 nginxpid='ps -C nginx --no-header | wc -l'
 if [$nginxpid -eq 0 ];then
 /etc/init.d/keepalived stop
 fifi
sleep 5
done
1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.

3、MySQL主从监控邮件报警脚本

  • 此脚本应该能适应各种各样不同的内外网环境。
  • 让脚本也顺便监控下MySQL是否正常运行。
  • Slave机器的IO和SQL状态都必须为YES,缺一不可,这里用到了多重条件判断-a。
shell> check_mysql_slave.sh
#!/bin/bash#check MySQL_Slave Status

MYSQLPORT='netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}''
MYSQLIP='ifconfig eth0|grep "inet addr" | awk -F[:" "]+ '{print $4}''
STATUS=$(/usr/local/mysql/bin/mysql -u dbuser -dbpwd123 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running")
IO_env='echo $STATUS | grep IO | awk ' {print $2}''
SQL_env='echo $STATUS | grep SQL | awk '{print $2}''if [ "$MYSQLPORT" == "3306" ]
then
 echo "mysql is running"else
 mail -s "warn!server: $MYSQLIP mysql is down" [email protected]fiif [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ]
then
 echo "Slave is running!"else
 echo "####### $date #########">> /data/log/check_mysql_slave.log
 echo "Slave is not running!" >> /data/log/check_mysql_slave.log
 mail -s "warn! $MySQLIP_replicate_error" [email protected] log/check_mysql_slave.log
fi# 建议每10分钟运行一次:
shell> crontab -e
*/10 * * * * root /bin/sh /root/check_mysql_slave.sh
1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.

4、系统初始化脚本

此脚本用于新装Linux的相关配置工作,比如更换默认yum源,优化系统内核、停掉一些没必要启动的系统服务等。此脚本尤其适合大批新安装的CentOS系列的服务器。适用于Centos7

shell>vim cenots_7_system_init.sh
#!/bin/bash# Filename:    centos7-init.sh# Author:     [email protected]#判断是否为root用户if [ `whoami` != "root" ];thenecho " only root can run it"exit 1
fi#执行前提示echo -e "\033[31m 这是centos7系统初始化脚本,将更新系统内核至最新版本,请慎重运行!\033[0m"  
read -s -n1 -p "Press any key to continue or ctrl+C to cancel"echo "Your inputs: $REPLY"#1.定义配置yum源的函数yum_config(){
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum clean all && yum makecache
}
#2.定义配置NTP的函数ntp_config(){
yum –y install chrony
systemctl start chronyd && systemctl enable chronyd
timedatectl set-timezone Asia/Shanghai && timedatectl set-ntp yes
}
#3.定义关闭防火墙的函数close_firewalld(){
systemctl stop firewalld.service &> /dev/null  
systemctl disable firewalld.service &> /dev/null
}
#4.定义关闭selinux的函数close_selinux(){
setenforce 0
sed -i 's/enforcing/disabled/g' /etc/selinux/config
}
#5.定义安装常用工具的函数yum_tools(){
yum install –y vim wget curl curl-devel bash-completion lsof iotop iostat unzip bzip2 bzip2-devel
yum install –y gcc gcc-c++ make cmake autoconf openssl-devel openssl-perl net-tools
source /usr/share/bash-completion/bash_completion
}
#6.定义升级最新内核的函数update_kernel (){
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
yum --enablerepo=elrepo-kernel install -y kernel-ml
grub2-set-default 0
grub2-mkconfig -o /boot/grub2/grub.cfg
}
#执行脚本main(){
   yum_config;
   ntp_config;
   close_firewalld;
   close_selinux;
   yum_tools;
   update_kernel;
}
main  

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/222460.html<

(0)
运维的头像运维
上一篇2025-04-15 12:26
下一篇 2025-04-15 12:28

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注