靠谱SVN 服务器搭建步骤以用法

简介:

一、实验环境:

[root@node02 ~]# uname -a

Linux node02 2.6.32-504.el6.x86_64 #1 SMP Wed Oct 15 04:27:16 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux

[root@node02 ~]# cat /etc/redhat-release 

CentOS release 6.6 (Final)

[root@node02 ~]#

[root@node02 ~]# ifconfig eth0

eth0      Link encap:Ethernet  HWaddr 00:0C:29:DF:59:C7  

          inet addr:192.168.112.129  Bcast:192.168.112.255  Mask:255.255.255.0

          inet6 addr: fe80::20c:29ff:fedf:59c7/64 Scope:Link

          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1

          RX packets:37078 errors:0 dropped:0 overruns:0 frame:0

          TX packets:21925 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:1000 

          RX bytes:26850825 (25.6 MiB)  TX bytes:3241796 (3.0 MiB)


[root@node02 ~]# 


二、SVN Apache安装

这里我直接用yum安装

[root@node02 ~]# yum install subversion apr apr-util   mod_dav_svn  httpd

[root@node02 ~]#

[root@node02 ~]# rpm -qa subversion apr apr-util   mod_dav_svn  httpd

apr-util-1.3.9-3.el6_0.1.x86_64

subversion-1.6.11-15.el6_7.x86_64

apr-1.3.9-5.el6_2.x86_64

httpd-2.2.15-55.el6.centos.2.x86_64

mod_dav_svn-1.6.11-15.el6_7.x86_64

[root@node02 ~]# 

查看目录结构:

[root@node02 ~]# tree /etc/httpd/

/etc/httpd/

├── conf

│   ├── httpd.conf

│   └── magic

├── conf.d

│   ├── passwd

│   ├── README

│   ├── subversion.conf

│   ├── subversion.conf.bak

│   └── welcome.conf

├── logs -> ../../var/log/httpd

├── modules -> ../../usr/lib64/httpd/modules

└── run -> ../../var/run/httpd


5 directories, 7 files

[root@node02 ~]# 

目录配置:

(1)svn目录配置

[root@node02 ~]# mkdir -p /application/svn/svndata

[root@node02 ~]# mkdir -p /application/svn/svndata/svnpasswd/

[root@node02 ~]# 

[root@node02~]# touch /application/svn/svndata/svnpasswd/authz

[root@node02 ~]# touch /application/svn/svndata/svnpasswd/passwd


注意:这里的/application/svn/svndata是SVN的项目目录,该目录下就是我们平常的项目存放位置

目录/application/svn/svndata/svnpasswd/是用用户认证和权限文件存放路径,结构如下:

[root@node02 ~]# tree /application/svn/svndata/svnpasswd/

/application/svn/svndata/svnpasswd/

├── authz

└── passwd


0 directories, 2 files

[root@node02 ~]# 

(2)启动SVN

[root@node02 ~]# svnserve -d -r /application/svn/svndata/

[root@node02 ~]# ps -ef|grep svn

root     13512     1  0 18:48 ?        00:00:00 svnserve -d -r /application/svn/svndata/

root     14068  1977  0 22:49 pts/0    00:00:00 grep svn

[root@node02 ~]# netstat -lnput|grep svn

tcp        0      0 0.0.0.0:3690                0.0.0.0:*                   LISTEN      13512/svnserve      

[root@node02 ~]# 

(3)创建项目

[root@node02 ~]# svnadmin create /application/svn/svndata/project001

[root@node02 ~]# tree /application/svn/svndata/project001/

/application/svn/svndata/project001/

├── conf

│   ├── authz

│   ├── passwd

│   └── svnserve.conf

├── db

│   ├── current

│   ├── format

│   ├── fsfs.conf

│   ├── fs-type

│   ├── min-unpacked-rev

│   ├── rep-cache.db

│   ├── revprops

│   │   └── 0

│   │       └── 0

│   ├── revs

│   │   └── 0

│   │       └── 0

│   ├── transactions

