说明:

SVN(subversion)的运行方式有两种:

一种是基于Apache的http、https网页访问形式,还有一种是基于svnserve的独立服务器模式。

SVN的数据存储方式也有两种:一种是在Berkeley DB数据库中存储数据;另一种是使用普通的文件FSFS存储数据。由于Berkeley DB方式在使用中有可能锁住数据,一般建议使用FSFS方式更安全。

实现目的:

以svnserve的独立服务器模式,使用FSFS数据存储方式源码编译安装配置SVN服务器。

准备篇

一、关闭SELINUX

vi /etc/selinux/config

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq! #保存退出

setenforce 0 #使配置立即生效

二、开启防火墙端口

基于svnserve的独立服务器模式,默认端口为3690

CentOS 7.x默认使用的是firewall作为防火墙,这里改为iptables防火墙。

1、关闭firewall:

systemctl stop firewalld.service #停止firewall

systemctl disable firewalld.service #禁止firewall开机启动

yum remove firewalld # 卸载firewall

2、安装iptables防火墙

yum install iptables-services #安装

vi /etc/sysconfig/iptables #编辑防火墙配置文件

# you can edit this manually or use system-config-firewall

# please do not ask us to add additional ports/services to this default configur

ation

*filter

:INPUT ACCEPT [0:0]

:FORWARD ACCEPT [0:0]

:OUTPUT ACCEPT [0:0]

-A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT

-A INPUT -p icmp -j ACCEPT

-A INPUT -i lo -j ACCEPT

-A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT

-A INPUT -p tcp -m state --state NEW -m tcp --dport 3690 -j ACCEPT

-A INPUT -j REJECT --reject-with icmp-host-prohibited

-A FORWARD -j REJECT --reject-with icmp-host-prohibited

COMMIT

:wq! #保存退出

systemctl restart iptables.service #最后重启防火墙使配置生效

systemctl enable iptables.service #设置防火墙开机启动

/usr/libexec/iptables/iptables.init restart #重启防火墙

安装篇

1、测试安装环境

#lsb_release –a

#uname –a

2、安装软件

(1)安装软件

# yum -y install subversion

subversion安装在/usr/bin目录 :which svnserve

(2)测试软件是否安装成功

#svnserve --version

3、新建一个目录用于存储SVN所有文件

subversion默认以/var/svn作为数据根目录,可以通过/etc/sysconfig/svnserve修改这个默认位置。

修改/etc/sysconfig/svnserver将默认目录指定到/opt/svn。

OPTIONS="-r /var/svn" =>OPTIONS="-r /opt/svn"

使用svnadmin建立版本库lehuo。

该目录是SVN根目录,后期可以再执行新建版本库的命令用来创建多个项目

#mkdir -p /opt/svn

新建一个版本库,并初始化

#svnadmin create /opt/svn/lehuo

[root@VM_67_242_centos lehuo]# ll

total 24

-rw-r--r-- 1 root root  229 Mar 23 09:45 README.txt

drwxr-xr-x 2 root root 4096 Mar 23 10:19 conf

drwxr-sr-x 6 root root 4096 Mar 23 09:45 db

-r--r--r-- 1 root root    2 Mar 23 09:45 format

drwxr-xr-x 2 root root 4096 Mar 23 09:45 hooks

drwxr-xr-x 2 root root 4096 Mar 23 09:45 locks

4、用户账号权限配置

(1)修改版本库的配置文件

#vim/opt/svn/lehuo/conf/svnserve.conf

[general]

anon-access = none   #使非授权用户无法访问

auth-access = write  #使授权用户有写权限

password-db = passwd #指明密码文件路径

authz-db = authz     #访问控制文件

realm = lehuo #认证命名空间,subversion会在认证提示里显示,并且作为凭证缓存的关键字,其它采用默认配置. 各语句都必须顶格写, 左侧不能留空格,等号两边有空格, 否则会出错.

(2)修改允许访问版本库的用户文件

#vim /opt/svn/lehuo/conf/passwd

文件格式如下所示:

[users] //不可省略

chengyuan1 = chengyuan1

chengyuan2 = chengyuan2

test = 123   //用户名密码对,每个用户一行,各语句都必须顶格写, 左侧不能留空格,等号两边有空格

(3)修改用户访问版本库的权限

#vim /opt/svn/lehuo/conf/authz

注意:权限配置文件中出现的用户名必须在passwd文件中有定义过,对权限配置文件authz的修改会立即生效,此配置文件采用“基于路径的授权”策略,中括号里指定路径,以下列出对各用户的授权。还可以对用户分组。

文件格式如下所示:

用户组格式:

[groups]

#user_group_name = username1,username2 //用户间以逗号分割, 组名 = 成员1,成员2

lehuo = chengyuan1,chengyuan2

版本库目录格式:

[test:/project/directory] //版本库:/项目/目录

@user_group_name = permissions //用户组名=权限

username = permissions //用户名=权限

[lehuo:/]

@lehuo = rw  # 配置用户组的权限

test = r         # 配置单个用户的权限

* =

注意:配置项所有的行都必须顶格,否则报错。

[]可以有多种定义/表示对全部的版本库设置权限,oil:/表示对oil版本库设置权限,oil:/www表示对oil中的www项目设置权限,oil:/www/example.com表示对oil中的www项目的example.com目录设置权限。可以用*来表示所有用户。权限可以设置为w,r,wr和空,空表示没有任何权限。

5、SVN服务

启动SVN服务。

#killall svnserve

