linux安装Subversion版本控制工具(Subversion + Apache + jsvnadmin)

转载:https://www.cnblogs.com/wangfajun/p/5282331.html

linux安装Subversion版本控制工具(Subversion + Apache + jsvnadmin)

操作系统:Centos 6.7

集成环境服务器:10.0.210.112

操作用户:root

建议安装前更新操作系统

# yum update

更新完成后重启

# reboot

1: 安装 Apache

# yum install httpd httpd-devel

# service httpd start

# chkconfig httpd on 

2: 修改httpd.conf 配置文件:

# vi /etc/httpd/conf/httpd.conf

找到 ServiceName 并修改成:

ServiceName localhost:80

3: 防火墙中配置80端口:

# vi /etc/sysconfig/iptables

增加: -A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

4: 重启防火墙:

# service iptables restart

5: 访问 Apache : http://10.0.210.112 :

6: 安装 SVN 服务:

# yum install mod_dav_svn subversion (必须安装mod_dav_svn模块)

# cd /etc/httpd/conf.d

# ls

此时你可以看到一个subversion.conf配置文件,svn安装完成后重启 Apache

# service httpd restart

7:查看模块是否安装成功:

# ls /etc/httpd/modules/ | grep svn

mod_authz_svn.so
mod_dav_svn.so

8: 创建Svn库主目录(多库模式,一份配置文件管理多个库)

# mkdir /svn/

9:修改subversion.conf 配置文件:

# vi /etc/httpd/conf.d/subversion.conf 增加以下内容:

<Location /svn/>
   DAV svn
   SVNListParentPath on
   SVNParentPath /svn
   AuthType Basic
   AuthName "Subversion repositories"
   AuthUserFile /svn/passwd.http
   AuthzSVNAccessFile /svn/authz
   Require valid-user
</Location>
RedirectMatch ^(/svn)$ $1/

10:创建 /svn/passwd.http 和 /svn/authz

# touch /svn/passwd.http

# touch /svn/authz

11: 重启 Apache

# service httpd restart

12: 下载 jsvnadmin (需要FQ),第21步需要用到 :

https://code.google.com/p/jsvnadmin/

https://jsvnadmin.googlecode.com/files/svnadmin-3.0.5.zip

13: 安装 Mysql (单独安装,与业务系统的数据库分开)

# rpm -qa | grep mysql  (查看该操作系统上是否已经安装了mysql数据库)

有的话,可以通过 rpm -e 命令或者 rpm -e  --nodeps 命令来卸掉

# yum install mysql-server mysql mysql-devel

# service mysqld start

14: 用chkconfig --list | grep mysqld 查看Mysql是否开机启动

# chkconfig --list | grep mysqld

# mysqld         0:off    1:off    2:off    3:off    4:off    5:off    6:off

# chkconfig mysqld on

方便远程管理,防火墙打开3306端口

# vi  /etc/sysconfig/iptables 增加以下内容:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
# service iptables restart

15: 设置 Mysql数据库root用户的密码:

# mysqladmin -u root password 'wangfajun'

16:登录数据库:

mysql -u root -p

17: Mysql授权远程访问(先用root登录Mysql)

mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'wangfajun' WITH GRANT OPTION;

mysql>FLUSH PRIVILEGES;

18: 使用Tomcat7部署svnadmin(我的Tomcat放置在/root下):

# cd /root

# tar -zxvf apache-tomcat-7.0.61.tar.gz  (解压)

# mv apache-tomcat-7.0.61 svnadmin-tomcat (重命名)
19: 修改Tomcat 的端口为9000,容器编码为UTF-8:

# vi /root/svnadmin-tomcat/conf/server.xml 修改以下内容:

<Server port="9005" shutdown="SHUTDOWN">

<Connector port="9000" protocol="HTTP/1.1"
       connectionTimeout="20000"
       redirectPort="8443"

   URIEncoding="UTF-8"/>

20:防火墙配置9000端口:

# vi /etc/sysconfig/iptables

增加以下内容:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 9000-j ACCEPT

#service iptables restart

21: 上传svnadmin.war 到 /root/svnadmin-tomcat/webapps 目录:

# cd /root/svnadmin-tomcat/webapps

解压

# unzip svnadmin.war -d svnadmin

# cd svnadmin/WEB-INF

# vi jdbc.properties

db=MySQL

#MySQL
MySQL.jdbc.driver=com.mysql.jdbc.Driver
MySQL.jdbc.url=jdbc:mysql://127.0.0.1:3306/svnadmin?characterEncoding=utf-8  注:127.0.0.1也可以是你的主机地址:10.0.210.112
MySQL.jdbc.username=root
MySQL.jdbc.password=wangfajun
22:创建数据库svnadmin并导入响应数据(utf-8编码)

执行:db/mysql5.sql和db/lang/en.sql

23:启动svnadmin-tomcat:

# /root/svnadmin-tomcat/bin/startup.sh

浏览器中打开: http://10.0.210.112:9000/svnadmin

输入:admin wangfajun

24: 配置库目录权限:

# cd /svn

# chown -R apache.apache  meeting_study

# chmod -R 777 meeting_study

如果创建了新的库,都要执行上面两步授权 )

原因:当前http访问的发起者是Apache(/etc/httpd/conf/httpd.conf 中配置了),而访问的目录(/svn/meeting_study)拥有者为root)

25: 关闭SELinux(Linux的访问控制):

点击URL链接进去,会显示认证失败,原因是当前登录用户admin没有所属的一个用户组,并且linux自带的selinux访问控制跟svn目录访问有冲突

将SELINUX=enforcing 改为 SELINUX=disabled

重启生效:

# reboot

猜你喜欢

转载自blog.csdn.net/hqbootstrap1/article/details/84262613
今日推荐