本篇例子: 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完成新建
-
源码管理选择
Subversion
, 填上放置SQL的svn地址
-
构建选择
Execute shell
-
配置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
-
配置
构建后操作
完成后的配置
/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
- 点击保存, 回到工程页面,立即构建
蓝色:成功
黄色:一般是SQL执行错误
红色:失败
-
执行成功后,查看数据库和SVN目录
如果公司服务器太多,本篇例子不合适, 因为例子是100%信任所有服务都正常,没有任何错误补偿