標籤:
SVN是一種版本管理系統,前身是CVS,是開源軟體的基石。即使在溝通充分的情況下,多人維護同一份原始碼的一定也會出現混亂的情況,版本管理系統就是為瞭解決這些問題。
SVN中的一些概念 :
a. repository(原始碼庫)
原始碼統一存放的地方。
b. Checkout (提取)
當你手上沒有原始碼的時候,你需要從repository checkout一份。
c. Commit (提交)
當你已經修改了代碼,你就需要Commit到repository。
d. Update (更新)
當你已經Checkout了一份原始碼, Update一下你就可以和Repository上的原始碼同步,你手上的代碼就會有最新的變更。
Centos 搭建SVN服務,有效管理代碼,以下三步可以快速搞定。
1、安裝
[[email protected] ~]# yum install subversion
[[email protected] ~]# svn -v 判斷是否安裝成功 svnserve, version 1.6.11 (r934486) 出現類型提示,說明安裝成功。
有了SVN軟體後還需要建立SVN庫。 [[email protected] ~]# mkdir /opt/svn/repos [[email protected] ~]# svnadmin create /opt/svn/repos 執行上面的命令後,自動在repos下建立多個檔案, 分別是conf, db,format,hooks, locks, README.txt。 |
2、配置
上面的操作很簡單,幾個命令就搞定, 下面的操作也不難。
進入上面產生的檔案夾conf下,進行配置, 有以下幾個檔案authz, passwd, svnserve.conf
其中authz 是許可權控制,可以設定哪些使用者可以訪問哪些目錄, passwd是設定使用者和密碼的, svnserve是設定svn相關的操作。
2 .1先設定passwd [[email protected] ~]# vi passwd [users] # harry = harryssecret # sally = sallyssecret hello=123 使用者名稱=密碼
這樣我們就建立了hello使用者, 123密碼
2.2 再設定許可權authz [[email protected] ~]# vi authz [/] hello= rw
意思是hello使用者對所有的目錄有讀寫權限,當然也可以限定。 如果是自己用,就直接是讀寫吧。
2.3最後設定snvserv.conf [[email protected] ~]# vi snsvserv.conf anon-access = none # 使非授權使用者無法訪問 auth-access = write # 使授權使用者有寫入權限 password-db = password #authz-db = authz # 存取控制檔案 realm = /opt/svn/repos # 認證命名空間,subversion會在認證提示裡顯示,並且作為憑證緩衝的關鍵字。 採用預設配置. 以上語句都必須頂格寫, 左側不能留空格, 否則會出錯. |
好了,通過以上配置,你的svn就可以了。
3、串連
[[email protected] ~]# svnserve -d -r /opt/svn/repos 啟動svn: 如果已經有svn在運行,可以換一個連接埠運行 [[email protected] ~]# svnserve -d -r /opt/svn/repos --listen-port 3391
這樣同一台伺服器可以運行多個svnserver
好了,啟動成功後,就可以使用了。 建議採用TortoiseSVN, 串連地址為: svn://your server address (如果指定連接埠需要添加連接埠 :連接埠號碼)
串連後可以上傳本地的檔案,有效管理你的代碼。
|
開放svn連接埠
修改
iptables -I INPUT -p tcp --dport 3690 -j ACCEPT
儲存
/etc/rc.d/init.d/iptables save
重啟
service iptables restart
查看
/etc/init.d/iptables status
svn 命令詳解
1、將檔案checkout到本地目錄
svn checkout path(path是伺服器上的目錄)
例如:svn checkout svn://192.168.1.1/pro/domain
簡寫:svn co
2、往版本庫中添加新的檔案
svn add file
例如:svn add test.php(添加test.php)
svn add *.php(添加目前的目錄下所有的php檔案)
3、將改動的檔案提交到版本庫
svn commit -m “LogMessage“ [-N] [--no-unlock] PATH(如果選擇了保持鎖,就使用–no-unlock開關)
例如:svn commit -m “add test file for my test“ test.php
簡寫:svn ci
4、加鎖/解鎖
svn lock -m “LockMessage“ [--force] PATH
例如:svn lock -m “lock test file“ test.php
svn unlock PATH
5、更新到某個版本
svn update -r m path
例如:
svn update如果後面沒有目錄,預設將目前的目錄以及子目錄下的所有檔案都更新到最新版本。
svn update -r 200 test.php(將版本庫中的檔案test.php還原到版本200)
svn update test.php(更新,於版本庫同步。如果在提交的時候提示到期的話,是因為衝突,需要先update,修改檔案,然後清除svn resolved,最後再提交commit)
簡寫:svn up
6、查看檔案或者目錄狀態
1)svn status path(目錄下的檔案和子目錄的狀態,正常狀態不顯示)
【?:不在svn的控制中;M:內容被修改;C:發生衝突;A:預定加入到版本庫;K:被鎖定】
2)svn status -v path(顯示檔案和子目錄狀態)
第一列保持相同,第二列顯示工作版本號碼,第三和第四列顯示最後一次修改的版本號碼和修改人。
註:svn status、svn diff和 svn revert這三條命令在沒有網路的情況下也可以執行的,原因是svn在本地的.svn中保留了本地版本的原始拷貝。
簡寫:svn st
7、刪除檔案
svn delete path -m “delete test fle“
例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete test file”
或者直接svn delete test.php 然後再svn ci -m ‘delete test file‘,推薦使用這種
簡寫:svn (del, remove, rm)
8、查看日誌
svn log path
例如:svn log test.php 顯示這個檔案的所有修改記錄,及其版本號碼的變化
9、查看檔案詳細資料
svn info path
例如:svn info test.php
10、比較差異
svn diff path(將修改的檔案與基礎版本比較)
例如:svn diff test.php
svn diff -r m:n path(對版本m和版本n比較差異)
例如:svn diff -r 200:201 test.php
簡寫:svn di
11、將兩個版本之間的差異合并到當前檔案
svn merge -r m:n path
例如:svn merge -r 200:205 test.php(將版本200與205之間的差異合并到當前檔案,但是一般都會產生衝突,需要處理一下)
12、SVN 協助
svn help
svn help ci
13、版本庫下的檔案和目錄列表
svn list path
顯示path目錄下的所有屬於版本庫的檔案和目錄
簡寫:svn ls
建立版本庫:
終端輸入:svnadmin create [路徑]
該路徑可以是相對路徑,例如,當前在home/user/svn/目錄下,輸入svnadmin create myproject,則該版本庫會被建立在home/user/svn/目錄下,建立一個檔案夾名為myproject,其中便是版本庫的檔案了。
將檔案匯入版本庫:
終端輸入:svn import [源路徑] [目標版本庫路徑] -m [日誌資訊]
源路徑可以是相對路徑,匯入時會遞迴匯入源路徑下的所有檔案和檔案夾,目標版本庫路徑需要絕對目錄(反正我實驗是這樣的),例如版本庫的目錄是:home/user/svn/myproject/。則應該這樣寫:file:///home/user/svn/myproject/
例如將目前的目錄匯入版本庫myproject:
svn import . file:///home/user/svn/myproject -m "匯入檔案"
從版本庫匯出:
匯入後原檔案並未被納入版本管理,若想獲得受版本控制的檔案,就需要從版本庫匯出
終端輸入:svn co [版本庫路徑] [匯出目標路徑]
例如將myproject庫中的檔案匯出到目前的目錄:svn co file:///home/user/svn/myproject .
svn提交檔案後自動同步更新到網站目錄
#!/bin/bash
REPOS="$1"
REV="$2"
export LANG=zh_CN.UTF-8
svn update /var/www/html/test/
echo `date`,`whoami`,$REPOS,$REV >> /var/www/svn/test/svn.log
linux svn使用