│   ├── txn-current

│   ├── txn-current-lock

│   ├── txn-protorevs

│   ├── uuid

│   └── write-lock

├── format

├── hooks

│   ├── post-commit.tmpl

│   ├── post-lock.tmpl

│   ├── post-revprop-change.tmpl

│   ├── post-unlock.tmpl

│   ├── pre-commit.tmpl

│   ├── pre-lock.tmpl

│   ├── pre-revprop-change.tmpl

│   ├── pre-unlock.tmpl

│   └── start-commit.tmpl

├── locks

│   ├── db.lock

│   └── db-logs.lock

└── README.txt


10 directories, 28 files

[root@node02 ~]# 

(3)修改项目配置文件

[root@node02 ~]# cd /application/svn/svndata/project001

[root@node02 project001]# ls

conf  db  format  hooks  locks  README.txt

[root@node02 project001]# 

[root@node02 project001]# cd conf/

[root@node02 conf]# ll

total 12

-rw-r--r-- 1 root root 1080 Dec 31 22:53 authz

-rw-r--r-- 1 root root  309 Dec 31 22:53 passwd

-rw-r--r-- 1 root root 2279 Dec 31 22:53 svnserve.conf

[root@node02 conf]# 

[root@node02 conf]# vim svnserve.conf

anon-access = none         ------------------->12行去掉注释,并修改read为none

auth-access = write        ------------------->13行去掉注释

password-db = /application/svn/svndata/svnpasswd/passwd ------------>18行去掉注释

authz-db = /application/svn/svndata/svnpasswd/authz ---------------->25行去掉注释

[root@node02 conf]#

提示:svnserve.conf中每个参数都要顶格写,开头不能有空格

或者执行如下命令修改:

[root@node02 conf]# sed -i 's/# anon-access = read/anon-access = none/g' svnserve.conf  

[root@node02 conf]# sed -i 's/# auth-access = write/auth-access = write/g' svnserve.conf  

[root@node02 conf]# sed -i 's%# password-db = passwd%password-db = /application/svn/svndata/svnpasswd/passwd%g' svnserve.conf

[root@node02 conf]# sed -i 's%# authz-db = authz%authz-db = /application/svn/svndata/svnpasswd/authz%g' svnserve.conf  

修改完之后可以运行如下命令进行检查

[root@node02  conf]# egrep "\-access|\-db =" svnserve.conf                                                          

anon-access = none

auth-access = write

password-db = /application/svn/svndata/svnpasswd/passwd

authz-db = /application/svn/svndata/svnpasswd/authz

[root@node02  conf]#

确认配置修改无误后,拷贝用户认证文件passwd和权限管理文件authz到刚才创建的目录下:

[root@node02 conf]# cp authz  passwd  /application/svn/svndata/svnpasswd/

[root@node02 conf]# tree /application/svn/svndata/svnpasswd/

/application/svn/svndata/svnpasswd/

├── authz

└── passwd


0 directories, 2 files

[root@node02 conf]# 

(4)创建用户admin、user001并设置密码,格式:用户名 = 密码

[root@node02 svnpasswd]# cat passwd 

### This file is an example password file for svnserve.

### Its format is similar to that of svnserve.conf. As shown in the

### example below it contains one section labelled [users].

### The name and password for each user follow, one account per line.


[users]

# harry = harryssecret

# sally = sallyssecret

admin = admin

user001 = 123456

[root@node02 svnpasswd]# 

访问权限:

[root@node02 svnpasswd]# cat authz 

-----省略部分-------------


[aliases]

# joe = /C=XZ/ST=Dessert/L=Snake City/O=Snake Oil, Ltd./OU=Research Institute/CN=Joe Average


[groups]

# harry_and_sally = harry,sally

# harry_sally_and_joe = harry,sally,&joe

users = admin,user001

# [/foo/bar]

# harry = rw

# &joe = r

# * =


# [repository:/baz/fuz]

# @harry_and_sally = rw

# * = r

[/]

@users = rw

[root@node02 svnpasswd]# 

