成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

企業(yè)生產(chǎn)環(huán)境Shell腳本案例分享

系統(tǒng) Linux
生產(chǎn)環(huán)境下的Shell腳本還是挺多的,這里介紹幾個(gè)企業(yè)常見(jiàn)的Shell腳本。

[[316003]]

生產(chǎn)環(huán)境下的Shell腳本還是挺多的,這里介紹幾個(gè)企業(yè)常見(jiàn)的Shell腳本。

1、MySQL數(shù)據(jù)庫(kù)備份腳本,下面的腳本是Mysql全量備份+異地備份

一般Mysql數(shù)據(jù)庫(kù)備份會(huì)采用在MYSQL從庫(kù)上執(zhí)行全量備份+增量備份方式。在從庫(kù)備份避免Mysql主庫(kù)備份的時(shí)候鎖表造成業(yè)務(wù)影響。 

  1. shell> vim db_backup.sh 
  2.  
  3. #!/bin/bash   
  4. # description:  MySQL buckup shell script   
  5. # author:       magedu.com 
  6. # 192.168.10.10 為專門(mén)的備份服務(wù)器,需要做一下服務(wù)器之間免密碼登錄 
  7.  
  8. #備份的數(shù)據(jù)庫(kù)名 
  9. DATABASES=( 
  10.             "magedu01" 
  11.             "magedu02"                     
  12. USER="root" 
  13. PASSWORD="dbpwd123" 
  14.  
  15. MAIL="magedu@gmail.com"  
  16. BACKUP_DIR=/data/backup 
  17. LOGFILE=/data/backup/data_backup.log  
  18. DATE=`date +%Y%m%d_%H%M` 
  19.  
  20. cd $BACKUP_DIR 
  21. #開(kāi)始備份之前,將備份信息頭寫(xiě)入日記文件    
  22. echo "--------------------" >> $LOGFILE    
  23. echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE    
  24. echo "-------------------" >> $LOGFILE 
  25.  
  26. for DATABASE in ${DATABASES};do 
  27.   /usr/local/mysql/bin/mysqldump -u$USER -p$PASSWORD --events  -R --opt  $DATABASE |gzip >${BACKUP_DIR}\/${DATABASE}_${DATE}.sql.gz 
  28.   if [ $? == 0 ];then 
  29.     echo "$DATE--$DATABASE is backup succeed" >> $LOGFILE 
  30.   else 
  31.     echo "Database Backup Fail!" >> $LOGFILE    
  32. done 
  33. #判斷數(shù)據(jù)庫(kù)備份是否全部成功,全部成功就同步到異地備份f服務(wù)器 
  34. if [ $? == 0 ];then 
  35.   /usr/bin/rsync -zrtopg   --delete  /data/backup/* root@192.168.10.10:/data/backup/  >/dev/null 2>&1 
  36. else 
  37.   echo "Database Backup Fail!" >> $LOGFILE    
  38.   #備份失敗后向管理者發(fā)送郵件提醒 
  39.   mail -s "database Daily Backup Fail!" $MAIL    
  40. fi 
  41.  
  42. #刪除30天以上的備份文件   
  43. find $BACKUP_DIR  -type f -mtime +30 -name "*.gz" -exec rm -f {} \; 

2、Nginx負(fù)載均衡服務(wù)器上監(jiān)控Nginx進(jìn)程的腳本

企業(yè)負(fù)載均衡層如果用到Nginx+Keepalived架構(gòu),而Keepalived無(wú)法進(jìn)行Nginx服務(wù)的實(shí)時(shí)切換,所以這里用了一個(gè)監(jiān)控腳本check_nginx_pid.sh,每隔5秒就監(jiān)控一次Nginx的運(yùn)行狀態(tài),如果發(fā)現(xiàn)有問(wèn)題就關(guān)閉本機(jī)的Keepalived程序,讓VIP切換到從Nginx負(fù)載均衡器上。 

  1. shell> vim check_nginx_pid.sh 
  2.  
  3. #!/bin/bash 
  4. while : 
  5. do 
  6. nginxpid='ps -C nginx --no-header | wc -l' 
  7. if [$nginxpid -eq 0 ];then 
  8.   ulimit -SHn 65535 
  9.   /usr/local/nginx/sbin/nginx 
  10. sleep 5 
  11.  nginxpid='ps -C nginx --no-header | wc -l' 
  12.  if [$nginxpid -eq 0 ];then 
  13.  /etc/init.d/keepalived stop 
  14.  fi 
  15. fi 
  16. sleep 5 
  17. done 

3、MySQL主從監(jiān)控郵件報(bào)警腳本

  • 此腳本應(yīng)該能適應(yīng)各種各樣不同的內(nèi)外網(wǎng)環(huán)境。
  • 讓腳本也順便監(jiān)控下MySQL是否正常運(yùn)行。
  • Slave機(jī)器的IO和SQL狀態(tài)都必須為YES,缺一不可,這里用到了多重條件判斷-a。 
  1. shell> check_mysql_slave.sh 
  2. #!/bin/bash 
  3. #check MySQL_Slave Status 
  4.  
  5. MYSQLPORT='netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}'' 
  6. MYSQLIP='ifconfig eth0|grep "inet addr" | awk -F[:" "]+ '{print $4}'' 
  7. STATUS=$(/usr/local/mysql/bin/mysql -u dbuser -dbpwd123 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running"
  8. IO_env='echo $STATUS | grep IO | awk ' {print $2}'' 
  9. SQL_env='echo $STATUS | grep SQL | awk '{print $2}'' 
  10.  
  11. if [ "$MYSQLPORT" == "3306" ] 
  12. then 
  13.  echo "mysql is running" 
  14. else 
  15.  mail -s "warn!server: $MYSQLIP mysql is down" magedu@gmail.com 
  16. fi 
  17.  
  18.  
  19. if [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ] 
  20. then 
  21.  echo "Slave is running!" 
  22. else 
  23.  echo "####### $date #########">> /data/log/check_mysql_slave.log 
  24.  echo "Slave is not running!" >> /data/log/check_mysql_slave.log 
  25.  mail -s "warn! $MySQLIP_replicate_error" magedu@gmail.com << /data/log/check_mysql_slave.log 
  26. fi 
  27.  
  28. # 建議每10分鐘運(yùn)行一次: 
  29. shell> crontab -e 
  30. */10 * * * * root /bin/sh /root/check_mysql_slave.sh 

4、系統(tǒng)初始化腳本

此腳本用于新裝Linux的相關(guān)配置工作,比如更換默認(rèn)yum源,優(yōu)化系統(tǒng)內(nèi)核、停掉一些沒(méi)必要啟動(dòng)的系統(tǒng)服務(wù)等。此腳本尤其適合大批新安裝的CentOS系列的服務(wù)器。適用于Centos7 

  1. shell>vim cenots_7_system_init.sh 
  2. #!/bin/bash 
  3. # Filename:    centos7-init.sh 
  4. # Author:     magedu@gmail.com 
  5. #判斷是否為root用戶 
  6. if [ `whoami` != "root" ];then 
  7. echo " only root can run it" 
  8. exit 1 
  9. fi 
  10. #執(zhí)行前提示 
  11. echo -e "\033[31m 這是centos7系統(tǒng)初始化腳本,將更新系統(tǒng)內(nèi)核至最新版本,請(qǐng)慎重運(yùn)行!\033[0m"  
  12. read -s -n1 -p "Press any key to continue or ctrl+C to cancel" 
  13. echo "Your inputs: $REPLY" 
  14. #1.定義配置yum源的函數(shù) 
  15. yum_config(){ 
  16. mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup 
  17. wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo 
  18. yum clean all && yum makecache 
  19. #2.定義配置NTP的函數(shù) 
  20. ntp_config(){ 
  21. yum –y install chrony 
  22. systemctl start chronyd && systemctl enable chronyd 
  23. timedatectl set-timezone Asia/Shanghai && timedatectl set-ntp yes 
  24. #3.定義關(guān)閉防火墻的函數(shù) 
  25. close_firewalld(){ 
  26. systemctl stop firewalld.service &> /dev/null  
  27. systemctl disable firewalld.service &> /dev/null 
  28. #4.定義關(guān)閉selinux的函數(shù) 
  29. close_selinux(){ 
  30. setenforce 0 
  31. sed -i 's/enforcing/disabled/g' /etc/selinux/config 
  32. #5.定義安裝常用工具的函數(shù) 
  33. yum_tools(){ 
  34. yum install –y vim wget curl curl-devel bash-completion lsof iotop iostat unzip bzip2 bzip2-devel 
  35. yum install –y gcc gcc-c++ make cmake autoconf openssl-devel openssl-perl net-tools 
  36. source /usr/share/bash-completion/bash_completion 
  37. #6.定義升級(jí)最新內(nèi)核的函數(shù) 
  38. update_kernel (){ 
  39. rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org 
  40. rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm 
  41. yum --enablerepo=elrepo-kernel install -y kernel-ml 
  42. grub2-set-default 0 
  43. grub2-mkconfig -o /boot/grub2/grub.cfg 
  44. #執(zhí)行腳本 
  45. main(){ 
  46.     yum_config; 
  47.     ntp_config; 
  48.     close_firewalld; 
  49.     close_selinux; 
  50.     yum_tools; 
  51.     update_kernel; 
  52. main  

 

責(zé)任編輯:龐桂玉 來(lái)源: Linux學(xué)習(xí)
相關(guān)推薦

2019-08-09 13:50:08

shellLinux

2010-10-09 09:18:59

Shell腳本

2021-06-07 13:02:31

Shell腳本Linux

2019-08-12 07:45:44

Linux腳本shell

2012-06-25 14:01:10

云計(jì)算案例

2021-05-31 12:05:46

Shell命令Linux

2021-11-08 08:29:57

Oracle數(shù)據(jù)庫(kù)后端開(kāi)發(fā)

2019-10-31 08:22:39

shell腳本Linux

2019-08-13 11:53:01

腳本語(yǔ)言AWKBash

2023-09-12 23:15:08

Shell腳本

2021-12-01 08:59:20

Go 支付獎(jiǎng)勵(lì)

2017-06-20 15:20:54

spring-data案例詳解

2024-11-27 09:19:25

2019-08-23 06:22:47

LinuxShell監(jiān)控腳本

2015-01-13 17:35:30

BPM選型

2015-02-12 09:26:34

DockerLXCPaaS

2020-10-23 11:10:51

Spring BootShellJava

2022-09-01 08:50:22

kubernetes容器

2021-08-19 08:04:36

IT部門(mén)首席信息官CIO

2024-10-08 14:55:25

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 一区二区视频 | 黄色片视频网站 | 成人精品一区二区三区中文字幕 | 国产在线网站 | 精品不卡 | xxx国产精品视频 | 日本h片在线观看 | 这里有精品 | 欧美视频第二页 | 亚洲福利av | 久久爱一区| 亚洲一区二区三区久久久 | 亚洲成人免费视频 | 色偷偷噜噜噜亚洲男人 | 999久久久久久久久6666 | 久草视频在线播放 | 一级毛片免费看 | 国产精品亚洲综合 | 麻豆亚洲 | 国产精品毛片一区二区三区 | 亚洲激情在线视频 | 精品中文字幕一区二区 | 久久久美女 | 日韩精品久久 | 国产在线播 | 国产不卡一区 | 伊人春色在线 | 黑人巨大精品欧美黑白配亚洲 | 国产精品自拍啪啪 | 免费黄色录像片 | 黄色av一区 | 三级在线免费 | 欧美一区二区小视频 | 日韩久久久久久 | 国产成人一区在线 | 欧美一区二区三区免费在线观看 | 超碰在线播 | 亚洲国产精品久久久久久 | 欧美一级毛片久久99精品蜜桃 | 午夜精品久久久 | 日本高清中文字幕 |