#systemctl start svnserve.service

#svnserve -d -r /opt/svn/lehuo   # 启动具体的某一个项目

检查服务是否启动成功。

#ps aux | grep svn
root      16349  0.0  0.1
162180   900
?        Ss   15:01   0:00
/usr/bin/svnserve --daemon --pid-file=/run/svnserve/svnserve.pid
-r /opt/svn

通过netstat可以看到SVN打开了3690端口。

#netstat -tnlp
Proto Recv-Q Send-Q Local Address          
Foreign Address         State       PID/Program name   
tcp        0      0 0.0.0.0:3690            0.0.0.0:*               LISTEN      16349/svnserve

设置成开机启动。

#systemctl enable
svnserve.service

注意:如果在一台服务器上同时启动多个版本管理,那么启动路径必须是所有项目仓库的根路径

加入开机启动(echo ‘/usr/bin/svnserve -d -r /opt/svn>> /etc/rc.local)

此时SVN服务器配置完成,访问地址为:svn://IP/lehuo

仓库中没有任何文件信息,版本号为0

CentOS 7.2 x64 配置SVN服务器的更多相关文章

  1. CentOS 7下搭建配置SVN服务器

    CentOS 7下搭建配置SVN服务器 1. 安装 CentOS通过yum安装subversion. $ sudo yum install subversion subversion安装在/bin目录 ...

  2. Centos apache + mysql + usvn 配置svn 服务器

    1.遇到问题 提交异常:'svn/!svn/me'path not found http://www.myexception.cn/cvs-svn/1262826.html 更改http.conf 配 ...

  3. CentOS 7下搭建配置 SVN 服务器

    原文链接:https://www.cnblogs.com/tdalcn/p/6937714.html 同步:http://blog.csdn.net/u011884440/article/detail ...

  4. 阿里云服务器centos下安装配置svn服务器

      阿里云服务器centos下安装配置svn服务器 1.安装svn服务器端yum install subversion      从镜像下载安装svn服务器端中间会提示是否ok,输入y,确认安装成功提 ...

  5. CentOS 6.6安装配置LAMP服务器(Apache+PHP5+MySQL)

    准备篇: CentOS 6.6系统安装配置图解教程 http://www.osyunwei.com/archives/8398.html 1.配置防火墙,开启80端口.3306端口 vi /etc/s ...

  6. CentOS 6.5安装配置LNMP服务器(Nginx+PHP+MySQL)

    CentOS 6.5安装配置LNMP服务器(Nginx+PHP+MySQL) 一.准备篇: /etc/init.d/iptables stop #关闭防火墙 关闭SELINUX vi /etc/sel ...

  7. CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)

    这篇文章主要介绍了CentOS 6.4安装配置LAMP服务器(Apache+PHP5+MySQL)的方法,需要的朋友可以参考下 文章写的不错,很详细:IDO转载自网络: 准备篇: 1.配置防火墙,开启 ...

  8. CentOS 7.0安装配置LAMP服务器(Apache+PHP+MariaDB)

    CentOS 7.0默认使用的是firewall作为防火墙,这里改为iptables防火墙. 1.关闭firewall: systemctl stop firewalld.service #停止fir ...

  9. 如何配置svn服务器

    如果你已经安装好了VisualServer服务器,现在让我们一起来配置svn服务器吧. 工具/原料 VisualServer 配置VisualServer 找到VisualServer Manager ...

随机推荐

  1. $().attr()的使用方法 && $().html()与$().text()的差别

    <1>$().attr()的使用方法 </pre><pre class="html" name="code"><htm ...

  2. 初探Java中的异常处理

      Java中的异常有以下几种: 1) Error:Java运行时的内部错误. 2) Exception:程序中应该捕获的异常.          RuntimeException:因为编程产生的错误 ...

  3. java的死锁学习

    学习java的死锁写的代码 也是看书上的然后自己敲了一个 <span style="font-size:18px;">package synchronization.j ...

  4. IOS6.0自带下拉刷新控件UIRefreshControl

    1.UIRefreshControl必需要在IOS6.0以后才干使用,同一时候他仅仅能在UITableViewController类中才干够使用 2.使用比較简单 self.refreshContro ...

  5. C++中的inline的用法

    C++中的inline的用法  参考:http://www.cnblogs.com/fnlingnzb-learner/p/6423917.html 1. 引入inline关键字的原因 在c/c++中 ...

  6. .NET页面事件执行顺序

    摘自:http://www.cnblogs.com/kenkofox/archive/2011/03/18/1987998.html和http://blog.csdn.net/yiruoyun/art ...

  7. leetcode数组相关

    目录 4寻找两个有序数组的中位数 11盛最多水的容器,42接雨水 15三数之和,16最接近的三数之和,18四数之和 26/80删除排序数组中的重复项, 27移除元素 31下一个排列 53最大子序和 5 ...

  8. 单向链表的归并排序——java实现

    在做Coursera上的Algorithms第三周测验练习的时候有一道链表随机排序问题,刚开始没有什么思路,就想着先把单向链表归并排序实现了,再此基础上进行随机排序的改造.于是就结合归并排序算法,实现 ...

  9. aspectC++常用命令

    常用命令:1.ag++ main.cc //在工程目录下产生编译后的exe2.ag++ main.cc --weave_only //产生.acc 纯c++文件3.ag++ main.cc --gen ...

  10. bzoj 3172 单词

    3172: [Tjoi2013]单词 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 3937  Solved: 1912[Submit][Status ...