说明:users= admin,user001将admin、user001两个用户赋值用户组users,@user = rw 是让用户组对跟目录有读写权限,也就是说用户admin、user001这两个用户对根目录有读写的权限。

到这里svn服务器算搭建完成。

(5)客户端安装

下面进行客户端的安装和操作

wKioL1hnW6qDHikAAAN4PxefgC4703.png


这里介绍安装过程,windows下安装客户端直接双击,然后下一步下一步即可。

(6)SVN的常用操作,提交、更新、删除文件

安装好之后,鼠标置于桌面右键会有如下图标出现 SVN Checkout和TortoiseSVN两个标签

wKiom1hnXubywFTKAAK_nzM27Bo905.png


这里我在桌面创建一个文件夹,输入写入一个文件,然后提交SVN Checkout,

wKioL1hnYEyShsUyAAKe6s1H8AE751.png

会弹出一个登录对话框,此时点击OK

wKioL1hnYfqybGcjAAKzpiwT5mw108.png

此时会提示输入用户名和密码:

输入刚才创建的用户admin或者user001登录即可,这里用user001登录即可。如果有文件要提交,这里直接把文件放入project001里,在文件夹上右击,弹出如下对话框,然后选择文件点击"确定"即可

wKioL1hna7XDaz-6AAURujO-hfw275.png

提交后的结果为:

wKiom1hnc6CSB6KZAADXFigtn50413.png

这里,就将本地的文件提交到svn上,如果有意外操作。比如不小心把本地文件删除了,可以在从svn上再拉取一份即可。

wKioL1hndYTDXnm5AADy6UQSF7M950.png

删除2.xlsx文件,然后再从svn上拉取一次,

wKioL1hndIOgeznuAABPsz7z_UM892.png

输入用户名和密码

wKioL1hndNjx5C4uAAFHaUvKXJw968.png


确定后,就从svn上拉取了一份2.xlsx文件

wKiom1hnddrDkV0-AAE_RLoa-Oc728.png

如果要删除SVN上的某个文件,需要将本地的文件删除,然后再执行cmmit(提交)

wKiom1hndoeBj-RvAACh0VcL9sI309.png


弹出如下对话框

wKiom1hnduHSx7JNAAHEAkwRywQ283.png

确定后,即可完成SVN服务器上的2.xlsx文件的删除

wKiom1hndzGQHW7aAAFAHMTJsWc496.png


(7)导入SVN原始的目录树

[root@node02 ~]# cd /application/tools/

[root@node02 tools]# mkdir -p branch tags trunk/

[root@node02 tools]# ll

total 12

drwxr-xr-x 2 root root 4096 Dec 31 21:02 branch

drwxr-xr-x 2 root root 4096 Dec 31 21:02 tags

drwxr-xr-x 2 root root 4096 Dec 31 21:02 trunk

[root@node02 tools]# 

[root@node02 tools]# svn import /application/tools/ file:///application/svn/svndata/project001/

svn: Could not use external editor to fetch log message; consider setting the $SVN_EDITOR environment variable or using the --message (-m) or --file (-F) options

svn: None of the environment variables SVN_EDITOR, VISUAL or EDITOR are set, and no 'editor-cmd' run-time configuration option was found

[root@node02 tools]# 

报错,提示加参数 -m "xxxxx"

[root@node02 tools]# svn import /application/tools/ file:///application/svn/svndata/project001/ -m "import messages"

Adding         /application/tools/trunk

Adding         /application/tools/branch

Adding         /application/tools/tags


Committed revision 5.

[root@node02 tools]# 

导入成功,客户端检查一下

wKiom1hnelzQ_jM_AAGBmcPO8BI277.png

点击“版本库浏览器”

wKioL1hner6havJLAAL-O4EaH-s278.png至此SVN原始目录树导入成功。


(8)打tags版本

如果我们有一个项目为ucode,开发完所有的基本功能之后,的版本问1.0,如下图所示:

wKioL1hqDyvwzYYhAADdpC6BRzU082.png

