svn的基本流程和用法

基本流程

比如新项目名为test。我本地项目路径为:/home/svn/。远程项目服务端路径为:192.168.0.148/test

 

安装svn

1
sudo apt-get install subversion

 

1,如果本地没有项目,需要导入:

1
2
3
进入/home/svn/
svn checkout svn://192.168.0.148/test
此时/home/svn/下就会自动生成test目录

 

2,更新文件(相当于git中的pull):

1
svn update

 

3,添加文件(相当于git中的add):

1
2
3
svn add xxx.php(文件名)
或者
svn add *

 

4,将改动的文件提交到版本库(相当于git中的push):

1
2
3
svn commit -m '说明文字' xxx.php
或者
svn commit -m '说明文字' *

 

会提示输入密码.确认后没出错的话就提交成功了。
注意:svn的commit跟git的commit不一样,他没有push。他的commit就相当于是push。

 

 

附录

Ubuntu下SVN服务端的配置

1.安装包

1
sudo apt-get install subversion

 

2.创建项目目录

1
2
3
sudo mkdir /home/svn
cd /home/svn/
sudo mkdir test

 

3.创建svn文件仓库

1
sudo svnadmin create /home/svn/test

4.导入项目到svn文件仓库 (可有可无)

1
sudo svn import webftp(文件夹路径) file:///home/svn/test -m "init import"

5.访问权限设置 修改 /home/svn/test/conf目录下:

1
2
3
4
5
6
7
8
9
svnserve.conf 、passwd 个文件,行最前端不允许有空格
编辑svnserve.conf文件,把如下面行取消注释,并需要顶格
anon-access = read
auth-access = write
password-db = passwd
编辑passwd 如下:
[users]
zou = 123
注意:zou是用户名,123是密码

 

6. 开启svnserve,以SVN根目录开启:

1
svnserve -d -r /home/svn

7.检查是否正常启动

1
2
netstat -ntlp
可以看到有一个端口为3690的地址,表示启动成功

8.局域网访问,checkout出来SVN库的文件

1
2
3
svn checkout svn://SvnIp地址/test
或者简写为:
svn co svn://SvnIp地址/test

 

ubuntu SVN命令大全

 

1、将文件checkout到本地目录 svn checkout path(path 是服务器上的目录)

1
2
例如:$ svn checkout svn://192.168.1.1/pro
简写:$ svn co svn://192.168.1.1/pro

 

2、往版本库中添加新的文件

1
2
3
$ svnadd file
$ svn add test.php(添加test.php)
$ svn add *.php(添加当前目录下所有的php文件)

 

3、将改动的文件提交到版本库

1
2
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、更新到某个版本

1
2
3
4
5
$ svn update -rm path
例如:$ svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
$ svn update -r 200 test.php(将版本库中的文件test.php还原到版本200)
$ svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文 件,然后清除
$ svn resolved,最后再提交commit) 简写:svn up

 

5、删除文件

1
2
3
$ svn delete path -m 'delete test fle'
例如:$ svn delete test.php 然后再$ svn ci -m 'delete test file'
简写:svn (del, remove, rm)

 

6、比较差异

1
2
3
4
5
$ svn diff path(将修改的文件与基础版本比较)
例如:$ svn diff test.php
$ svn diff -r m:n path(对版本m和版本n比较差异)
例如:svn diff -r 200:201 test.php
简写:svn di

 

7、查看文件或者目录状态

1
2
3
4
5
6
7
1)svn status path(目录下的文件和子目录的状态,正常状态不显示)
【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
2)svn status -v path(显示 文件和子目录状态)
第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人

注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
简写:svn st

 

8、解决冲突

1
2
3
4
$ svn resolved: 移除工作副本的目录或文件的“冲突”状态。
用法: $ resolved PATH…
注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的
相关文件,然后让 PATH 可以再次提交。

 

坚持原创技术分享,您的支持将鼓励我继续创作!