SVN + Ansible 做代码自动部署

svn 安装参考:
http://www.ha97.com/4467.html

svn hook 触发的思路,参考了这里:
http://www.open-open.com/lib/view/open1376871583553.html

环境:CentOS 6.8 最小化安装,svn 默认已安装,ansible 安装步骤暂略。

一、基本的SVN 服务配置


查看可使用的 svn 命令:

[root@vm_mac ~]# svn
svn            svndumpfilter  svnserve       svnversion
svnadmin       svnlook        svnsync

1,新建一个目录用于存储SVN所有文件

[root@vm_mac ~]# mkdir /home/svn

2,新建一个版本仓库

[root@vm_mac ~]# svnadmin create /home/svn/project

3,初始化版本仓库中的目录

[root@vm_mac ~]# mkdir -p /root/project/{server,client,test} (建立临时目录)
[root@vm_mac ~]# svn import /root/project/ file:///home/svn/project/ -m "svn dir init"
Adding         /root/project/test
Adding         /root/project/server
Adding         /root/project/client

Committed revision 1.

[root@vm_mac ~]# rm -rf /root/project/ (删除临时建立的目录)

4,添加用户

要添加SVN用户非常简单,只需在/home/svn/project/conf/passwd文件添加一个形如“username=password”的条目就可以了。为了测试,我添加了如下内容:

[users]
# harry = harryssecret
# sally = sallyssecret
pm = pm_pw
server_group = server_pw
client_group = client_pw
test_group = test_pw

5,修改用户访问策略

/home/svn/project/conf/authz记录用户的访问策略,以下是参考:

[groups]
project_p = pm
project_s = server1,server2,server3
project_c = client1,client2,client3
project_t = test1,test1,test1

[project:/]
@project_p = rw
* =

[project:/server]
@project_p = rw
@project_s = rw
* =

[project:/client]
@project_p = rw
@project_c = rw
* =

[project:/doc]
@project_p = rw
@project_s = r
@project_c = r
@project_t = r
* =

说明:以上信息表示,只有project_p用户组有根目录的读写权。r表示对该目录有读权限,w表示对该目录有写权限,rw表示对该目录有读写权限。

最后一行的*=表示,除了上面设置了权限的用户组之外,其他任何人都被禁止访问本目录。这个很重要,一定要加上!

6,修改svnserve.conf文件,让用户和策略配置升效.

svnserve.conf内容如下:

[general]
anon-access = none
auth-access = write
password-db = /home/svn/project/conf/passwd
authz-db = /home/svn/project/conf/authz

7,启动服务器

# svnserve -d -r /home/svn

注意:如果修改了svn配置,需要重启svn服务,步骤如下:

# ps -aux|grep svnserve
# kill -9 ID号
# svnserve -d -r /home/svn

8,测试服务器

# svn co svn://192.168.60.10/project
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Password for 'root':
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Username: server_group
Password for 'server_group':
svn: Authorization failed ( server_group没用根目录的访问权 )

# svn co svn://192.168.60.10/project
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Password for ‘root’:
Authentication realm: <svn://192.168.60.10:3690> 92731041-2dae-4c23-97fd-9e1ed7f0d18d
Username: pm
Password for ‘pm’:
A    project/test
A    project/server
A    project/client
Checked out revision 1.  ( 测试提取成功 )

# cd project/server
# vim main.c
# svn add main.c
# svn commit main.c -m “测试一下我的C程序,看什么看,不行啊??”
Adding         main.c
Transmitting file data .
Committed revision 2.  ( 测试提交成功 )

二,结合 ansible 做代码自动部署


实验环境:

  • svn服务器:192.168.0.120 (vm_mac.guli.com)
  • 目标服务器:192.168.0.171 (lamp1.guli.com)

测试目标:使用 svn 提交代码,如果提交时添加注释中含有 "auto_deploy" 字符串,则自动部署到目标服务器中。

编辑 post-commit 脚本:

[root@vm_mac hooks]# vi /home/svn/project/hooks/post-commit


#!bin/bash
REPOS="$1"
REV="$2"

export LC_CTYPE=en_US.UTF-8

if (svnlook log -r $REV /home/svn/project | grep "auto_deploy"); then
    echo "`date` $REV auto deploy command received" >> /tmp/test_svnautocommit.txt
    ansible lamp -a "svn checkout "svn://192.168.0.120/project" /var/www/html/web1 --force --username="pm" --password="pm_pw" --non-interactive"