以后的开发都是基于这个版本的开发,那么可以把这个版本锁定,然后定义为一个新的版本,操作如下:

wKiom1hqEFnjX-liAADoalw0gU8216.png

选择"分支/标记(T)" 弹出如下对话框,输入"ucode_dev_1.0_release_v0001",如下图:

wKioL1hqEKmCnidaAACcxaAEcC4721.png

然后"确定"即可。

wKioL1hqEe6RQaWGAAB4pluw_Ks821.png

接下来可以在tags目录下看到刚才打的版本号:

wKioL1hqErGREXcGAADMyHUUU3w371.png

(9)多项目管理,这里以project_test001和project_test002为例:

[root@node02 ~]# svnadmin create /application/svn/svndata/project_test001

[root@node02 ~]# svnadmin create /application/svn/svndata/project_test002

用户配置:

[root@node02 svnpasswd]# cat passwd 
### This file is an example password file for svnserve.
### Its format is similar to that of svnserve.conf. As shown in the
### example below it contains one section labelled [users].
### The name and password for each user follow, one account per line.

[users]
# harry = harryssecret
# sally = sallyssecret
admin = admin
user001 = 123456
user002 = 123456
user003 = 123456
[root@node02 svnpasswd]#


图片.png

注意,passwd文件中只定义用户和密码,用户分组以及权限控制放在authz文件中,做实验的时候一直把分组放passwd文件中,导致提交一直报错,花了不少时间;另外每个项目的配置文件中用户和认证文件都要指定到同一路径下的文件,便于集中管理,我这里两个项目project_test001和project_test002中配置文件中访问用户和认证文件都是:

password-db = /application/svn/svndata/svnpasswd/passwd
authz-db = /application/svn/svndata/svnpasswd/authz


图片.png


权限控制:

[root@node02 svnpasswd]# pwd
/application/svn/svndata/svnpasswd
[root@node02 svnpasswd]# cat authz |egrep -v '^#|^$' authz 
[aliases]
[groups]
dev_users = admin,user001
pro_users = user002,user003
[project_test001:/]
@dev_users = rw
@pro_users = r
[project_test002:/]
@pro_users = rw
[root@node02 svnpasswd]#

图片.png

说明:dev_users对project_test001项目有读写权限,pro_users用户组对project_test002项目有读写权限,对project_test001项目有读权限,没有写权限(即不能讲本地更新代码提交到project_test001版本库中)

user001登陆project_test001,并提交内容

图片.png

点击“OK”提示输入用户名和密码,这里输入user001和123456

         图片.png

登陆成功出现如下界面:

图片.png

浏览project_test001项目目录内容:

  图片.png


写入文件新文件“2017年金秋联谊运动会.pdf”,然后commit提交

图片.png


图片.png

选中提交内容然后点击OK:

图片.png

提示提交成功:

图片.png


说明user001对项目project_test001有读写权限,下面测试user002对项目project_test001的读写权限

切换登陆用户为user002,(切换用户TortoiseSVN--->Settings-->Save Data--->Authentication data--->Clear all)

图片.png

点击OK,提示登陆成功


图片.png

点击ok,进入project_test001浏览文件

图片.png

写入内容“系统垃圾清理.bat",

图片.png

返回project_test001,然后提交:

图片.png


弹出如下界面:

图片.png


说明提交失败,即说明user002对project_test001项目只有读取权限,无修改权限。


(10)配置Apache,让svn支持http协议访问

[root@node02 conf.d]# pwd

/etc/httpd/conf.d

[root@node02 conf.d]# ll

total 20

-rw-r--r-- 1 root root   46 Dec 31 18:25 passwd

-rw-r--r-- 1 root root  392 Nov 19 07:49 README

-rw-r--r-- 1 root root 1049 Dec 31 18:35 subversion.conf

-rw-r--r-- 1 root root 1042 Dec 31 18:23 subversion.conf.bak

-rw-r--r-- 1 root root  299 Nov  3 22:33 welcome.conf

[root@node02 conf.d]# 

