搭建svn独立服务器以及自动部署

来源:互联网 发布:仿小刀娱乐网源码 编辑:程序博客网 时间:2024/05/16 16:04
常识:

svn存储版本数据也有2种方式:BDB和FSFS。因为BDB方式在服务器中断时,有可能锁住数据,所以还是FSFS方式更安全一点。 


一,下载工具

wget http://subversion.tigris.org/downloads/subversion-1.6.17.tar.gz

wget  http://subversion.tigris.org/downloads/subversion-deps-1.6.17.tar.gz

注意:

版本要一样,都是必须下载的,否则单独下载第一个包编译时就会提示缺少模块。


二,解压缩

tar xfvz subversion-.6.17.tar.gz
tar xfvz subversion-deps-.6.17.tar.gz

注意:

这两个包下载解压后会解压到同一个目录下,不需要特别指定。


三,编译

cd subversion-.6.17

//prefix指定安装的目录,without-berkeley-db表明不使用berkeley数据库

编译 ./configure --prefix=/opt/svn -without-berkeley-db -with-zlib

这里只是搭建svn独立服务器,没有依赖apache的,所以不需要编译关于apache的相关参数

总结编译后会出现的问题:

1,编译后,报错:configure: error: invalid variable name: `prefix'

解决prefix 前面的小横线“-”打错了,应该是 "--" .

2,报错:configure: error: no XML parser was found: expat or libxml 2.x required

其一:错误提示需要安装expat

 Yum install expat
其二:  configure: error: no XML parser was found: expat or libxml 2.x required

  configure failed for neon

  解决办法:

 #yum install libxml2 libxml2-devel  RedHat 和 Fedora 安装 
<span style="color: rgb(51, 51, 51);font-size:12px;"> # aptitude install libxml2-dev         </span><span style="color: rgb(51, 51, 51);font-size:12px;">ubuntu</span>

3,其次编译,报错:

configure: error: We require OpenSSL; try --with-openssl
configure failed for serf

解决:

此时先检查本机有没有装 openssl 和 openssl-devel 
最简单的方法就是找一下有没有opensslv.h这个文件

find / -name opensslv.h

如果能找到,就在configure命令之后添加 --with-openssl= ...(此处是opensslv.h所在的目录) 

如果找不到,就执行

yum install opensslyum install openssl-devel

进行安装,安装之后找到opensslv.h所在的目录加到configure命令之后

例如:
./configure -–prefix=/usr/local/svn -–without-berkeley-db --with-openssl=/usr/include/openssl

4,编译报错:configure: error: --with-zlib requires an argument.

解答:安装zlib,其实下载的subversion-deps-.6.17.tar.gz包里会有

在svn的安装目录下有个zlib目录,说明是已经安装的了。

编译的时候不报这个错误,下面的步骤是不需要操作的:

# cd ../software/subversion-1.6.6/zlib/  # ./configure –shared  # make 
完成zlib的make,再次完成编译的时候,需要指定刚才安装的zlib路径

例如:

./configure --prefix=/opt/svn -without-berkeley-db -with-zlib=/tmp/subversion-1.6.17/zlib/

当然在安装svn前,也可以先安装zlib,如下所示:

tar -zxvf zlib-1.2.3.tar.gzcd zlib-1.2.3./configure && make && make install

编译成功提示:


如果最后出现下面WARNING,我们直接忽略即可。因为不使用BDB存储。(这个warning是编译的时候没有编译berkeley-db这个导致的,恩恩


四,安装

make cleanmake && make install  
会安装在 编译--prefix指定的目录

安装完提示:

test -d /opt/svn/include/subversion-1 || \          /usr/bin/install -c -d /opt/svn/include/subversion-1(subversion/svnversion/svnversion . ||  \         svnversion . ||                        \         echo "unknown";                                    \        ) > /opt/svn/include/subversion-1/svn-revision.txt

安装会需要很多基本包,有的时候非常有必要判断这些基本包是否已经安装,可以用此命令

Rpm -qa | grep xxx

可以查看expat,libxml,neon,openssl,zlib


五,检测svn是否安装成功

在svn安装目录的bin目录下,运行命令:

#svnserve --version

如果出现svn的版本号,说明已经安装成功。


六,添加svn环境变量

#export PATH=$PATH:/opt/svn/bin

#echo $PATH

这样在任何位置运行,svnserve --version 都可以成功


七,创建svn版本库

mkdir -p /opt/svndata/repos1

加上参数P,是如果没有父目录则自动创建

  注意: /opt/svndata在这里将是所有仓库的根目录,repos1是其中的一个仓库

建立svn版本库

svnadmin create /opt/svndata/repos1

运行完,repos1目录下就会出现很多文件。


八,配置svn版本库

1修改svn版本库配置文件版本库1:

vi /opt/svndata/repos1/conf/svnserve.conf

内容修改为:

[general]anon-access = noneauth-access = writepassword-db = passwdauthz-db = authzrealm = repos1

2,修改用户密码文件

文件格式如下:

文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。

示例:
[users]
svntest = svntest
配置svn用户访问权限vi /opt/svn/conf/authz

为了简化配置,所有版本库可共用1个权限配置文件/opt/svn/conf/passwd。如有必要,也可以分开。文件中定义用户组和版本库目录权限。

注意:对用户配置文件的修改立即生效,不必重启svn。


3,修改权限控制文件

用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[repos1:/abc/aaa]
king = rw
[repos2:/pass]
king =

注意:

* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。


九,启动svn

建立启动svn的用户

useradd svn
passwd svn
根据提示为用户svn设置密码


允许用户svn访问版本库chown -R svn:svn /opt/svndata
chown -R svn:svn /opt/data
启动命令:

[root@FirstPro repos1]# su - svn -c "svnserve -d --listen-port 9999 -r /opt/svndata"

没有指定监听端口,默认是3690

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

-r /opt/svndata指定根目录是/opt/svndata

到此,svn服务器配置完成!


十,运行svn

服务器端初次检出到网站:[svn@FirstPro web]$ svn co svn://192.168.61.128/repos1/ ./web1

可以输入用户名和密码,选择yes,记住密码

本地检出:


说明防火墙没有配置让svn的端口通行,配置一下防火墙,重启ok

 

十一,配置钩子文件-自动部署

把svn版本库中的代码,自动同步到服务器上网站目录下。需要配置post-commit钩子

cp post-commit.tmpl post-commit 
chmod 755 post-commit

post-commit 中内容:

EPOS="$1"  //svn版本库跟目录REV="$2"    //svn更新的版本号#mailer.py commit "$REPOS" "$REV" /path/to/mailer.confDIR="/var/www/html/web1"//以下信息是保证编码一致export LC_ALL=en_US.UTF-8export LANG=zh_CN.UTF-8CURDATE=`date`echo "Code Deployed By at $CURDATE,$REPOS,$REV" >> /var/www/log/svn_look.log .log/opt/svn/bin/svn co svn://192.168.61.128/repos1 $DIR --username svntest --password svntest >> /var/www/log/svn_look.log 2>&1

或者改为:

/opt/svn/bin/svn up  $DIR --username svntest --password svntest >> /var/www/log/svn_look.log 2>&1

注意:

Svn在服务器上首次需要检出

Svn co svn://192.168.61.128/repos1 网站跟目录


//标准输出和错误输出都输出到日志文件

Svn_look.log 中记录内容:

U    /var/www/html/web1/1.txt  //版本库检出的文件

Checked out revision 17.   


这样svn独立服务器搭建完成。













0 0