Jenkins & LinuxJenkins社区Linux学习之路

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

2017-11-23  本文已影响503人  1204号技师

本篇例子: 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;
INSERT INTO `jenkins_demo`.`jenkins_data` (`message`) VALUES ( '初始化');
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
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
image.png

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

image.png

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

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

上一篇 下一篇

猜你喜欢

热点阅读