[root@node02 conf.d]# cat subversion.conf


LoadModule dav_svn_module     modules/mod_dav_svn.so

LoadModule authz_svn_module   modules/mod_authz_svn.so


#

# Example configuration to enable HTTP access for a directory

# containing Subversion repositories, "/var/www/svn".  Each repository

# must be both:

#

#   a) readable and writable by the 'apache' user, and

#

#   b) labelled with the 'httpd_sys_content_t' context if using

#   SELinux

#


#

# To create a new repository "http://localhost/repos/stuff" using

# this configuration, run as root:

#

#   # cd /var/www/svn

#   # svnadmin create stuff   

#   # chown -R apache.apache stuff

#   # chcon -R -t httpd_sys_content_t stuff

#


<Location /repos>

   DAV svn

   SVNParentPath /application/svn/svndata

    AuthType Basic

    AuthName "Authorization Realm"

    AuthUserFile /etc/httpd/conf.d/passwd

    Require valid-user

</Location>

[root@node02 conf.d]# 

生成认证用户和密码

[root@node02 conf.d]# htpasswd -c  /etc/httpd/conf.d/passwd user001

New password: 

Re-type new password: 

Updating password for user user001

[root@node02 conf.d]# 

wKiom1hsu5Wwinm3AANMfzILz0k562.png

另外在配置多个项目时,务必要统一配置文件,比如这里的项目是project001,则project001的配置文件必须跟其他项目文件保持同一份文件否则认证失败:

[root@node02 conf]# pwd

/application/svn/svndata/project001/conf

[root@node02 conf]# egrep -v "^#" svnserve.conf



[general]

anon-access = read

auth-access = write

password-db = /application/svn/svndata/svnpasswd/passwd

authz-db = /application/svn/svndata/svnpasswd/authz


[sasl]

[root@node02 conf]# 

http访问svn时所用的认证配置文件为:

[root@node02 conf]# pwd

/application/svn/svndata/project001/conf

[root@node02 conf]# cd /etc/httpd/conf.d/

[root@node02 conf.d]# pwd

/etc/httpd/conf.d

[root@node02 conf.d]# ll

total 20

-rw-r--r-- 1 root root   22 Jan  5 01:01 passwd

-rw-r--r-- 1 root root  392 Nov 19 07:49 README

-rw-r--r-- 1 root root 1049 Dec 31 18:35 subversion.conf

-rw-r--r-- 1 root root 1042 Dec 31 18:23 subversion.conf.bak

-rw-r--r-- 1 root root  299 Nov  3 22:33 welcome.conf

[root@node02 conf.d]# cat passwd 

user001:vQWeaqcB4YzpU

[root@node02 conf.d]# ll passwd 

-rw-r--r-- 1 root root 22 Jan  5 01:01 passwd

[root@node02 conf.d]# 

此时passwd文件中的用户名和密码要与svn的passwd中的用户名和密码保持相同

[root@node02 svnpasswd]# cat passwd 

### This file is an example password file for svnserve.

### Its format is similar to that of svnserve.conf. As shown in the

### example below it contains one section labelled [users].

### The name and password for each user follow, one account per line.


[users]

# harry = harryssecret

# sally = sallyssecret

admin = admin

user001 = 123456

[root@node02 svnpasswd]# 

即:passwd中的user001 密码123456要与/etc/httpd/conf.d/passwd中的是完全相同,然后重启Apache,访问即可,如果出现访问权限问题,可以在Apache的主配置文件中httpd.conf中的最后面添加如下内容:

<Directory "/application/svn/svndata">

    Options Indexes FollowSymLinks

    AllowOverride None

    Order allow,deny

    Allow from all

</Directory>







      本文转自027ryan  51CTO博客,原文链接:http://blog.51cto.com/ucode/1888322,如需转载请自行联系原作者





