*リポジトリのレイアウト
1.トランクトランク
トランクが開発のメインラインで、一般的なプロジェクトは、メインラインへと発展しています。
2.支店の支店
枝は通常、あなたが一定の期間で開発された機能を分離したい場合は、一緒に他の機能と混合とは異なり、今回の枝が邪魔をうまく利用され、トランクのバージョンをコピーします。あなたは、開発がそれを完了するまで提出していない、この機能でトランクに開発されている必要はありません。一般的には、トランクにマージします。
3.タグラベル
タグラベルは、定義によって、将来の参照を容易にするために、どのページ、およびマークを作り、見て、ちょうど厚いを読んだように、それのバージョンを記録しています。
ときに反復開発、記録を作成するために、リリースのアプリケーションは、この時間は、タグは非常に実用的なものにします。リリース後は、行は、このタグの再発のバージョンに合わせて修復することができ、バグがありました。
二つは、SVNのサーバーを設定して使用します。
*コードリポジトリ(アップロードされたクライアントを格納するために使用されるコード)を作成します。
最初のステップします。mkdir SVNの:私たちは後で我々は倉庫より多くのディレクトリが内側にあります、新しいディレクトリのsvnを作成してドキュメントディレクトリ(〜/書類)で作成する
ステップ2:、ターミナルを開いて作成するには、次のコマンドを実行呼ばれるTestCodeの倉庫: svnadmin create /Users/liangxiaolong/Documents/SVN/TestCode
*設定のユーザー権利
変更 のsvn / TestCode / confに ファイルフォルダを:
ステップ1:オープンsvnserve.confと前の設定項目を以下、#、およびスペースが削除されます
図VI
アノン・アクセスを=匿名アクセスに代わって時間を読んで読み取り専用である、なしに代わっ匿名アクセスを禁止する代わりに、アノン・アクセス=、あなたがアカウントにアクセスするためのパスワードが必要な場合:注意してください
。ステップ2:変更 passwdのを。で[ ユーザーは(ここで私は二人のユーザーを設定し)]下記の口座番号とパスワードを追加します。
図VII
注:#1 liangxiaolong(アカウント)= liangxiaolong(パスワード)
ステップ3:オープンのauthz、ユーザーグループおよび権限を設定
私たちは、将来的には、ユーザーの異なるグループに割り当てられ、その後、あなたは、ユーザーのグループごとに異なるアクセス権を設定することができ、ユーザーごとに個別の設定権限が必要でないpasswdにユーザーを追加することができます。
[グループ]で、次のグループ名とユーザ名を追加し、カンマで区切って複数のユーザ(、)
1
2
|
[groups]
topgroup=mj,jj
|
さらに権限の設定に続いて、このグループに属しtopgroup説明とMJ JJ、。
すべてのリポジトリを使用して、[/]は、SVNサーバを表し、
1
2
|
[/]
@topgroup =rw
|
上記の設定手順は、目の前にグループ名を使用して、このグループ内のすべてのユーザーがすべてのリポジトリに(RW)権限書き込みを読んだことがあるtopgroup @
ユーザー名は、@を、追加しない場合は、ユーザーなどの読み取りおよび書き込み権限のMJました
1
2
|
[/]
mj=rw
|
ユーザーtopgroupパケットは、読み取り専用とCODE1への書き込みアクセスをしています。
1
|
[/code1]<br> @topgroup = liangxiaolong
|
*スタートのsvnサーバー
非常に多くの目の前の設定、キーは、起動しない場合、通常は、サーバを起動するかどうかを見る前無駄に多くの作業を行うことです。
次の端末入力コマンドで:
1
|
svnserve -d -r /Users/liangxiaolong/Documents/SVN/
|
または次のコマンドを入力します。
1
|
svnserve -d -r /Users/liangxiaolong/Documents/SVN/TestCode
|
それはの打ち上げ成功を示して何のプロンプトはありません
*ストップSVNサーバ
1
|
打开“活动监视器” 。搜索 svn,将进程强制退出即可。
|
第三に、使用のsvnクライアント機能
ここではいくつかの一般的に使用されるコマンドがあります
図1に示すように、ローカルサーバからのコード(第1の初期化の導入)をインポートします
ターミナルで
命令の意味:すべてのコンテンツ/ユーザ/りんご/ドキュメント/ eclipse_workspace / weiboは、二重引用符の後ろに、ディレクトリサーバmycodeのweibo倉庫にアップロードされたノートを「初期化が導入されました」
2、サーバーからクライアントのローカルにコードをダウンロードします
ターミナルで
1
|
svn checkout svn: //localhost/mycode --username=mj --password=123 /Users/apple/Documents/code
|
命令の意味:/ユーザ/りんご/ドキュメント/コードのディレクトリにダウンロードしたウェアハウス・サーバーのmycodeコンテンツ
速記を:
1
|
svn co svn: //localhost/mycode --username=mj --password=123 /Users/apple/Documents/code
|
注意:
なしパラメータ転送--passwordパスワードは、パスワードを入力するように求められます場合は*、--passwordオプションは平文を使用しないことをお勧めします。
*元のユーザー名とパスワードは、二つの短期的ではなく、一つです。
*現在のディレクトリにチェックアウトし、ローカルディレクトリへのフルパスを指定しないでください。
3.サーバーに変更されたコードを送信
サーバーコードでステップ2は、現在、いくつかのコードを変更し、サーバーに変更を提出、その下/ユーザ/りんご/ドキュメント/コードのディレクトリにダウンロードされています
1> 打开终端,先定位到/Users/apple/Documents/code目录,输入:cd /Users/apple/Documents/code
2> 输入提交指令:svn commit -m "修改了main.m文件"
这个指令会将/Users/apple/Documents/code下的所有修改都同步到服务器端,假如这次我只修改了main.文件
可以看到终端的打印信息:
1
2
3
|
Sending weibo/weibo/main.m
Transmitting file data .
Committed revision
|
必须带上-m参数,参数可以为空,但是必须写上-m
例子:
svn commit -m “提交当前目录下的全部在版本控制下的文件“ * <- 注意这个*表示全部文件
svn commit -m “提交我的测试用test.php“ test.php
svn commit -m “提交我的测试用test.php“ -N --no-unlock test.php <- 保持锁就用–no-unlock开关
svn ci -m “提交当前目录下的全部在版本控制下的文件“ * <- 注意这个*表示全部文件
svn ci -m “提交我的测试用test.php“ test.php
svn ci -m “提交我的测试用test.php“ -N --no-unlock test.php <- 保持锁就用–no-unlock开关
4、导出(导出一个干净的不带.svn文件夹的目录树)
svn export [-r 版本号] http://路径(目录或文件的全路径) [本地目录全路径] --username 用户名
svn export [-r 版本号] svn://路径(目录或文件的全路径) [本地目录全路径] --username 用户名
svn export 本地检出的(即带有.svn文件夹的)目录全路径 要导出的本地目录全路径
注:第一种从版本库导出干净工作目录树的形式是指定URL,
如果指定了修订版本号,会导出相应的版本,
如果没有指定修订版本,则会导出最新的,导出到指定位置。
如果省略 本地目录全路径,URL的最后一部分会作为本地目录的名字。
第二种形式是指定 本地检出的目录全路径 到 要导出的本地目录全路径,所有的本地修改将会保留,
但是不在版本控制下(即没提交的新文件,因为.svn文件夹里没有与之相关的信息记录)的文件不会拷贝。
例子:
svn export svn://localhost/测试工具 /home/testtools --username wzhnsc
svn export svn://localhost/test/testapp --username wzhnsc
svn export /home/testapp /home/testtools
5、添加新文件
1
|
svn add 文件名
|
注:告诉SVN服务器要添加文件了,还要用svn commint -m真实的上传上去!
例子:
svn add test.php <- 添加test.php
svn commit -m “添加我的测试用test.php“ test.php
svn add *.php <- 添加当前目录下所有的php文件
svn commit -m “添加我的测试用全部php文件“ *.php
6、更新文件
1
2
3
|
svn update
svn update -r 修正版本 文件名
svn update 文件名
|
例子:
svn update <- 后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本
svn update -r 200 test.cpp <- 将版本库中的文件 test.cpp 还原到修正版本(revision)200
svn update test.php <- 更新与版本库同步。
提交的时候提示过期冲突,需要先 update 修改文件,
然后清除svn resolved,最后再提交commit。
7、删除文件
1
2
3
4
|
svn delete svn: //路径(目录或文件的全路径) -m “删除备注信息文本”
推荐如下操作:
svn delete 文件名
svn ci -m “删除备注信息文本”
|
例子:
svn delete svn://localhost/testapp/test.php -m “删除测试文件test.php”
推荐如下操作:
1
2
|
svn delete test.php
svn ci -m “删除测试文件test.php”
|
8、加锁/解锁
1
2
|
svn lock -m “加锁备注信息文本“ [--force] 文件名
svn unlock 文件名
|
例子:
svn lock -m “锁信测试用test.php文件“ test.php
svn unlock test.php
9、比较差异
1
2
|
svn diff 文件名
svn diff -r 修正版本号m:修正版本号n 文件名
|
例子:
svn diff test.php <-将修改的文件与基础版本比较
svn diff -r 200:201 test.php <- 对 修正版本号200 和 修正版本号201 比较差异
10、查看文件或者目录状态
1
2
3
4
5
6
7
8
|
svn st 目录路径/名
svn status 目录路径/名<- 目录下的文件和子目录的状态,正常状态不显示
【?:不在svn的控制中; M:内容被修改;C:发生冲突;
A:预定加入到版本库;K:被锁定】
svn -v 目录路径/名
svn status -v 目录路径/名<- 显示文件和子目录状态
【第一列保持相同,第二列显示工作版本号,
第三和第四列显示最后一次修改的版本号和修改人】
|
注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,
原因是svn在本地的.svn中保留了本地版本的原始拷贝。
11、查看日志
1
|
svn log 文件名
|
例子:
svn log test.php<- 显示这个文件的所有修改记录,及其版本号的变化
12、查看文件详细信息
1
|
svn info 文件名
|
例子:
svn info test.php
13、SVN 帮助
1
2
|
svn help <- 全部功能选项
svn help ci <- 具体功能的说明
|
14、查看版本库下的文件和目录列表
1
2
|
svn list svn: //路径(目录或文件的全路径)
svn ls svn: //路径(目录或文件的全路径)
|
例子:
1
2
|
svn list svn: //localhost/test
svn ls svn: //localhost/test <- 显示svn://localhost/test目录下的所有属于版本库的文件和目录
|
15、创建纳入版本控制下的新目录
1
2
|
svn mkdir 目录名
svn mkdir -m "新增目录备注文本" http: //目录全路径
|
例子:
1
2
|
svn mkdir newdir
svn mkdir -m "Making a new dir." svn: //localhost/test/newdir
|
注:添加完子目录后,一定要回到根目录更新一下,不然在该目录下提交文件会提示“提交失败”
1
|
svn update
|
注:如果手工在checkout出来的目录里创建了一个新文件夹newsubdir,
再用svn mkdir newsubdir命令后,
SVN会提示:
svn: 尝试用 “svn add”或 “svn add --non-recursive”代替?
svn: 无法创建目录“hello”: 文件已经存在
此时,用如下命令解决:
1
|
svn add --non-recursive newsubdir
|
在进入这个newsubdir文件夹,用ls -a查看它下面的全部目录与文件,会发现多了:.svn目录
再用 svn mkdir -m "添hello功能模块文件" svn://localhost/test/newdir/newsubdir 命令,
SVN提示:
svn: File already exists: filesystem '/data/svnroot/test/db', transaction '4541-1',
path '/newdir/newsubdir '
16、恢复本地修改
1
|
svn revert [--recursive] 文件名
|
注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复被删除的目录。
例子:
1
2
|
svn revert foo.c <- 丢弃对一个文件的修改
svn revert --recursive . <-恢复一整个目录的文件,. 为当前目录
|
17、把工作拷贝更新到别的URL
1
|
svn switch http: //目录全路径 本地目录全路径
|
例子:
1
|
svn switch http: //localhost/test/456 . <- (原为123的分支)当前所在目录分支到localhost/test/456
|
18、解决冲突
1
|
svn resolved [本地目录全路径]
|
例子:
1
2
3
|
$ svn update
C foo.c
Updated to revision 31.
|
如果你在更新时得到冲突,你的工作拷贝会产生三个新的文件:
$ ls
foo.c
foo.c.mine
foo.c.r30
foo.c.r31
当你解决了foo.c的冲突,并且准备提交,运行svn resolved让你的工作拷贝知道你已经完成了所有事情。
你可以仅仅删除冲突的文件并且提交,但是svn resolved除了删除冲突文件,还修正了一些记录在工作拷贝管理区域的记录数据,所以我们推荐你使用这个命令。
19、不checkout而查看输出特定文件或URL的内容
1
|
svn cat http: //文件全路径
|
例子:
1
|
svn cat http: //localhost/test/readme.txt
|
20、新建一个分支copy
1
|
svn copy branchA branchB -m "make B branch" // 从branchA拷贝出一个新分支branchB
|
21、合并内容到分支merge
1
|
svn merge branchA branchB // 把对branchA的修改合并到分支branchB
|