fi

脚本说明:

如果提交时添加注释中含有 "auto_deploy",则记录一条简单的日志,并且执行一条 ansible 命令,意思是在 lamp 组的所有主机上(这里只定义了一个 lamp1.guli.com),执行 svn checkout 操作,将目标 repo 检出到本地 /var/www/html/web1。第一次执行时,如果目录不存在,会自动创建目录;否则进行检出。

ansible 的用户组配置:

[root@vm_mac hooks]# vi /etc/ansible/hosts
[lamp]
lamp1.guli.com

ansible 主机和 lamp1 建立 ssh 信任步骤等暂略,注意那是必要的。

测试:

1.lamp1 主机上,现在还没有创建 web1 目录:

[root@lamp1 html]# pwd
/var/www/html
[root@lamp1 html]# ll
total 4
-rw-r--r-- 1 root root 24 Jul 16 14:54 index.html
[root@lamp1 html]# hostname
lamp1

2.在 svn 服务器上,现在 /root/project/test 目录下有如下文件,

 [root@vm_mac test]# pwd
 /root/project/test
 [root@vm_mac test]# ll
 total 0
 -rw-r--r-- 1 root root 0 Aug  5 11:00 ccc
 -rw-r--r-- 1 root root 0 Aug  5 11:06 ddd
 -rw-r--r-- 1 root root 0 Aug  5 11:37 eee
 -rw-r--r-- 1 root root 0 Aug  5 12:31 fff

3.我们添加一个 ggg 文件,并且提交

[root@vm_mac test]# touch ggg
[root@vm_mac test]# svn add ggg
A         ggg
[root@vm_mac test]# svn commit -m "auto_deploy"
Adding         test/ggg
Transmitting file data .
Committed revision 47.

现在版本是 47

4.查看 lamp1 上是否同步过去了:

[root@lamp1 html]# ll
total 8
-rw-r--r-- 1 root root   24 Jul 16 14:54 index.html
drwxr-xr-x 6 root root 4096 Aug  5 13:29 web1
[root@lamp1 html]# ll web1/test/
total 0
-rw-r--r-- 1 root root 0 Aug  5 13:29 ccc
-rw-r--r-- 1 root root 0 Aug  5 13:29 ddd
-rw-r--r-- 1 root root 0 Aug  5 13:29 eee
-rw-r--r-- 1 root root 0 Aug  5 13:29 fff
-rw-r--r-- 1 root root 0 Aug  5 13:29 ggg

我们看到,在 /var/www/html 目录下多了一个 web1 目录,并且 test 子目录的内容是同步的

5.现在到 lamp1 上删除一个文件 ccc ,并提交:

[root@vm_mac test]# svn del ccc
D         ccc
[root@vm_mac test]# svn commit -m "auto_deploy"
Deleting       test/ccc

Committed revision 48.

[root@vm_mac test]# ll
total 0
-rw-r--r-- 1 root root 0 Aug  5 11:06 ddd
-rw-r--r-- 1 root root 0 Aug  5 11:37 eee
-rw-r--r-- 1 root root 0 Aug  5 12:31 fff
-rw-r--r-- 1 root root 0 Aug  5 13:28 ggg

现在版本号到了 48

6.再查看 lamp1 上是否同步过去了:

[root@lamp1 html]# ll web1/test/
total 0
-rw-r--r-- 1 root root 0 Aug  5 13:29 ddd
-rw-r--r-- 1 root root 0 Aug  5 13:29 eee
-rw-r--r-- 1 root root 0 Aug  5 13:29 fff
-rw-r--r-- 1 root root 0 Aug  5 13:29 ggg

可以看到 ccc 文件成功被删除了。

好了,到了这里已经基本实现了。这是使用 svn 检出实现的方式。

后续需要完善的几个方面:


1.实验里的检出可能没有加密,后面考虑使用 svn+ssh 协议,类似这样,更为安全,这个等有时间再完善一下:

# Checkout subversion repository to specified folder.
- subversion: repo=svn+ssh://192.168.0.120/project dest=/var/www/html/web1

ansible lamp -m subversion -a "repo=svn+ssh://192.168.0.120/project dest=/var/www/html/web1 username=pm password=pm_pw revision=$REV"

2.检出时,加上 -r $REV 应该更好,因为默认是检出 HEAD 版本,对于这一点待查