相关文章
|
1月前
|
存储 网络协议 Ubuntu
Linux环境下的SVN服务器搭建并结合内网穿透实现远程连接
Linux环境下的SVN服务器搭建并结合内网穿透实现远程连接
|
1月前
|
弹性计算 Ubuntu Linux
新手怎么搭建《幻兽帕鲁Palworld》服务器流程步骤
对于《幻兽帕鲁》的忠实粉丝来说,与好友一同在这个开放世界中冒险无疑是最大的乐趣。而搭建一个专属服务器,则能为你们提供更加稳定和自由的游戏体验。那么,如何轻松搭建《幻兽帕鲁》服务器呢?接下来,就让我们一起探索吧!
|
2月前
|
弹性计算
2024年幻兽帕鲁/Palworld专用服务器搭建一步步讲解,联机服务器搭建详细步骤
近期,《幻兽帕鲁》这款游戏在游戏圈中引起了不小的轰动,尤其是其联机对战模式,为玩家们带来了前所未有的游戏体验。但是,想要与众多好友一同畅玩,却时常受到服务器卡顿、延迟高等问题的困扰。那么,如何解决这一问题呢?
|
1月前
|
弹性计算 Ubuntu 搜索推荐
幻兽帕鲁Palworld搭建联机服务器教程,新手搭建流程步骤
随着《幻兽帕鲁》这款开放世界生存游戏的持续火热,越来越多的玩家希望搭建属于自己的游戏服务器,与好友一同探险。那么,怎样才能轻松搭建《幻兽帕鲁》服务器呢?接下来,就跟随我们的脚步,简单几步助你实现梦想!
224 0
|
1月前
|
网络协议 Ubuntu Linux
如何在Linux环境搭建本地SVN服务器并结合cpolar实现公网访问
如何在Linux环境搭建本地SVN服务器并结合cpolar实现公网访问
|
1月前
|
人工智能 弹性计算 监控
在阿里云服务器上搭建自己的人工智能,可以按照以下步骤进行:
【2月更文挑战第22天】在阿里云服务器上搭建自己的人工智能,可以按照以下步骤进行:
43 6
|
1月前
|
弹性计算 Ubuntu Linux
2024年Palworld/幻兽帕鲁联机服务器搭建方法分享,详细步骤
想要和好友一起畅游幻兽帕鲁的世界吗?别再为联机而烦恼,因为搭建自己的服务器其实并不难!今天,就为大家带来一篇超详细的幻兽帕鲁服务器搭建教程,保证让你轻松上手!
20 0
|
1月前
|
弹性计算
玩转幻兽帕鲁部署:2024年幻兽帕鲁Palworld服务器怎么搭建开服,详细步骤教程
您是不是已经厌倦了《幻兽帕鲁》中漫长的加载时间和不稳定的公共服务器?好消息是,现在您可以拥有自己的专属服务器了!而且,搭建过程非常简单,仅需轻点三次鼠标,3秒就能轻松开服。接下来,就让我们一起看看如何轻松搭建《幻兽帕鲁》的专属服务器吧!
|
1月前
|
弹性计算 安全 定位技术
2024年幻兽帕鲁Palworld游戏服务器怎么搭建流程,步骤详解
近期,随着《幻兽帕鲁》的风靡,越来越多的玩家渴望能拥有自己的专属游戏服务器,与好友在这个充满奇幻色彩的世界中畅游。好消息是,阿里云为了满足广大玩家的需求,特别推出了全程自动化的《幻兽帕鲁》服务器搭建服务。这一服务究竟有多简单?即便是从未接触过服务器设置的小白玩家,也能在几分钟内轻松搞定!
|
1月前
|
弹性计算 安全 数据安全/隐私保护
阿里云上搭建Palworld幻兽帕鲁专用服务器详细步骤
对于《幻兽帕鲁》的忠实粉丝来说,与好友一起联机冒险无疑是游戏中的一大乐趣。但如何快速、简便地搭建一个稳定的联机服务器,却常常成为玩家们的难题。今天,我将为大家带来一篇实用指南,教你如何利用阿里云轻松搭建《幻兽帕鲁》专用服务器,让你和好友在短短3秒内就能开启联机之旅!