jenkins调用shell执行数据库升级及备份

###this is deploysql.sh###

#!/bin/bash
LANG="en_US.UTF-8"
date=`date +'%Y%m%d_%H%M%S'`
user=root
password=yourpassword
cd /root/SQLtest/
svn up
if [ $? = 0 ];then
    get_env=`cat /root/SQLtest/upgrade.sql |grep ^#ENV=|sed 's/#ENV=//g;s/.$//'`
    get_host=`cat /root/SQLtest/upgrade.sql |grep ^#HOST=|sed 's/#HOST=//g;s/.$//'`
    host=${get_host}
  if [ -n "${get_env"}] && [ -n "${get_host}"];then
    echo -e "正在获取 ${get_env} ip:${get_host}需要备份的表...\n"
    backup_tables=`cat /root/SQLtest/upgrade.sql |grep ^#backup_tables=|sed 's/#backup_tables=//g;s/.$//'`
    OLD_IFS="$IFS"
    IFS=","
    tables=($backup_tables)
    IFS="$OLD_IFS"
    if [ -n "$tables" ];then
      echo -e "您需要备份的表有:${tables[*]}\n"
      for table in ${tables[@]}
      do
    echo -e "mysqldump -uroot -pdbpasswd ${table%.*} ${table#*.} > ${table%.*}_${table#*.}_${date}.sql\n"
      done
      if [ $? -eq 0 ]
      then
        echo -e "备份成功!\n"
        echo -e "正在执行升级SQL...\n"
        mysql -u$user -p$password -h $host <<EOF
        source /root/SQLtest/upgrade.sql;
EOF
      else
        echo -e "备份失败!\n"
      fi
    else        
      echo -e "警告:您没有输入任何需要备份的表!但是升级SQL依然执行...\n"
      echo -e "正在执行升级SQL...\n"
      mysql -u$user -p$password -h $host <<EOF
      source /root/SQLtest/upgrade.sql;
EOF
    fi
  else
    echo -e "ENV or HOST not found!\n"
  fi
else
    echo -e "svn update failed!\n"
fi

 


#this is testENV.sql#

################################声明主机(运维维护)##############################################

#ENV=准生产环境
#HOST=192.168.1.1.

################################END###################################################




#################################声明需要备份的表,建议对升级有操作的表进行备份,可以为空,即不备份直接升级(开发维护)######################################

#请在下一行“backup_tables=”后输入需要备份的表,格式:db.table多个之间用“,”分隔

#backup_tables=mysql.user,mysql.host

##################################END##################################################





################################提供升级操作SQL(开发维护)############################################
use mysql;
show tables;
################################END#####################################################

转载于:https://www.cnblogs.com/nbuntu/p/5753178.html

在使用Jenkins调用Shell脚本执行SSH时,出现"host key verification failed"错误是因为SSH无法验证远程主机的密钥。这可能是由以下原因导致的: 1. 第一次连接:当第一次使用SSH连接到远程主机时,主机的密钥会被保存在~/.ssh/known_hosts文件中。如果主机的密钥发生了变化,就会导致验证失败。 解决方法:打开Jenkins所在服务器的终端,用ssh命令手动连接到该远程主机,确认是否出现了密钥变化的提示信息。如果确认变化是合理的,可以删除~/.ssh/known_hosts文件中对应的主机密钥,然后重新执行Jenkins任务。 2. 未正确配对:如果远程主机使用了公钥/私钥对进行连接验证,而Jenkins任务在使用SSH时没有正确配置公钥/私钥对,也会导致验证失败。 解决方法:检查Jenkins任务中SSH配置的密钥路径是否正确,并确保公钥已经添加到远程主机的~/.ssh/authorized_keys文件中。 3. hosts文件设置不正确:如果在远程主机的/etc/hosts文件中设置了不正确的主机名,会导致验证失败。 解决方法:在远程主机上检查/etc/hosts文件,确保主机名和IP地址的对应关系正确。 综上所述,解决"host key verification failed"错误的方法包括删除已知主机密钥、正确配置公钥/私钥对和检查/etc/hosts文件设置等。根据具体情况进行排查和解决,可以消除该错误并使Jenkins任务能够顺利执行SSH操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值