在Linux(CentOS 6.6)服务器上安装并配置基于Apache的SVN服务器

在Linux(CentOS 6.6)服务器上安装并配置基于Apache的SVN服务器

  1 #!/bin/bash
  2 #
  3 #    在Linux(CentOS 6.6)服务器上安装并配置基于Apache的SVN服务器:
  4 #
  5 #    1、安装服务
  6 #    2、创建svn版本库
  7 #    3、创建svn用户
  8 #    4、配置svn权限
  9 #    5、配置http访问
 10 #
 11 
 12 #
 13 #    1、安装服务
 14 #
 15 
 16 #    1.1、安装程序包:subversion httpd mod_dav_svn
 17 
 18 yum install subversion httpd mod_dav_svn -y >> $0.log
 19 if [[ $? != 0 ]]
 20 then
 21     echo "安装服务失败,停止svn部署"
 22     exit 1
 23 fi
 24 
 25 #
 26 #    2、创建svn版本库
 27 #
 28 
 29 #    2.1、定义svn版本库存放目录
 30 svn_path=/svn
 31 #    2.2、创建svn版本库存放目录
 32 mkdir -p $svn_path
 33 #    2.3、定义要创建版本库的名称
 34 repo_name=mysvn5
 35 #    2.4、创建新的版本库
 36 if [[ -d $svn_path/$repo_name ]]
 37 then
 38     echo "版本库 $repo_name 已经存在"
 39     exit 1
 40 fi
 41 svnadmin create $svn_path/$repo_name
 42 #    2.5、配置svn版本库的属主属组为http服务的启动用户
 43 chown apache.apache -R $svn_path
 44 #    2.6、确认新创建的svn版本库已经生成,且文件属主属组正确
 45 ls -l $svn_path/$repo_name >> $0.log
 46 
 47 #
 48 #    3、创建svn用户
 49 #
 50 
 51 #    3.1、创建svn管理员账号
 52 admin_passwd=$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c9)
 53 htpasswd -c -b -m $svn_path/$repo_name/conf/passwd admin $admin_passwd
 54 echo "$repo_name 版本库的管理员账号为 admin ,密码是 $admin_passwd " |tee -a $0.log
 55 
 56 #    3.2、创建svn具有读写权限的账号
 57 rw_user_passwd=$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c9)
 58 htpasswd -b -m $svn_path/$repo_name/conf/passwd rw_user $rw_user_passwd
 59 echo "$repo_name 版本库的读写账号为 rw_user ,密码是 $rw_user_passwd " |tee -a $0.log
 60 
 61 #    3.3、创建svn具有只读权限的账号
 62 ro_user_passwd=$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c9)
 63 htpasswd -b -m $svn_path/$repo_name/conf/passwd ro_user $ro_user_passwd
 64 echo "$repo_name 版本库的只读账号为 ro_user ,密码是 $ro_user_passwd " |tee -a $0.log
 65 
 66 #
 67 #    4、配置svn权限
 68 #
 69 
 70 #    4.1、设置权限节点
 71 echo "[$repo_name:/]" >>$svn_path/$repo_name/conf/authz
 72 #    4.2、配置管理员账号有“读写”权限
 73 echo "admin = rw" >>$svn_path/$repo_name/conf/authz
 74 #    4.3、配置读写账号有“读写”权限
 75 echo "rw_user = rw" >>$svn_path/$repo_name/conf/authz
 76 #    4.4、配置只读账号有“只读”权限
 77 echo "ro_user = r" >>$svn_path/$repo_name/conf/authz
 78 
 79 #
 80 #    5、配置http访问
 81 #
 82 
 83 echo '<Location /svn/'$repo_name'>' >> /etc/httpd/conf.d/subversion.conf
 84 #    定义svn类型的http服务,会调用dav_svn_module
 85 echo '    DAV svn' >> /etc/httpd/conf.d/subversion.conf
 86 #    svn版本库目录
 87 echo '    SVNPath '$svn_path'/'$repo_name'' >> /etc/httpd/conf.d/subversion.conf
 88 #    svn访问权限的配置文件
 89 echo '    AuthzSVNAccessFile '$svn_path'/'$repo_name'/conf/authz' >> /etc/httpd/conf.d/subversion.conf
 90 #    svn使用http基本验证方式验证账号身份
 91 echo '    AuthType Basic' >> /etc/httpd/conf.d/subversion.conf
 92 #    http基本验证的提示信息
 93 echo '    AuthName "Authorization repot SVN"' >> /etc/httpd/conf.d/subversion.conf
 94 #    svn账号配置文件,包含加密后的密码信息
 95 echo '    AuthUserFile '$svn_path'/'$repo_name'/conf/passwd' >> /etc/httpd/conf.d/subversion.conf
 96 #    仅允许通过验证的用户访问svn
 97 echo '    Require valid-user' >> /etc/httpd/conf.d/subversion.conf
 98 echo '</Location>' >> /etc/httpd/conf.d/subversion.conf
 99 
100 #    重启http服务
101 /etc/init.d/httpd restart
102 #    设置http服务开机启动
103 chkconfig httpd on
104 #    在防火墙上开放http服务
105 iptables -I INPUT -p tcp --dport 80 -m state --state NEW -j ACCEPT
106 /etc/init.d/iptables save
107 #    关闭selinux
108 setenforce 0
109 
110 #
111 #    6、提交代码时必须写注释,且不能少于10个字符;允许修改注释
112 #
113 
114 cp $svn_path/$repo_name/hooks/pre-commit.tmpl $svn_path/$repo_name/hooks/pre-commit
115 
116 sed -i '75a LOGMSG=$($SVNLOOK log -t "$TXN" "$REPOS" | grep "[a-zA-Z0-9]" | wc -c)\nif [ "$LOGMSG" -lt 10 ]; then\necho -e "\n 提交文件时必须添加注释,提交中止."1>&2\nexit 1\nfi' $svn_path/$repo_name/hooks/pre-commit
117 
118 sed -i 's/^commit-access-control.pl/#commit-access-control.pl/' $svn_path/$repo_name/hooks/pre-commit
119 
120 chmod +x $svn_path/$repo_name/hooks/pre-commit
121 
122 cp $svn_path/$repo_name/hooks/pre-revprop-change.tmpl $svn_path/$repo_name/hooks/pre-revprop-change
123 
124 chmod +x $svn_path/$repo_name/hooks/pre-revprop-change

 

转载于:https://www.cnblogs.com/www1707/p/5435919.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109054.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 浏览器offsetWidth、clientWidth、scrollWith等总结

    浏览器offsetWidth、clientWidth、scrollWith等总结  对象尺寸会涉及width和height,我们以width为例,height则是一样的道理。  1、clientWidth:对象可见的宽度,不包括滚动条等边线,会随窗口的显示大小改变。  clientWidth = 元素width+padding  2、scrollWidth:实际内容的宽,不包括边线宽度,会随着对象中内容的多少改变。  无滚动时等于c…

    2022年7月22日
    10
  • JVM调优常用参数

    JVM调优常用参数

    2021年5月14日
    94
  • 【WPF】Toolkit(一个项目)的要点总结

    【WPF】Toolkit(一个项目)的要点总结架构相关1.插件式开发:MEF具体怎么使用可参考百度+Demo(密码:k8ck)2.备份机制(项目特有功能)待续3.镜像机制(项目特有功能)待续4.分模块记录日志(转)非常完善的Log4net详细说明UI相关1.多语言读取系统的显示语言(displayLanguage),显示语言的定义是:假如你的系统现在是中文的,

    2022年10月2日
    1
  • Eclipse自动补全设置(终极方案)

    Eclipse自动补全设置(终极方案)Eclipse自动补全、字体、护眼色、tomcat、导包1.设置字体2.设置护眼色3.设置自动补全4.配置Tomcat服务器5.配置默认JSP编码6.无法导包解决方案1.设置字体2.设置护眼色3.设置自动补全26字母和”.”均会提示:Java和Java类型补全建议+26字母异常强大的补全提示:4.配置Tomcat服务器5.配置默认JSP编码6.无法导包解决方案…

    2022年6月28日
    28
  • Collections.shuffle()源码分析

    Collections.shuffle()源码分析Java.util.Collections类下有一个静态的shuffle()方法,如下:1)staticvoidshuffle(List<?>list)使用默认随机源对列表进行置

    2022年7月2日
    23
  • wd移动硬盘不能识别_西数移动硬盘电脑提示无法识别USB设备怎么办「建议收藏」

    展开全部1.造成USB设备无法识别的故障是由于很多原因引起的,包括软、硬件,解决方法32313133353236313431303231363533e58685e5aeb931333337623431如下:首先将usb设备插入计算机接口,然后在桌面左下角单击“开始”菜单,单击“运行”命令,打开框中键入“cmd”命令,单击“确定”按钮。2.启动命令提示符窗口,分别执行以下两条命令regadd”H…

    2022年4月11日
    68

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号