操作系统:Centos 6.7
建议安装前更新操作系统
# 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