青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Fork me on GitHub
隨筆 - 215  文章 - 13  trackbacks - 0
<2017年3月>
2627281234
567891011
12131415161718
19202122232425
2627282930311
2345678


專注即時通訊及網游服務端編程
------------------------------------
Openresty 官方模塊
Openresty 標準模塊(Opm)
Openresty 三方模塊
------------------------------------
本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

相冊

Awesome

Blog

Book

GitHub

Link

搜索

  •  

積分與排名

  • 積分 - 219786
  • 排名 - 117

最新評論

閱讀排行榜

http://www.jianshu.com/p/50b7dc07f1f1
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 不再問你是否需要保存密碼。

看來也是可行的。

到這里為止,已經可以用一個實際的項目做部署測試,后面有時間再來補上這一部分。但是我想看了這整個的步驟,自己做實驗驗證一下也比較簡單了。

posted on 2017-03-01 17:46 思月行云 閱讀(561) 評論(0)  編輯 收藏 引用 所屬分類: 服務器\Ops
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情黄色片| 久久精品成人欧美大片古装| 亚洲精品欧美激情| 香蕉成人久久| 国产乱码精品一区二区三区av | 久久亚洲综合色| 国产精品美女主播| 亚洲一区日韩在线| 亚洲女人av| 一区在线播放视频| 欧美成人精品一区| 久久久久久久欧美精品| 在线成人黄色| 99国产精品久久久久老师| 欧美精品亚洲精品| 午夜老司机精品| 久久久久看片| 亚洲欧美日韩视频二区| 一区二区在线看| 日韩午夜激情av| 日韩一级片网址| 亚洲欧美日韩人成在线播放| 久久久国产成人精品| 欧美承认网站| 欧美在线综合| 欧美精品一区二区三| 欧美在线精品免播放器视频| 久久这里有精品视频| 午夜精品久久久久久99热软件| 久久久久国产一区二区三区| 亚洲淫片在线视频| 欧美国产精品人人做人人爱| 久久久另类综合| 久久精彩免费视频| 欧美亚洲一区二区在线观看| 欧美极品aⅴ影院| 欧美韩日一区二区| 亚洲国产欧美国产综合一区| 欧美一区二区三区免费视频 | 久久高清国产| 亚洲综合电影| 国产精品久久久久毛片大屁完整版| 91久久精品一区| 黄色影院成人| 久久影院亚洲| 一区二区免费在线播放| 亚洲欧美日韩区| 国产欧美精品在线| 久久免费偷拍视频| 欧美专区中文字幕| 在线成人亚洲| 欧美日一区二区在线观看| 亚洲欧美国产高清va在线播| 99精品视频一区二区三区| 国产欧美一区二区精品婷婷| 亚洲欧美另类在线观看| 久久精品亚洲| 亚洲韩国一区二区三区| 国产精品99免费看 | 欧美一区视频| 激情成人av| 欧美久久久久久久久久| 亚洲欧美在线看| 亚洲激情婷婷| 欧美日韩视频第一区| 久久夜色精品国产| 99视频在线观看一区三区| 亚洲一区二区三区精品视频| 国产资源精品在线观看| 欧美精品免费视频| 亚洲综合第一| 一区二区三区视频免费在线观看| 欧美日韩综合视频| 欧美一区国产二区| 欧美一区中文字幕| 日韩一级精品| 久久久久久午夜| 亚洲综合色丁香婷婷六月图片| 巨胸喷奶水www久久久免费动漫| 亚洲天堂免费在线观看视频| 国产亚洲人成网站在线观看| 欧美风情在线观看| 日韩一级裸体免费视频| 久久久久综合| 欧美在线黄色| 午夜精品久久久久久99热| 香蕉乱码成人久久天堂爱免费| 欧美一区影院| 黄色成人在线网站| 国产欧美va欧美va香蕉在| 国产精品一区在线观看| 欧美日韩一区二| 嫩草影视亚洲| 欧美日韩国产小视频| 亚洲私人影院在线观看| 在线欧美影院| 在线日韩av片| 亚洲三级色网| 亚洲欧美另类在线| 亚洲欧美国产高清| 午夜在线精品偷拍| 久久久久久亚洲精品中文字幕| 亚洲欧美国内爽妇网| 亚洲一区二区三区高清| 欧美在线观看天堂一区二区三区 | 一区二区av在线| 狠狠色丁香久久婷婷综合丁香| 欧美成人精品一区| 欧美日韩亚洲一区三区| 国产精品一二三视频| 激情另类综合| 日韩一级裸体免费视频| 午夜久久黄色| 欧美黄色aaaa| 亚洲精品视频二区| 久久精品国产久精国产爱| 久久视频一区| 国产麻豆成人精品| 亚洲欧美综合另类中字| 欧美激情小视频| 国产老女人精品毛片久久| 亚洲精品久久久久中文字幕欢迎你| 99精品国产福利在线观看免费| 欧美伊人久久久久久久久影院| 欧美~级网站不卡| 午夜国产不卡在线观看视频| 久久综合婷婷| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲第一偷拍| 亚洲一本视频| 一区二区动漫| 欧美精品日韩综合在线| 午夜亚洲精品| 欧美一区二区三区在线观看视频| 欧美日韩国产精品自在自线| 一区二区在线观看视频| 老司机精品福利视频| 久久精品国产久精国产一老狼| 久久精品一区二区三区中文字幕| 国产精品一卡二| 久久av老司机精品网站导航| 亚洲一区图片| 国产亚洲精品一区二555| 国产精品综合色区在线观看| 久久激情五月丁香伊人| 久久国产精品黑丝| 亚洲成色999久久网站| 亚洲国产另类精品专区| 国产精品yjizz| 欧美在线视频不卡| 欧美1区3d| 欧美一区二区日韩| 狂野欧美激情性xxxx欧美| 中文一区在线| 久久久久久高潮国产精品视| 亚洲精品在线三区| 欧美在线视频一区二区三区| 国内外成人免费激情在线视频网站 | 国产精品视频一区二区高潮| 亚洲欧美激情诱惑| 亚洲国产网站| 国产亚洲永久域名| 欧美黄色aa电影| 国产精品网站在线观看| 在线欧美日韩| 久久久久亚洲综合| 国产精品嫩草久久久久| 亚洲国产日韩一区| 国产在线视频欧美一区二区三区| 日韩午夜在线观看视频| 最新成人av网站| 欧美在线不卡| 欧美一级淫片aaaaaaa视频| 欧美精品一区二区蜜臀亚洲| 欧美成人福利视频| 国产精品地址| 亚洲激情亚洲| 亚洲久久一区二区| 欧美激情综合| 亚洲精品一区二区三区99| 日韩亚洲精品在线| 亚洲伊人观看| 久久婷婷av| 国语自产精品视频在线看| 欧美一区二区视频97| 久久激情视频久久| 在线精品视频免费观看| 久久精品亚洲一区二区三区浴池| 久久久久国产成人精品亚洲午夜| 国产精品一区亚洲| 久久久久久一区二区| 久久久欧美一区二区| 亚洲国产日韩欧美在线99 | 欧美日韩综合一区| 一区二区久久久久久| 欧美一区二区在线视频| 亚洲国产高清aⅴ视频| 久久黄色小说| 夜夜狂射影院欧美极品| 久久夜色精品国产亚洲aⅴ|