您的位置:首页 > 运维架构 > Nginx

linux系统上安装svn服务器 环境linux+nginx+svnserver

2014-06-16 14:22 861 查看
系统:Ubuntu 12.04 64位 lnmp环境

集成软件:PHP5.4.27、Nginx1.6.0、MySQL5.5.37

阿里云服务器

svn服务器有2种运行方式:独立服务器和借助apache运行。两种方式各有利弊。我这里是独立的服务器,svnserver。第一次接触感觉很麻烦,网上搜了很多,最后摸索出了一个适合阿里云服务器的环境配置方案。当然也适合普通服务器,linux系统。

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------

首先当然就是下载安装svnserver了

两种方法

[plain] view
plaincopy





# yum install subversion

# apt-get install subversion



[b]然后就是创建svn仓库[/b]

我是创建在 /var/svndata目录下www目录的,这里目录可以自己定。当然这个目录得提前创建好

[plain] view
plaincopy





# cd /var

# mkdir svndata

# cd svndata

# mkdir www



然后就是创建仓库了

[plain] view
plaincopy





# svnadmin create /var/svndata/www

修改配置文件

进入/var/svndata/www目录(这里的www目录不是网站的web目录,仓库名为www)



[plain] view
plaincopy





# cd /var/svndata/www

# ls

会看到conf、hooks、db等目录,我们会用到的也就conf(配置目录)hooks(设置钩子,后面会讲到)

进入conf目录

[plain] view
plaincopy





# cd www

首先配置svnserve.conf

[plain] view
plaincopy





# vim svnserve.conf

修改(把前面的#号去掉,配置后面的值,共修改五行代码)

[plain] view
plaincopy





anon-access = none

auth-access = write

password-db = passwd

authz-db = authz

realm = www

在passwd文件中添加用户

[plain] view
plaincopy





# vim passwd

[plain] view
plaincopy





[users]

admin = 123456

dazeair = 123456

user1 = 123456

user2 = 123456

这里设置了四个用户,分别为admin,dazeair,user1和user2。根据情况不同可以随意设置。

在authz中添加组和权限

[plain] view
plaincopy





# vim authz

[plain] view
plaincopy





[groups]

group1 = admin,dazeair #group1组里的成员

group2 = user1,user2

[/] #配置根目录的权限

admin =rw #admin用户对[/]目录的权限:r读,w写

@group1 = rw #@表示组,group1组有读写权限

@group2 = r #group2组只有r读权限

* = #这里表示其他用户无任何权限

[www:/user1] #配置根目录(www目录)下的user1文件夹的权限user1 = rw

[www:/user2] #配置user2文件夹的权限

user2 = rw

这里说明下,前面添加了四个用户,分了两个组,对于根目录group1拥有读写权限,而group2只有r权限。根目录(www目录)下有user1和user2两个文件夹,分别配置了user1和user2两个用户相应的权限。如不需要,可以不添加相应的代码。

启动svnserve

[plain] view
plaincopy





# svnserve -d -r /var/svndata/

也可以使用 --listen-port 参数指定端口(默认端口3690),启动多个仓库

正常情况下不会出现问题的,如出现请检查刚才的配置文件

导入项目

项目目录为svn://localhost/www

创建svn仓库副本(nginx的读取目录,也就是web目录,我的web目录/var/www)

进入web目录

[plain] view
plaincopy





# cd /var

同步

[plain] view
plaincopy





svn co svn://localhost/www

显示如下



保存用户名与密码,实现之后的自动同步。

这里可能会出现 错误:svn:E170001;认证失败

还有可能出现找不到openssl错误,利用yum安装openssl和openssl-dev即可。



看到这个恭喜,已经搭建成功了。

设置svn更新后自动更新web目录



[plain] view
plaincopy





# cd /var/svndata/www/hooks/

里面会有很多.tmpl文件,这里我们只需要post-commit.tmpl文件,但这个文件只是模板文件,我们需要复制一份放在此目录下,命名为post-commit。

[plain] view
plaincopy





# cp post-commit.tmpl post-commit

# vim post-commit

在文件的底部修改和添加

[plain] view
plaincopy





# "$REPOS"/hooks/mailer.py commit "$REPOS" $REV "$REPOS"/mailer.conf # 注释掉这段代码

export LANG=zh_CN.UTF-8

export LANG=en_US.UTF-8

svn update --no-auth-cache --non-interactive /var/www #主要是这段代码,最后的地址是web地址

说明:

#!/bin/sh 说明是执行shell命令,不需要修改

export LANG=zh_CN.GBK 是为了解决svn post commit 中文乱码,设置本地化编码,因为我的系统为GBK编码,SVN默认是UTF-8编码,如果不设置将会出现错误,而执行不成功,错误标识为svn: Can't convert string from native encoding to 'UTF-8'

到这里自动更新也解决了,下一步就是开机自动启动。

实现开机自动启动

将svnserve -d -r /var/svndata/ 写入/etc/rc.local即可实现开机启动(一般在etc文件下,或者/etc/rc.d/文件夹下)

[plain] view
plaincopy





# vim /etc/rc.local

[plain] view
plaincopy





svnserve -d -r /var/svndata/

exit 0

ps:刚才配置的时候还有个user1之类的用户,user1只能管理user1目录,地址为svn://IP地址/www/user1

并且请保证文件有读写权限,chmod
-R 777 /var/www

到这里所有大功告成,现在可以用客户端测试下了,一般都用TortoiseSVN,地址为svn://IP地址/www。

你的svn服务器搭建好了吗?是不是很简单。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  svn linux