SVN(Subversion)是一個自由、開源的項目源代碼版本控制工具。目前,絕大多數開源軟件和企業代碼管理,都使用SVN作爲代碼版本管理軟件。
Subversion將文件存放在中心版本庫裏,這個版本庫很像一個普通的文件服務器。不同的是,它可以記錄每一次文件和目錄的修改情況,這樣就可以在需要的回滾時,將數據恢復到以前的版本,並可以查看數據的更改細節。
SVN 官方網址:Apache Subversion
SVN 服務器配置:安裝SVN服務器
一、 SVN常用命令
1、將文件checkout到本地目錄
svn checkout path(path是服務器上的目錄)
簡寫:svn co
2、往版本庫中添加新的文件
svn add file
3、將改動的文件提交到版本庫
svn commit -m “LogMessage” [-N] [--no-unlock] PATH(如果選擇了保持鎖,就使用–no-unlock開關)
簡寫:svn ci
4、加鎖/解鎖
svn lock -m “LockMessage” [--force] PATH
svn unlock PATH
5、更新到某個版本
svn update -r m path
簡寫:svn up
6、查看文件或者目錄狀態
1)svn status path(目錄下的文件和子目錄的狀態,正常狀態不顯示)
2)svn status -v path(顯示文件和子目錄狀態)
簡寫:svn st
7、刪除文件
svn delete path -m “delete test fle”
簡寫:svn (del, remove, rm)
8、查看日誌
svn log path
9、查看文件詳細信息
svn info path
10、比較差異
svn diff path(將修改的文件與基礎版本比較)
svn diff -r m:n path(對版本m和版本n比較差異)
簡寫:svn di
11、將兩個版本之間的差異合併到當前文件
svn merge -r m:n path
12、SVN 幫助
svn help
svn help ci
二、 SVN不常用命令
13、版本庫下的文件和目錄列表
svn list path 顯示path目錄下的所有屬於版本庫的文件和目錄簡寫:svn ls
14、創建納入版本控制下的新目錄
svn mkdir: 創建納入版本控制下的新目錄。
用法:
1、mkdir PATH...
每一個以工作副本 PATH 指定的目錄,都會創建在本地端,並且加入新增調度,以待下一次的提交。
2、mkdir URL... 創建版本控制的目錄。
每個以URL指定的目錄,都會透過立即提交於倉庫中創建。在這兩個情況下,所有的中間目錄都必須事先存在。
15、恢復本地修改
svn revert: 恢復原始未改變的工作副本文件 (恢復大部份的本地修改)。
用法: revert PATH... 注意: 本子命令不會存取網絡,並且會解除衝突的狀況。但是它不會恢復被刪除的目錄
16、代碼庫URL變更
svn switch (sw): 更新工作副本至不同的URL。
用法:
1、switch URL [PATH]
更新你的工作副本,映射到一個新的URL,其行爲跟“svn update”很像,也會將 服務器上文件與本地文件合併。這是將工作副本對應到同一倉庫中某個分支或者標記的方法。
2、switch --relocate FROM TO [PATH...]
改寫工作副本的URL元數據,以反映單純的URL上的改變。當倉庫的根URL變動 (比如方案名或是主機名稱變動),但是工作副本仍舊對映到同一倉庫的同一目錄時使用 這個命令更新工作副本與倉庫的對應關係。
17、解決衝突
svn resolved: 移除工作副本的目錄或文件的“衝突”狀態。
用法: resolved PATH... 注意: 本子命令不會依語法來解決衝突或是移除衝突標記;它只是移除衝突的相關文件,然後讓 PATH 可以再次提交。
18、輸出指定文件或URL的內容。
svn cat 目標[@版本]...如果指定了版本,將從指定的版本開始查找。 svn cat -r PREV filename > filename (PREV 是上一版本,也可以寫具體版本號,這樣輸出結果是可以提交的)
三、 SVN其它命令
雖然不像本章先前討論過的那些命令那麼常用,但是有時你也需要這些命令。
svn cleanup
當Subversion修改你的工作副本時(或者任何在.svn中的信息),它嘗試儘可能做到安全。在改變一個工作副本前,Subversion把它的意 圖寫到一個日誌文件中。接下來它執行日誌文件中的命令來應用要求的修改。最後,Subversion刪除日誌文件。從架構上來說,這與一個日誌文件系統 (journaled filesystem)類似。如果一個 Subversion操作被打斷(例如,進程被殺掉了,或機器當掉了)了,日誌文件仍在硬盤上。重新執行日誌文件,Subversion可以完成先前開始 的操作,這樣你的工作副本能回到一個可靠的狀態。
以下是svn cleanup所做的:它搜索你的工作副本並執行所有遺留的日誌,在這過程中刪除鎖。如果Subversion曾告訴你你的工作副本的一部分被“鎖定”了,那麼你應該執行這個命令。另外, svn status會在鎖定的項前顯示L。
$ svn status
L somedir
M somedir/foo.c
$ svn cleanup
$ svn status
M somedir/foo.c
svn import
使用svn import是把未版本化的文件樹複製到資料庫的快速辦法,它需要創建一個臨時目錄。
$ svnadmin create /usr/local/svn/newrepos
$ svn import mytree file:///usr/local/svn/newrepos/some/project
Adding mytree/foo.c
Adding mytree/bar.c
Adding mytree/subdir
Adding mytree/subdir/quux.h
Committed revision 1.
上面的例子把在some/project目錄下mytree目錄的內容複製到資料庫中。
$ svn list file:///usr/local/svn/newrepos/some/project
bar.c
foo.c
subdir/
注意在導入完成後,原來的樹沒有被轉化成一個工作副本。爲了開始工作,你仍然需要svn checkout這個樹的一個新的工作副本。
四、SVN 常用命令一覽表
命令 | 功能 | 使用格式 |
checkout | 檢出 | svn co URL |
up | 更新到當前URL的末端 | svn up |
switch | 更新到某一tag/branch | svn switch (tag/分支)URL |
add | 增加 | svn add 文件名 |
rm | 刪除文件 | svn rm 文件名 |
刪除目錄 | svn rm 目錄名 | |
diff | 與base版本(最後檢出或者更新到的版本)對比 | svn diff |
與版本庫中最新版本對比 | svn diff -r head | |
當前工作副本,兩個版本之間對比 | svn diff -r reversion1:reversion2 | |
版本庫中任意兩個tag做對比 | svn diff (tag1)URL (tag2)URL | |
ci | 提交 | svn ci -m "commit log" |
log | 查看當前工作副本log | svn log |
只查看指定版本的log | svn log -r | |
打印log所有附加信息 | svn log -v | |
查看當前tag/branch版本詳情 | svn log --stop-on-copy -v | |
info | 查看當前工作副本所在URL | svn info |
status | 查看工作副本的狀態 | svn st |
查看文件的taglist | svn命令不支持,可執行cs taglist | |
tag | 新增tag | svn cp . (tag)URL |
刪除tag | svn rm (tag)URL -m "commit log" | |
覆蓋已經存在的tag | 不支持 | |
分支開發 | 創建branch | svn cp (基線版本)URL (分支)URL -m "commit log" |
刪除branch | svn rm (分支)URL -m "commit log" | |
同步 | svn co (主幹)URL | |
cd ~/wc | ||
svn merge (主幹)URL (待同步tag)URL | ||
svn ci -m "commit log" | ||
svn cp (主幹)URL (以_PD_BL_MAIN結尾的tag)URL -m"commit log" | ||
合併 | svn co (合併目標)URL | |
cd ~/wc | ||
svn merge (基線版本tag)URL (上線tag)URL | ||
svn ci -m "commit log" | ||
svn cp (合併目標)URL (上線tag_MERGE_的tag對應)URL -m"commit log" |
參考推薦: