您的位置:首页 > 其它

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

2015-07-30 14:01 344 查看
常识:
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 openssl
yum 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.gz
cd zlib-1.2.3
./configure && make && make install】

编译成功提示:



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

四,安装
make clean
make && 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

内容修改为:
[gen
b971
eral]
anon-access = none
auth-access = write
password-db = passwd
authz-db = authz
realm = 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.conf

DIR="/var/www/html/web1"
//以下信息是保证编码一致
export LC_ALL=en_US.UTF-8
export LANG=zh_CN.UTF-8
CURDATE=`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 --passw
ord 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独立服务器搭建完成。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: