Centos下安装并配置SVN服务器并使用export命令实现自动发布
时间:2014-12-15 02:05 来源:linux.it.net.cn 作者:IT
1:安装,安装其实非常简单
#yum install subversion
测试是否安装成功
#svnserve --version
如果显示了版本信息则表示安装成功
2:配置
svn配置建立svn版本库目录可建多个:
新建一个版本库目录 名字为repos
#mkdir -p /opt/svndata/repos
建立svn版本库:
#svnadmin create /opt/svndata/repos
修改svn版本库配置文件版本库:
# vim /opt/svndata/repos/conf/svnserve.conf
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = /opt/svn/conf/passwd.conf
authz-db = /opt/svn/conf/authz.conf
realm = repos
注重:对用户配置文件的修改立即生效,不必重启svn。
#vim /opt/svn/conf/passwd.conf
[users]
username = password
这里是配置用户名与密码
配置svn用户访问权限:
# vim /opt/svn/conf/authz.conf
注重:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
= ,
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[:/项目/目录]
@ =
=
其中,方框号内部分可以有多种写法:
[/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/opt/svndata,[/]就是表示对全部版本库设置权限。
[repos:/] 表示对版本库repos设置权限
[repos2:/abc] 表示对版本库repos2中的abc项目设置权限
[repos2:/abc/aaa] 表示对版本库repos2中的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
启动svn
# su - svn -c "svnserve -d --listen-port 9999 -r /opt/svndata"
其中:
su - svn表示以用户svn的身份启动svn
-d表示以daemon方式(后台运行)运行
–listen-port 9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /opt/svndata指定根目录是/opt/svndata
好SVN已经启动了,你可以通过svn://ip地址:端口/repos 这种方式来访问了
让他去后台运行,这样就OK拉
另外一个要说的是,有时候发现你的SVN连不上,也许是因为端口被防火墙墙掉的缘故
# telnet {your-server-ip} 9999 检查端口是不是通的
SVN默认端口为3690,而我们上面已经将其改为9999,你可以去iptable里面将他开放
# vi /etc/sysconfig/iptables
添加:
-A OUTPUT -p tcp -m tcp --dport 9999 -j ACCEPT
为了可以在修改完代码提交到SVN服务器后,WEB服务器直接同步.需要配置SVN的钩子,打开hooks目录,
可以看到有一个post-commit.tmpl文件,这是一个模板文件,
复制一份放在此目录下,命名为post-commit,并将其用户组设为apache,这样就有了访问apache目录的权限。
里面原有的代码全部注释掉.这里可以执行shell命令,每次commit完成后都会调用此文件.
我的文件内容为
#!/bin/sh
export LANG=zh_CN.UTF-8
svn export --username 你版本库的用户名 --password 用户名的密码 svn://你的IP地址:端口/dev/trunk/source/main/kBase /home/phpcms/public_html/kBase --force
另外还需要修改apache目录下.subversion文件夹下的servers文件将其中一项改为store-plaintext-passwords = no,主要的原因是:执行脚本的时候会提示是否保存密码,root用户在交互状态下可以回答yes或no,而apache用户没有这个机会,所以要在apache目录下的.subversion/servers中预先配置好
说明:
#!/bin/sh 说明是执行shell命令
export LANG=zh_CN.UTF-8 是为了解决svn post commit 中文乱码。
如果你是GBK编码可能会提示:Error output could not be translated from the native locale to UTF-8
这是客户端和服务器编码的问题,默认是utf-8,可尝试设置export LANG=zh_CN.GBK或者export LANG=en_US.UTF-8
svn export --username 你版本库的用户名 --password 用户名的密码 svn://你的IP地址:端口/dev/trunk/source/main/kBase /home/phpcms/public_html/kBase --force 执行更新操作
--force 是覆盖文件
另外还需要将写入的目录/home/phpcms/public_html/kBase添加svn的权限,不然会提示权限不够。
如果提示:post-commit hook failed (exit code 255) with no output赋予post-commit文件可执行权限
如果您的默认编码就是UTF-8的,要上传中文文件,先将文件另存为UTF-8格式在提交
(责任编辑:IT)
1:安装,安装其实非常简单
测试是否安装成功 如果显示了版本信息则表示安装成功 2:配置 svn配置建立svn版本库目录可建多个: 新建一个版本库目录 名字为repos #mkdir -p /opt/svndata/repos 建立svn版本库: #svnadmin create /opt/svndata/repos 修改svn版本库配置文件版本库: # vim /opt/svndata/repos/conf/svnserve.conf 内容修改为:
注重:对用户配置文件的修改立即生效,不必重启svn。
这里是配置用户名与密码 配置svn用户访问权限: # vim /opt/svn/conf/authz.conf 注重: * 权限配置文件中出现的用户名必须已在用户配置文件中定义。 * 对权限配置文件的修改立即生效,不必重启svn。 用户组格式: [groups] = , 其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。 版本库目录格式: [:/项目/目录] @ = = 其中,方框号内部分可以有多种写法: [/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/opt/svndata,[/]就是表示对全部版本库设置权限。 [repos:/] 表示对版本库repos设置权限 [repos2:/abc] 表示对版本库repos2中的abc项目设置权限 [repos2:/abc/aaa] 表示对版本库repos2中的abc项目的aaa目录设置权限 权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。 权限可以是w、r、wr和空,空表示没有任何权限。 示例:
启动svn建立启动svn的用户
好SVN已经启动了,你可以通过svn://ip地址:端口/repos 这种方式来访问了
另外一个要说的是,有时候发现你的SVN连不上,也许是因为端口被防火墙墙掉的缘故 可以看到有一个post-commit.tmpl文件,这是一个模板文件, 复制一份放在此目录下,命名为post-commit,并将其用户组设为apache,这样就有了访问apache目录的权限。 里面原有的代码全部注释掉.这里可以执行shell命令,每次commit完成后都会调用此文件. 我的文件内容为
#!/bin/sh 另外还需要修改apache目录下.subversion文件夹下的servers文件将其中一项改为store-plaintext-passwords = no,主要的原因是:执行脚本的时候会提示是否保存密码,root用户在交互状态下可以回答yes或no,而apache用户没有这个机会,所以要在apache目录下的.subversion/servers中预先配置好 说明: #!/bin/sh 说明是执行shell命令 export LANG=zh_CN.UTF-8 是为了解决svn post commit 中文乱码。
如果你是GBK编码可能会提示:Error output could not be translated from the native locale to UTF-8 svn export --username 你版本库的用户名 --password 用户名的密码 svn://你的IP地址:端口/dev/trunk/source/main/kBase /home/phpcms/public_html/kBase --force 执行更新操作 --force 是覆盖文件 另外还需要将写入的目录/home/phpcms/public_html/kBase添加svn的权限,不然会提示权限不够。 如果提示:post-commit hook failed (exit code 255) with no output赋予post-commit文件可执行权限 如果您的默认编码就是UTF-8的,要上传中文文件,先将文件另存为UTF-8格式在提交 (责任编辑:IT) |