3.我们根据注释里的 auto_deploy 触发自动部署线上环境,也可以使用其他字符串,如 auto_test_deploy 触发自动部署测试环境。进一步设想,是开发一个 web 界面,手动选择自动部署测试环境,或者部署线上环境,这样比较直观好看一些。

4.checkout 是每次都拷贝覆盖,还是只更新需要更新的?

我们实验一下 svn update:

ansible lamp -a "svn update "svn://192.168.0.120/project" /var/www/html/web1 --force --username="pm" --password="pm_pw" --non-interactive"

增加 hhh 文件,并提交,注释为空,不要触发自动部署:

[root@vm_mac test]# touch hhh
[root@vm_mac test]# svn add hhh
A         hhh
[root@vm_mac test]# svn commit -m ""
Adding         test/hhh
Transmitting file data .
Committed revision 49.
[root@vm_mac test]# ansible lamp -a "svn update "svn://192.168.0.120/project" /var/www/html/web1 --force --username="pm" --password="pm_pw" --non-interactive"
lamp1.guli.com | SUCCESS | rc=0 >>
Skipped 'svn://192.168.0.120/project'
A    /var/www/html/web1/test/hhh
Updated to revision 49.
Summary of conflicts:
  Skipped paths: 1

查看 lamp1 上是否同步过去了:

[root@lamp1 html]# ll web1/test/
total 0
-rw-r--r-- 1 root root 0 Aug  5 13:29 ddd
-rw-r--r-- 1 root root 0 Aug  5 13:29 eee
-rw-r--r-- 1 root root 0 Aug  5 13:29 fff
-rw-r--r-- 1 root root 0 Aug  5 13:29 ggg
-rw-r--r-- 1 root root 0 Aug  5 13:38 hhh

可以看到成功添加了 hhh

试一试删除 ddd 文件,并且提交:

[root@vm_mac test]# ll
total 0
-rw-r--r-- 1 root root 0 Aug  5 11:06 ddd
-rw-r--r-- 1 root root 0 Aug  5 11:37 eee
-rw-r--r-- 1 root root 0 Aug  5 12:31 fff
-rw-r--r-- 1 root root 0 Aug  5 13:28 ggg
-rw-r--r-- 1 root root 0 Aug  5 13:38 hhh
[root@vm_mac test]# svn del ddd
D         ddd
[root@vm_mac test]# svn commit -m ""
Deleting       test/ddd

Committed revision 50.
[root@vm_mac test]# ansible lamp -a "svn update "svn://192.168.0.120/project" /var/www/html/web1 --force --username="pm" --password="pm_pw" --non-interactive"
lamp1.guli.com | SUCCESS | rc=0 >>
Skipped 'svn://192.168.0.120/project'
D    /var/www/html/web1/test/ddd
Updated to revision 50.
Summary of conflicts:
  Skipped paths: 1

查看 lamp1 上是否同步过去了:

[root@lamp1 html]# ll web1/test/
total 0
-rw-r--r-- 1 root root 0 Aug  5 13:29 eee
-rw-r--r-- 1 root root 0 Aug  5 13:29 fff
-rw-r--r-- 1 root root 0 Aug  5 13:29 ggg
-rw-r--r-- 1 root root 0 Aug  5 13:38 hhh

已经删除了 ddd 文件,证明是同步了

注,svn 非交互式:--non-interactive,第一次 checkout 不再问你是否需要保存密码。

看来也是可行的。

到这里为止,已经可以用一个实际的项目做部署测试,后面有时间再来补上这一部分。但是我想看了这整个的步骤,自己做实验验证一下也比较简单了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 命令的使用 1、检出 svn cohttp://路径(目录或文件的全路径)[本地目录全路径] --username...
    小李龍彪阅读 4,434评论 0 9
  • iOS 开发 SVN 版本控制器 更多技术交流请加群 iOS技术联盟 27512466 SVN是Subversio...
    Sunny_Fight阅读 8,763评论 7 63
  • 一.ansible (1) ansible: ansible是一款新出现的自动化运维系统,基于python开发并集...
    楠人帮阅读 1,939评论 0 8
  • 宛若水珠汇入大海,苏陌和王梓呆在一起的时间越来越少。 “王梓,我晚上要去广播站审稿子,你自己去吃饭吧!” “王梓,...
    韩夭夭阅读 206评论 0 0