SVN是一种版本管理系统,前身是CVS,是开源软件的基石。即使在沟通充分的情况下,多人维护同一份源代码的一定也会出现混乱的情况,版本管理系统就是为了解决这些问题。
SVN中的一些概念 :
a. repository(源代码库)
源代码统一存放的地方。
b. Checkout (提取)
当你手上没有源代码的时候,你需要从repository checkout一份。
c. Commit (提交)
当你已经修改了代码,你就需要Commit到repository。
d. Update (更新)
当你已经Checkout了一份源代码, Update一下你就可以和Repository上的源代码同步,你手上的代码就会有最新的变更。
Centos 搭建SVN服务,有效的管理代码,以下三步可以快速搞定。
1、安装
[root@www ~]# yum install subversion
[root@www ~]# svn -v 判断是否安装成功 svnserve, version 1.6.11 (r934486) 出现类型提示,说明安装成功。
有了SVN软件后还需要建立SVN库。 [root@www ~]# mkdir /opt/svn/repos [root@www ~]# svnadmin create /opt/svn/repos 执行上面的命令后,自动在repos下建立多个文件, 分别是conf, db,format,hooks, locks, README.txt。
|
2、配置
上面的操作很简单,几个命令就搞定, 下面的操作也不难。
进入上面生成的文件夹conf下,进行配置, 有以下几个文件authz, passwd, svnserve.conf
其中authz 是权限控制,可以设置哪些用户可以访问哪些目录, passwd是设置用户和密码的, svnserve是设置svn相关的操作。
2 .1先设置passwd [root@www ~]# vi passwd [users] # harry = harryssecret # sally = sallyssecret hello=123 用户名=密码
这样我们就建立了hello用户, 123密码
2.2 再设置权限authz [root@www ~]# vi authz
[/] hello= rw
意思是hello用户对所有的目录有读写权限,当然也可以限定。 如果是自己用,就直接是读写吧。
2.3最后设定snvserv.conf [root@www ~]# vi snsvserv.conf
anon-access = none # 使非授权用户无法访问 auth-access = write # 使授权用户有写权限 password-db = password #authz-db = authz # 访问控制文件 realm = /opt/svn/repos # 认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字。 采用默认配置. 以上语句都必须顶格写, 左侧不能留空格, 否则会出错.
|
好了,通过以上配置,你的svn就可以了。
3、连接
[root@www ~]# svnserve -d -r /opt/svn/repos 启动svn:
如果已经有svn在运行,可以换一个端口运行 [root@www ~]# svnserve -d -r /opt/svn/repos --listen-port 3391
这样同一台服务器可以运行多个svnserver
好了,启动成功后,就可以使用了。 建议采用TortoiseSVN, 连接地址为: svn://your server address (如果指定端口需要添加端口 :端口号)
连接后可以上传本地的文件,有效的管理你的代码。
|
svn 命令详解
1、将文件checkout到本地目录
svn checkout path(path是服务器上的目录)
例如:svn checkout svn://192.168.1.1/pro/domain
简写:svn co
2、往版本库中添加新的文件
svn add file
例如:svn add test.php(添加test.php)
svn add *.php(添加当前目录下所有的php文件)
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、加锁/解锁
svn lock -m “LockMessage“ [--force] PATH
例如:svn lock -m “lock test file“ test.php
svn unlock PATH
5、更新到某个版本
svn update -r m path
例如:
svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
svn update -r 200 test.php(将版本库中的文件test.php还原到版本200)
svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit)
简写:svn up
6、查看文件或者目录状态
1)svn status path(目录下的文件和子目录的状态,正常状态不显示)
【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
2)svn status -v path(显示文件和子目录状态)
第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
简写:svn st
7、删除文件
svn delete path -m “delete test fle“
例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete test file”
或者直接svn delete test.php 然后再svn ci -m ‘delete test file‘,推荐使用这种
简写:svn (del, remove, rm)
8、查看日志
svn log path
例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化
9、查看文件详细信息
svn info path
例如:svn info test.php
10、比较差异
svn diff path(将修改的文件与基础版本比较)
例如:svn diff test.php
svn diff -r m:n path(对版本m和版本n比较差异)
例如:svn diff -r 200:201 test.php
简写:svn di
11、将两个版本之间的差异合并到当前文件
svn merge -r m:n path
例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)
12、SVN 帮助
svn help
svn help ci
13、版本库下的文件和目录列表
svn list path
显示path目录下的所有属于版本库的文件和目录
简写:svn ls
分享到:
相关推荐
在linux下的svn英文版使用手册,包括一些常用命令和基本操作
Linux SVN的安装使用笔记 .
离线状态下安装linuxsvn支持redhat5.8和centos6.4,有各个依赖安装包,适合linux系统纯净安装的
linux svn客户端使用,包括 文件上传,下载,更新,查看版本,修改,添加。。。
linux 下 SVN 1.6.1 的安装部署流程,包含软件下载的路径。后续我会在我的CSDN中提供相关软件下载。 tag 均以 linux SVN 1.6.1 开头。
Linux离线安装svn, 含详细的配置文档和所需的所有相关依赖包,亲测可用。支持svn checkout https://这种格式的(ssl加密协议)
SUSE11G linuxSVN详细配置
linux 下svn 自动备份脚本
svn是近年来崛起的版本管理工具,是cvs的接班人。 本文档提供常用的svn指令
linux下SVN的一些常用的命令,比如常用的导入导出命令
linux svnlinuxSVN版linux64位
linux svn安装手册 支持https://...
Linux安装SVN的全量包,下载之后依次解压安装,可以在Linux环境下搭建SVN客户端
Linux下SVN的搭建与卸载简单步骤概述,已按该步骤完成svn的搭建与使用
eSVN,http://sourceforge.net/projects/esvn,只需要预装Qt,版本是Qt3以上就行,esvn-0.6.12-1.tar.gz很小1.8M,解压后按照说明make,make install就行
linux下SVN环境搭建 linux下SVN环境搭建 linux下SVN环境搭建
NULL 博文链接:https://ericfang.iteye.com/blog/318003
linux下svn升级
本文介绍https+linux+svn服务器搭建的详细过程~
svn在linux下的使用(svn命令)