SVN(Subversion)是一個自由、開源的項目源代碼版本控制工具。目前,絕大多數開源軟件和企業代碼管理,都使用SVN做爲代碼版本管理軟件。 html
Subversion將文件存放在中心版本庫裏,這個版本庫很像一個普通的文件服務器。不一樣的是,它能夠記錄每一次文件和目錄的修改狀況,這樣就能夠在須要的回滾時,將數據恢復到之前的版本,並能夠查看數據的更改細節。 apache
SVN 官方網址:Apache Subversion 安全
SVN 服務器配置:安裝SVN服務器 服務器
1、 SVN經常使用命令 網絡
一、將文件checkout到本地目錄
svn checkout path(path是服務器上的目錄)
簡寫:svn co
二、往版本庫中添加新的文件
svn add file
三、將改動的文件提交到版本庫
svn commit -m 「LogMessage」 [-N] [--no-unlock] PATH(若是選擇了保持鎖,就使用–no-unlock開關)
簡寫:svn ci
四、加鎖/解鎖
svn lock -m 「LockMessage」 [--force] PATH
svn unlock PATH
五、更新到某個版本
svn update -r m path
簡寫:svn up
六、查看文件或者目錄狀態
1)svn status path(目錄下的文件和子目錄的狀態,正常狀態不顯示)
2)svn status -v path(顯示文件和子目錄狀態)
簡寫:svn st
七、刪除文件
svn delete path -m 「delete test fle」
簡寫:svn (del, remove, rm)
八、查看日誌
svn log path
九、查看文件詳細信息
svn info path
十、比較差別
svn diff path(將修改的文件與基礎版本比較)
svn diff -r m:n path(對版本m和版本n比較差別)
簡寫:svn di
十一、將兩個版本之間的差別合併到當前文件
svn merge -r m:n path
十二、SVN 幫助
svn help
svn help ci 架構
2、 SVN不經常使用命令
1三、版本庫下的文件和目錄列表
svn list path 顯示path目錄下的全部屬於版本庫的文件和目錄簡寫:svn ls
1四、建立歸入版本控制下的新目錄
svn mkdir: 建立歸入版本控制下的新目錄。
用法:
一、mkdir PATH...
每個以工做副本 PATH 指定的目錄,都會建立在本地端,而且加入新增調度,以待下一次的提交。
二、mkdir URL... 建立版本控制的目錄。
每一個以URL指定的目錄,都會透過當即提交於倉庫中建立。在這兩個狀況下,全部的中間目錄都必須事先存在。
1五、恢復本地修改
svn revert: 恢復原始未改變的工做副本文件 (恢復大部份的本地修改)。
用法: revert PATH... 注意: 本子命令不會存取網絡,而且會解除衝突的情況。可是它不會恢復被刪除的目錄
1六、代碼庫URL變動
svn switch (sw): 更新工做副本至不一樣的URL。
用法:
一、switch URL [PATH]
更新你的工做副本,映射到一個新的URL,其行爲跟「svn update」很像,也會將 服務器上文件與本地文件合併。這是將工做副本對應到同一倉庫中某個分支或者標記的方法。
二、switch --relocate FROM TO [PATH...]
改寫工做副本的URL元數據,以反映單純的URL上的改變。當倉庫的根URL變更 (好比方案名或是主機名稱變更),可是工做副本仍舊對映到同一倉庫的同一目錄時使用 這個命令更新工做副本與倉庫的對應關係。
1七、解決衝突
svn resolved: 移除工做副本的目錄或文件的「衝突」狀態。
用法: resolved PATH... 注意: 本子命令不會依語法來解決衝突或是移除衝突標記;它只是移除衝突的相關文件,而後讓 PATH 能夠再次提交。
1八、輸出指定文件或URL的內容。
svn cat 目標[@版本]...若是指定了版本,將從指定的版本開始查找。 svn cat -r PREV filename > filename (PREV 是上一版本,也能夠寫具體版本號,這樣輸出結果是能夠提交的)
svn
3、 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這個樹的一個新的工做副本。 spa
4、SVN 經常使用命令一覽表 .net
命令 | 功能 | 使用格式 |
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" |
SVN實例
刪除目錄下全部的 .svn 隱藏子目錄
find . -name ".svn" -print0 | xargs -0 rm -rf
tags打分支
svn cp trunk/ tags/platform_2011.11.11 (或 svn cp http://192.168.1.100/platform/trunk/ http://192.168.1.100/platform/tags/platform_2011.11.11)
svn ci -m "svn cp trunk/ tags/platform_2011.11.11" // 提交,並給出提交記錄(-m "svn cp trunk/ tags/platform_2011.11.11")
svn 更名
svn mv platform_2011.11.11 platform_20111111
svn ci -m "svn mv platform_2011.11.11 platform_20111111" // 提交
svn directory is missing
1) svn up missingDirName
2) svn del missingDirName
3) svn ci
SVN(Subversion)是一個自由、開源的項目源代碼版本控制工具。目前,絕大多數開源軟件和企業代碼管理,都使用SVN做爲代碼版本管理軟件。
Subversion將文件存放在中心版本庫裏,這個版本庫很像一個普通的文件服務器。不一樣的是,它能夠記錄每一次文件和目錄的修改狀況,這樣就能夠在須要的回滾時,將數據恢復到之前的版本,並能夠查看數據的更改細節。
SVN 官方網址:Apache Subversion
SVN 服務器配置:安裝SVN服務器
1、 SVN經常使用命令
一、將文件checkout到本地目錄
svn checkout path(path是服務器上的目錄)
簡寫:svn co
二、往版本庫中添加新的文件
svn add file
三、將改動的文件提交到版本庫
svn commit -m 「LogMessage」 [-N] [--no-unlock] PATH(若是選擇了保持鎖,就使用–no-unlock開關)
簡寫:svn ci
四、加鎖/解鎖
svn lock -m 「LockMessage」 [--force] PATH
svn unlock PATH
五、更新到某個版本
svn update -r m path
簡寫:svn up
六、查看文件或者目錄狀態
1)svn status path(目錄下的文件和子目錄的狀態,正常狀態不顯示)
2)svn status -v path(顯示文件和子目錄狀態)
簡寫:svn st
七、刪除文件
svn delete path -m 「delete test fle」
簡寫:svn (del, remove, rm)
八、查看日誌
svn log path
九、查看文件詳細信息
svn info path
十、比較差別
svn diff path(將修改的文件與基礎版本比較)
svn diff -r m:n path(對版本m和版本n比較差別)
簡寫:svn di
十一、將兩個版本之間的差別合併到當前文件
svn merge -r m:n path
十二、SVN 幫助
svn help
svn help ci
2、 SVN不經常使用命令
1三、版本庫下的文件和目錄列表
svn list path 顯示path目錄下的全部屬於版本庫的文件和目錄簡寫:svn ls
1四、建立歸入版本控制下的新目錄
svn mkdir: 建立歸入版本控制下的新目錄。
用法:
一、mkdir PATH...
每個以工做副本 PATH 指定的目錄,都會建立在本地端,而且加入新增調度,以待下一次的提交。
二、mkdir URL... 建立版本控制的目錄。
每一個以URL指定的目錄,都會透過當即提交於倉庫中建立。在這兩個狀況下,全部的中間目錄都必須事先存在。
1五、恢復本地修改
svn revert: 恢復原始未改變的工做副本文件 (恢復大部份的本地修改)。
用法: revert PATH... 注意: 本子命令不會存取網絡,而且會解除衝突的情況。可是它不會恢復被刪除的目錄
1六、代碼庫URL變動
svn switch (sw): 更新工做副本至不一樣的URL。
用法:
一、switch URL [PATH]
更新你的工做副本,映射到一個新的URL,其行爲跟「svn update」很像,也會將 服務器上文件與本地文件合併。這是將工做副本對應到同一倉庫中某個分支或者標記的方法。
二、switch --relocate FROM TO [PATH...]
改寫工做副本的URL元數據,以反映單純的URL上的改變。當倉庫的根URL變更 (好比方案名或是主機名稱變更),可是工做副本仍舊對映到同一倉庫的同一目錄時使用 這個命令更新工做副本與倉庫的對應關係。
1七、解決衝突
svn resolved: 移除工做副本的目錄或文件的「衝突」狀態。
用法: resolved PATH... 注意: 本子命令不會依語法來解決衝突或是移除衝突標記;它只是移除衝突的相關文件,而後讓 PATH 能夠再次提交。
1八、輸出指定文件或URL的內容。
svn cat 目標[@版本]...若是指定了版本,將從指定的版本開始查找。 svn cat -r PREV filename > filename (PREV 是上一版本,也能夠寫具體版本號,這樣輸出結果是能夠提交的)
3、 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這個樹的一個新的工做副本。
4、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" |
SVN實例
刪除目錄下全部的 .svn 隱藏子目錄
find . -name ".svn" -print0 | xargs -0 rm -rf
tags打分支
svn cp trunk/ tags/platform_2011.11.11 (或 svn cp http://192.168.1.100/platform/trunk/ http://192.168.1.100/platform/tags/platform_2011.11.11)
svn ci -m "svn cp trunk/ tags/platform_2011.11.11" // 提交,並給出提交記錄(-m "svn cp trunk/ tags/platform_2011.11.11")
svn 更名
svn mv platform_2011.11.11 platform_20111111
svn ci -m "svn mv platform_2011.11.11 platform_20111111" // 提交
svn directory is missing
1) svn up missingDirName
2) svn del missingDirName
3) svn ci
參考推薦: