SVN服务器有2种运行方式:
1、独立服务器 (例如:svn://xxx.com/xxx);
2、借助apache   (例如:http://svn.xxx.com/xxx);
为了不依赖apache,我选择第一种方式:独立的svn服务器。
SVN存储版本数据也有2种方式:
1、bdb;
2、fsfs。
由于bdb方式在服务器中断时,有可能锁住数据,所以还是fsfs方式更安全一点,我也选择这种方式。
具体部署:
1.下载subversion安装包

[root@server ~]# cd /usr/local/src
[root@server src]# ls
[root@server src]# wget http://subversion.tigris.org/downloads/subversion-1.6.6.tar.gz
[root@server src]# wget http://subversion.tigris.org/downloads/subversion-deps-1.6.6.tar.gz
[root@server src]# tar xfvz subversion-1.6.6.tar.gz
[root@server src]# tar xfvz subversion-deps-1.6.6.tar.gz
[root@server src]# cd subversion-1.6.6
[root@server subversion-1.6.6]#

2.编译SVN
首先检测系统有没有安装SSL:

[root@server subversion-1.6.6]# find / -name opensslv.h
[root@server subversion-1.6.6]#

找不到,就执行如下命令进行安装:

[root@server subversion-1.6.6]# yum install openssl
[root@server subversion-1.6.6]# yum install openssl-devel 

安装之后用find / -name opensslv.h命令找到opensslv.h所在的目录,即下列--with-openssl=后面的路径,编译:

[root@server subversion-1.6.6]# find / -name opensslv.h
/usr/include/openssl/opensslv.h
[root@server subversion-1.6.6]# ./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db

注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db。
此时编译报如下错误:

configure: WARNING: unrecognized options: --with-openssl
configure: Configuring Subversion 1.6.6
configure: creating config.nice
checking for gcc... no
checking for cc... no
checking for cl.exe... no
configure: error: in `/usr/local/src/subversion-1.6.6':
configure: error: no acceptable C compiler found in $PATH
See `config.log' for more details.

说明没有安装gcc相关库,使用如下命令安装gcc后再编译:

[root@server subversion-1.6.6]# yum -y install gcc
[root@server subversion-1.6.6]# ./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db 

最后出现下面WARNING,直接忽略即可,因为不使用BDB存储。

configure: WARNING: we have configured without BDB filesystem support
You don't seem to have Berkeley DB version 4.0.14 or newer
installed and linked to APR-UTIL. We have created Makefiles which
will build without the Berkeley DB back-end; your repositories will
use FSFS as the default back-end. You can find the latest version of
Berkeley DB here:
http://www.sleepycat.com/download/index.shtml 

3.安装SVN
为避免出现以下错误

error while loading shared libraries: libiconv.so.2: cannot open shared object file: No such file or directory

先执行以下操作:
1)、编辑/etc/ld.so.conf文件,添加下面一行:

/usr/local/lib

2)、保存后运行ldconfig:

/sbin/ldconfig

注:ld.so.conf和ldconfig用于维护系统动态链接库。
安装

[root@server subversion-1.6.6]# make && make install

安装完成,执行以下命令测试:

[root@server subversion-1.6.6]# /usr/local/svn/bin/svnserve --version

svnserve,版本 1.6.6 (r40053)
   编译于 Feb 15 2012,22:15:26

版权所有 (C) 2000-2009 CollabNet。
Subversion 是开放源代码软件,请参阅 http://subversion.tigris.org/ 站点。
此产品包含由 CollabNet(http://www.Collab.Net/) 开发的软件。

下列版本库后端(FS) 模块可用:

* fs_fs : 模块与文本文件(FSFS)版本库一起工作。

为了方便下操作,下面将SVN的BIN添加到PATH,编辑/etc/profile,添加:

PATH=/usr/local/svn/bin:$PATH

保存后,使其立即生效:

source /etc/profile

4.配置SVN
建立版本库目录,可建多个:

[root@server ~]# mkdir -p /home/svndata/repos       #建立版本库
[root@server ~]# /usr/local/svn/bin/svnadmin create /home/svndata/repos       #修改版本库配置文件

编辑/home/svndata/repos/conf/svnserve.conf,内容修改为:

[general]
anon-access = none
auth-access = write
password-db = /usr/local/svn/conf/passwd.conf
authz-db = /usr/local/svn/conf/authz.conf
realm = repos 

注意:对用户配置文件的修改立即生效,不必重启svn。
在/usr/local/svn/下面新建conf目录,并在/usr/local/svn/conf内新建passwd.conf和authz.conf文件:

mkdir conf
cd conf/
touch passwd.conf
touch authz.conf

添加用户及密码:

[root@server ~]# useradd wll
[root@server ~]# passwd wll

编辑/usr/local/svn/conf/passwd.conf,添加如下代码并保存:

[users]
wll = 123456

配置svn用户访问权限,编辑usr/local/svn/conf/authz.conf,添加如下代码并保存:

[groups]
admin = wll
[/]
@admin = rw
# [repos:/abc/aaa]
# king = rw
# [repos:/pass]
# king =svn

注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
= ,
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
[/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/home/svndata,[/]就是表示对全部版本库设置权限。
[repos:/] 表示对版本库repos设置权限;
[repos:/abc] 表示对版本库repos中的abc项目设置权限;
[repos:/abc/aaa] 表示对版本库repos中的abc项目的aaa目录设置权限;
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。
权限可以是w、r、wr和空,空表示没有任何权限。

建立启动svn的用户:

[root@server ~]# useradd svn
[root@server ~]# passwd svn

允许用户svn访问版本库:

[root@server ~]# chown -R svn:svn /home/svndata 

启动svn:

[root@server ~]# su - svn -c "svnserve -d --listen-port 9999 -r /home/svndata"

其中:
su - svn :表示以用户svn的身份启动svn;
-d :表示以daemon方式(后台运行)运行;
--listen-port 9999 :表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限;
-r /home/svndata :指定根目录是/home/svndata。

5.将svn加入到开机启动
编辑/etc/rc.d/rc.local文件,加入如下启动命令:

/usr/local/svn/bin/svnserve -d --listen-port 9999 -r /home/svndata

如果想停止svn,则使用如下命令:

killall svnserve

如果想将svn作为服务,在/etc/rc.d/init.d/目录下新建名为svn的文件并设置权限为755,并添加如下代码:

#!/bin/bash
# build this file in /etc/rc.d/init.d/svn
# chmod 755 /etc/rc.d/init.d/svn
# centos下可以用如下命令管理svn: service svn start(restart/stop)
SVN_HOME=/home/svndata
if [ ! -f "/usr/local/svn/bin/svnserve" ]
then
    echo "svnserver startup: cannot start"
    exit
fi
case "$1" in
    start)
        echo "Starting svnserve..."
        /usr/local/svn/bin/svnserve -d --listen-port 9999 -r $SVN_HOME
        echo "Finished!"
        ;;
    stop)
        echo "Stoping svnserve..."
        killall svnserve
        echo "Finished!"
        ;;
    restart)
        $0 stop
        $0 start
        ;;
    *)
        echo "Usage: svn { start | stop | restart } "
        exit 1
esac 

6.连接SVN
安装TortoiseSVN,重启系统。启动TortoiseSVN并在地址栏中输入

svn://192.168.1.87:9999/repos

根据提示输入用户名与密码后就可以

