Jenkins自动化部署-数据库篇 (五)

本篇例子: mysql + svn

  • 在练习用的远程服务器上初始化练习用的表
CREATE USER 'jenkins'@'%' IDENTIFIED BY '123456';
CREATE DATABASE `jenkins_demo` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
GRANT all ON jenkins_demo.* TO 'jenkins'@'%';
use jenkins_demo;
CREATE TABLE "jenkins_data" (
  "id"  int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键编号',
  "message" varchar(100) NOT NULL,
  PRIMARY KEY ("id")
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8;
  • 在 svn 上新建一个SQL文件 update.sql
INSERT INTO `jenkins_demo`.`jenkins_data` (`message`) VALUES ( '初始化');
  • 新建一个工程, 选择构建一个自由风格的软件项目,点OK完成新建

    《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 源码管理选择Subversion, 填上放置SQL的svn地址

    《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 构建选择Execute shell

    《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 配置Shell脚本

    • 把需要执行的SQL进行备份
    • 复制一份部署到远程服务的副本 push.sql
    • 清空update.sql内容, 提交svn
rm -rf push.sql
today=`date "+%Y-%m-%d"`
sqlfile=$WORKSPACE/update.sql
if [ ! -x "$sqlfile"]; then
  exit 0
fi
bakfile=update-`date "+%Y%m%d%H%M%S"`.sql
mkdir -p $WORKSPACE/${today} && cp ${sqlfile} "$_"/${bakfile}
cp ${sqlfile} push.sql
svn add $WORKSPACE/${today}
svn add $WORKSPACE/${today}/${bakfile}
echo "" > $WORKSPACE/update.sql
svn update $WORKSPACE/update.sql --username xxxx --password 111111 --no-auth-cache
svn commit -m "SQL自动化部署" --username xxxx --password 111111 --no-auth-cache

《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 配置构建后操作

    《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 完成后的配置

/usr/local/mysql/bin/mysql -ujenkins -p123456 <<EOF 
use jenkins_demo;
source /data/sql/jenkins-demo/dev/push.sql;
EOF
exit;
rm /data/sql/jenkins-demo/dev/push.sql

《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 点击保存, 回到工程页面,立即构建

蓝色:成功
黄色:一般是SQL执行错误
红色:失败

《Jenkins自动化部署-数据库篇 (五)》 image.png

  • 执行成功后,查看数据库和SVN目录

    《Jenkins自动化部署-数据库篇 (五)》 image.png
    《Jenkins自动化部署-数据库篇 (五)》 image.png
    《Jenkins自动化部署-数据库篇 (五)》 image.png
    《Jenkins自动化部署-数据库篇 (五)》 image.png
    《Jenkins自动化部署-数据库篇 (五)》 image.png

如果公司服务器太多,本篇例子不合适, 因为例子是100%信任所有服务都正常,没有任何错误补偿

下一篇: Jenkins自动化部署-权限管控篇 (六)

    原文作者:1204号技师
    原文地址: https://www.jianshu.com/p/e0c1fbc98f0d
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