亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

svn及其使用簡介

發布時間:2020-07-18 11:47:06 來源:網絡 閱讀:452 作者:watertoeast 欄目:軟件技術

版本庫

svn及其使用簡介

Subversion是文件服務系統,一個特別的文件系統。它可以記錄每一次的更改,包括文件和目錄的修改,增刪等。


版本模型

鎖定-修改-解鎖

svn及其使用簡介

鎖定-修改-解鎖方案

拷貝-修改-合并

svn及其使用簡介

拷貝-修改-合并方案

工作拷貝

一個subversion工作拷貝是本地機器一個普通的目錄,保存著一些文件,可以任意編輯文件。工作拷貝時在私有工作區,在明確的做了特定操作之前,subversion不會把修改與其他人的合并,也不會把你的修改展示給別人。

修訂版本

svn及其使用簡介

subversion版本庫

Subversion的修訂號是針對整個目錄樹的,而不是單個文件。每一個修訂號代表了一次提交后版本庫整個目錄樹的特定狀態,另一種理解是修訂號N代表版本庫已經經過了N次提交。同一時刻倉庫中所有文件都處于同一個修訂版本。


Cvs是針對每個文件進行。在同一個時刻,倉庫中的文件可能處于不同的修訂版本。如圖四所示,文件名后面的數字代表此文件的修訂版本。

svn及其使用簡介

cvs版本庫示意

分支和標簽

分支

svn及其使用簡介

開發分支

用途:針對不同的小需求,維護不同的版本;協作開發時,個別人員可在分支上進行開發,在適當時間合并到主干上來。

Subversion的分支存在于真實的正常文件系統中,并不是存在于另外的維度,這些目錄只是保留了額外的歷史信息。如下面的目錄結構,三個分支都有目錄與之對應,只是他們的歷史信息不一樣,如圖五所示,分支1可能從修訂版本n拷貝過來,分支2則可能是從修訂版本m拷貝過來,分支3則可能從修訂版本k拷貝過來(mnk)。

C:\USERS\SIY\PROJ

├─branch

├─branch2

├─branch3

└─branch4

├─tags

└─trunk

標簽

用途:保存發布的版本。

Subversion的標簽和分支一樣,也存在于真實的文件系統中。開發人員時間軟件功能后,向用戶發布時,應該將發布的源代碼,文檔,二進制文件拷貝一份作為備份,這個備份通常可以叫做標簽。這些標簽不再做任何更改,一直保存在倉庫中。

C:\USERS\SIY\PROJ

├─branch

├─branch2

├─branch3

└─branch4

├─tags

├─proj_1.0.0.1

├─proj_1.0.0.2

└─proj_2.0.0.0

└─trunk


本質上講,分支和標簽沒有本質的區別,只是開發者人為的劃分,它們都是主干上的一個拷貝而已。


要生成分支或者標簽只需要使用svncopy命令拷貝相應目錄即可,具體可svnhelp copy查看幫助。

使用心得

圖形界面vs命令行

1、查看工作拷貝中哪些目錄、哪些文件做了修改?

svn及其使用簡介

svn及其使用簡介



D:\work\workspace>svnst

?       trunk\Release

?       trunk\Debug

?       trunk\controlled.opt

?       trunk\controlled.ncb

?       trunk\test\Release

?       trunk\test\test.plg

?       trunk\Controller\Controller_i.c

?       trunk\Controller\Release

?       trunk\Controller\Controller_i.h

?       trunk\Controller\Debug

?       trunk\Controller\res\Thumbs.db

M       trunk\Controller\ForwardMgrSplit.cpp

!       trunk\test_lib\test_lib.ncb

......

很顯然,圖形界面直觀方便。

2、對比工作拷貝最新狀態和原始狀態的區別。

圖形界面無法對整個目錄進行對比操作,操作很繁瑣;如果查看每個文件的不同,并且每個文件都提交的話,在文件很多的情況下,會形成過多的修訂版本。

命令行可對整個目錄進行比較操作,可方便查看每個不同之處、了解整體的修改情況、對整個文件夾進行提交。

3、提交修改文件。

圖形界面提交:可對整個文件夾進行提交,但無法同時查看所有修改,不便寫修改日志;每個文件提交一次產生過多的修訂版本。

命令行提交:可對整個文件夾進行提交,可同時查看所有修改,方便寫修改日志。

4、備份和恢復操作。

tortoise svn的圖形界面中未發現此功能……

命令行備份svnadmin dump 倉庫路徑 > proj1.dump (可以對指定的修訂版本進行備份,具體看命令的幫助)

命令行恢復:

svnadmin create 倉庫路徑

svnadmin load 倉庫路徑 < proj1.dump


圖形界面和命令行可結合使用,以命令行為主,圖形界面主要用于查看哪些目錄哪些文件被修改。

工作流程

1、單人工作過程

l創建倉庫

svnadmin create 倉庫路徑

如:svnadmin create e:\mycode\proj1

若倉庫已經存在則跳過

l導入

svn import 本地路徑倉庫路徑

svn import e: \proj1svn:///e:/mycode/proj1   (內網搭建的是https的訪問方式)

若已經導入則跳過。導入之后可將proj1刪除,真正要編輯的文件要從倉庫中導出。

l導出

svn checkout 倉庫路徑本地路徑

如:svn checkout svn:///e:/mycode/proj1 e:\work\proj1

checkout可簡寫成co,若已經有本地副本則跳過

l更新

svn update

如:進入e:\work\proj1svn update

l修改

進行正常的編程,對于文件的刪除添加等操作應該使用svn delsvn add等操作,不能直接使用資源管理器進行操作,否則svn服務器無法知曉。

l提交

svn commit –m “日志

或者

svn commit (需要配置編輯器),見注冊表文件按editor.reg,此處配置的gvim


2、多人協作過程

l創建倉庫

l導入

l導出

l更新

l修改

l提交

l處理沖突

l再提交

基本和單人的工作過程一致,多了沖突處理。

3、備份還原

這個在代碼遷移中很常用(比如兩個物理隔離網絡之間的代碼遷移)。

svnadmin dump 倉庫路徑 > proj1.dump (可以對指定的修訂版本進行備份,具體看命令的幫助)

命令行恢復:

svnadmin create 倉庫路徑

svnadmin load 倉庫路徑 < proj1.dump



向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蕲春县| 肥东县| 濮阳市| 定远县| 天峨县| 南漳县| 台州市| 准格尔旗| 周口市| 濉溪县| 嘉鱼县| 铜鼓县| 枣强县| 西盟| 巴林右旗| 丹凤县| 依安县| 常德市| 泾源县| 溧阳市| 屏山县| 阜平县| 克山县| 乌兰浩特市| 阳泉市| 阳高县| 土默特右旗| 济阳县| 烟台市| 通州市| 环江| 平利县| 崇文区| 达日县| 霍城县| 丹凤县| 通山县| 庆云县| 行唐县| 梓潼县| 德清县|