CentOS 5.5下搭建部署独立SVN服务器全程详解相关推荐

  1. Windows下搭建Tomcat集群的配置详解

    < Windows下搭建Tomcat集群基础入门详解 > 前言 在搭建 < Apache + Tomcat 实现Web服务器集群 > 前我们还需要实现 Tomcat集群实现Se ...

  2. linux 子域dns,linux下搭建DNS子域及相关授权详解

    linux下搭建DNS子域及相关授权详解forward功能是本地无法解析的域名,转发给指定DNS服务器 forward only; 所有无法解析的域名,都转发给指定DNS服务器,必须有解析结果 for ...

  3. linux下搭建DNS子域及相关授权详解

    linux下搭建DNS子域及相关授权详解 forward功能是本地无法解析的域名,转发给指定DNS服务器 forward only; 所有无法解析的域名,都转发给指定DNS服务器,必须有解析结果 fo ...

  4. linux做子域dns,linux下搭建DNS子域及相关授权详解

    linux下搭建DNS子域及相关授权详解 forward功能是本地无法解析的域名,转发给指定DNS服务器 forward only; 所有无法解析的域名,都转发给指定DNS服务器,必须有解析结果 fo ...

  5. Apache Kafka-初体验Kafka(02)-Centos7下搭建单节点kafka_配置参数详解_基本命令实操

    文章目录 安装JDK 安装zookeeper 安装kafka 下载解压 配置hosts 启动kafka服务 server.properties核心配置详解 基本命令 创建主题 发送消息 消费消息 查看 ...

  6. 启动mongodb服务器时发生系统错误5,CentOS 7系统下SELinux阻止MongoDB启动的问题详解...

    问题描述: 最近发现了一个问题,在新装的CentOS7上,安装了MongoDB3.4,挂载了一个大的数据盘后,修改/etc/mongo.conf,将配置文件中的log和data目录放在新的数据盘下,并 ...

  7. centos 释放swap_CentOS下SWAP分区建立及释放内存详解

    方法一: 一.查看系统当前的分区情况: >free -m 二.创建用于交换分区的文件: >dd if=/dev/zero of=/whatever/swap bs=block_size ( ...

  8. Mac下搭建Cocos2d-x-3.2的开发环境详解

    http://www.yxkfw.com/?p=8180 转载于:https://blog.51cto.com/3387980/1600451

  9. centos linux asp,CentOS 7.4 下 如何部署 AspNetCore 结合 consul

    原标题:CentOS 7.4 下 如何部署 AspNetCore 结合 consul 上篇我们讲到consul的概念,以及在WIN下如何使用: 在Windows 下如何使用 AspNetCore Ap ...

最新文章

  1. java运算符-逻辑、三元运算符
  2. Google、微软、阿里、腾讯、百度这些大公司在GitHub上开源投入排名分析 | CSDN原力计划...
  3. python添加系统环境win7_python环境配置(基于win7 x64)
  4. 中国第五届CSS大会分享:CSS TIME
  5. Pytest之pytest.assume用例中断言1失败会继续执行后续代码断言2
  6. Linux——find命令常见用法
  7. Python使用标准库itertools中count类求解数苹果问题
  8. 理解Python中的继承规则和继承顺序
  9. python爬虫框架学习_学习Python爬虫必备框架:Scrapy
  10. Android日历视图
  11. HANA中SQL之truncate 、delete与drop区别
  12. HttpHandler和ashx要实现IRequiresSessionState接口才能访问Session信息(转载)
  13. python 字符串交集_集合 (Set) | 一山不容二虎的 Python 数据类型
  14. List集合之ArrayList
  15. 伟大程序员必须具备的7个好习惯
  16. (一)一文掌握flink性能优化:资源配置调优
  17. 视频号拍摄技巧和制作方法有哪些?
  18. 51Nod 1677 treecnt
  19. 在ARM芯片中使用打印函数总结
  20. html 字母强制换行,Html 页面的强制换行问题总结

热门文章

  1. Linux 从头学 01:CPU 是如何执行一条指令的?
  2. neo4j python 算法_python操作neo4j简单实例
  3. list java语法_java基础语法 List
  4. mysql使用CONCAT()函数拼接字符串
  5. linux教程opensuse,OpenSUSE/Linux 网络配置
  6. maven添加子工程_重量级!Maven史上最全教程,看了必懂
  7. 后端:SpringBoot集成Swagger-Bootstrap-UI,界面美观!
  8. 关系数据库模式和完整性约束相关概念
  9. 数据迁移,不停机上线的正确姿势
  10. 微软最强命令行工具 Windows Terminal,强势霸榜GitHub