Skip to content

Latest commit

 

History

History
331 lines (241 loc) · 6.17 KB

svn.md

File metadata and controls

331 lines (241 loc) · 6.17 KB

CentOS7安装使用svn

安装部署

安装SVN

yum install httpd subversion mod_dav_svn
rpm -ql subvserion # 查看 subversion 安装位置

OK 这样就完成了安装。下面是SVN的配置:

验证安装

svnserve --version

# svnserve,版本 1.7.14 (r1542130)
#    编译于 Aug 23 2017,20:43:38
# 
# 版权所有 (C) 2013 Apache 软件基金会。
# 此软件包含了许多人的贡献,请查看文件 NOTICE 以获得更多信息。
# Subversion 是开放源代码软件,请参阅 http://subversion.apache.org/ 站点。
# 
# 下列版本库后端(FS) 模块可用:
# 
# * fs_base : 模块只能操作BDB版本库。
# * fs_fs : 模块与文本文件(FSFS)版本库一起工作。
# 
# Cyrus SASL 认证可用。

代码库创建

SVN软件安装完成后还需要建立SVN库

mkdir -p /opt/svn/repo
svnadmin create /opt/svn/repo

执行上面的命令后,自动建立repo库,查看/opt/svn/repo 文件夹发现包含了conf, db,format,hooks, locks, README.txt等文件,说明一个SVN库已经建立。

配置用户

/source/svn/【项目文件】/conf目录下有三个文件:

  • passwd : 里面保存用户信息,基本格式为:user = passwd
  • authz : 里面保存用户的分组信息,以及每个组的访问权限
  • svnserve.conf : 里面保存服务器的基本配置(下面介绍)

添加用户

passwd 文件中添加用户。

[users]
harry = harry123
sally = sally123
wcj = wcj123

配置用户权限

authz 文件中配置用户权限。

[groups]
admin = harry,sally

# 该项目的权限配置
[/]
@admin=rw      # admin分组配置读写权限(实际中可以增加只读分组)

wcj=rw # wcj   # 用户的权限为读写
* = r          # 其他用户的权限为只读

svnserve.conf配置

[general]
# 匿名用户权限(none:拒绝, write:读写, read:只读权限)
anon-access = none
auth-access = write

authz-db = authz

# 这个配置我给删除了,多数教程填写工程 /opt/svn/repo 目录
# 我测试没有什么卵用
# realm = My First Repository

启动svn

配置防火墙端口

vi /etc/sysconfig/iptables
# 添加以下内容:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3690 -j ACCEPT

# 或者下面方式
# 开启3690端口的命令,在终端输入以下命令:
iptables -I INPUT -i eth0 -p tcp --dport 3690 -j ACCEPT
iptables -I OUTPUT -o eth0 -p tcp --sport 3690 -j ACCEPT
# 保存后重启防火墙
service iptables save
service iptables restart

启动SVN

注意,创建的工程repo 启动指定目录为/opt/svn 而不是 /opt/svn/repo 这里是非常深的坑哦。

svnserve -d -r /opt/svn

启动报警告

svnserve -d -r /opt/svn
svnserve: warning: cannot set LC_CTYPE locale
svnserve: warning: environment variable LC_CTYPE is UTF-8
svnserve: warning: please check that your locale name is correct

解决方法

echo "export LC_ALL=C" >> /etc/profile

查看SVN进程

ps -ef|grep svn|grep -v grep
# root     24394     1  0 23:32 ?        00:00:00 svnserve -d -r /opt/svn

检测SVN 端口

netstat -ln |grep 3690
tcp        0      0 0.0.0.0:3690            0.0.0.0:*               LISTEN

停止重启SVN

killall svnserve # 停止
svnserve -d -r /opt/svn # 启动

简单SVN命令

下载克隆项目

# 下载项目
svn checkout 'url'
# 简写
svn co 'url'
# 实例
svn checkout path(path是服务器上的目录)
svn checkout svn://192.168.1.1/pro/domain

添加

# 添加指定文件或目录
svn add 'file''dir'

# 添加所有目录文件
svn add *

# 创建纳入版本目录
svn mkdir -m 'commit message' 'url/dir'

删除

删除指定文件
svn delete 'file'
推荐组合
svn delete 'file name'
svn commit -m 'delete file name'

提交修改

# 提交指定文件
svn commit -m 'commit message' 'file'

# 提交所有文件
svn commit -m 'commit message'
# 简写
svn ci -m

查看状态

# 查看文件或目录状态
svn status 'file''dir'
# 简写
svn st 'file''dir'

正常状态不显示

?:不在svn的控制中
M:内容被修改
C:发生冲突
A:预定加入到版本库
K:被锁定

查看日志

# 看指定文件日志
svn log 'file'

# 查看指定文件详细信息
svn info 'file'

# 查看指定目录文件列表
svn list 'dir'

更新

# 更新指定文件
svn update 'file'

# 更新所有文件
svn update

锁定

# 加锁指定文件
svn lock -m 'commit message' 'file'  

# 解锁指定文件
svn unlock 'file'

比较差异

比较指定文件差异
svn diff 'file'  

对指定文件的版本1和版本2比较差异
svn diff -r version1:version2 'file'  

分支

从分支A新建出一个分支B
svn copy branchA branchB -m 'commit message'    

解决冲突

svn resolved 
# 产生冲突是,会生成三个新的文件,
# svn resolved除了删除冲突文件,
# 还修正了一些记录在工作拷贝管理区域的记录数据

帮助

svn help