欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Subversion使用Redmine帐户验证简单应用、高级应用以及优化

程序员文章站 2022-03-02 22:36:31
...

这是原创:http://www.himysql.com/vcs/subversion-redmine-advance.html
一、简介

Redmine是一套开源、免费跨平台的项目管理系统,是项目管理界的后起之秀。是中小型开发团队项目管理的首选系统。

Redmine跟Trac类似,但是支持多项目、wiki、多种版本控制系统(Subversion、Git、Mercurial)。

Subversion就不累述了。

 

Subversion的帐号管理默认只能通过htpasswd添加及管理密码。新员工加入团队或者离开团队时SVN帐号管理起来都非常不方便。通过redmine系统可以实现员工自行操作实现修改密码、忘记密码取回等操作。

今天就探讨一个使用Redmine帐号来验证Subversion的简单应用及高级应用。

二、软件准备

Subversion 1.4以上版本、Apache 2.0以上版本、mod_dav_svn.so(注意要和apache版本对应)、redmine、mod_auth_mysql 2.8以上版本

本次实验的版本号如下:

subversion 1.6.5(通过yum从rpmforge装的)、apache 2.2(centos rpm装的)、mod_dav_svn.so(同样通过yum从rpmforge装的)、redmine 0.8.7

mod_auth_mysql(同样通过yum从rpmforge装的)

上述三个软件以及两个apache插件装好后就可以开工啦。(redmine具体安装方法请参考官方安装文档或者网上教程)

什么,你说我懒?!

那就对了,我们要把精力放在关键的地方,非关键的地方能快速通过的就快速通过。

三、简单应用

先来个简单的应用:redmine系统中所有注册且已经激活的帐号能访问SVN。

 

新注册的帐号由redmine管理员激活之后,即可访问subversion。

httpd.conf中配置如下:

<Location /svn>

Order Deny,Allow

Deny from all

DAV svn

SVNListParentPath on

SVNParentPath /Data/SVNRepo

AuthzSVNAccessFile /Data/SVNRepo/authz  #若需要进行路径精准控制,需要加上该句

 

 

        AuthMySQLEnable On

        AuthMySQLHost 192.168.xxx.xxx  # redmine 所用户MySQL数据服务器的IP

        AuthMySQLUser redmine  # redmine链接数据库所用的用户名

        AuthMySQLPassword redminepasswd # redmine链接数据库所用的密码

        AuthMySQLDB redmine087  # redmine所用数据库名

        AuthMySQLUserTable "users“

        AuthMySQLNameField login

        AuthMySQLPasswordField hashed_password

        AuthMySQLPwEncryption sha1

        AuthMySQLUserCondition " users.`status` = 1"

Require valid-user

 

</Location>

改完重启apache即可。

四、高级应用

Redmine功能强大,可以用来在公司、团队中分享知识、BUG管理、进度管理等。但并不是每个Redmine用户都需要访问Subversion,所以需要控制指定某一部分用户才能访问Subversion。

经过研究,我发现结合redmine项目成员管理可以实现上述目的。

思路:新建一个项目(这个项目并不是真正的项目),就是为了验证Subversion之用。即,这个项目的成员都可以访问Subversion。新注册帐号由redmine管理员激活,并且将新注册帐号设成刚才新建项目的成员。

实现:

 

<Location /svn>

   Order Deny,Allow

   Deny from all

   DAV svn

   SVNListParentPath on

   SVNParentPath /Data/SVNRepo

    AuthzSVNAccessFile /Data/SVNRepo/authz

        AuthName "SVN"

        AuthType Basic

 

        AuthMySQLEnable On

        AuthMySQLHost 192.168.xxx.xxx

        AuthMySQLUser redmine

        AuthMySQLPassword redmine_password

        AuthMySQLDB redmine087

        AuthMySQLUserTable "users, members" #注意这儿跟上不一样

        AuthMySQLNameField login

        AuthMySQLPasswordField hashed_password

        AuthMySQLPwEncryption sha1

        AuthMySQLUserCondition "members.`project_id` = 1 and members.`role_id` IN (3, 4) and users.`status` = 1 and users.`login` <> '' and users.id = members.`user_id`"  #project_id = 1具体数字要根据用来验证用户的项目的ID来定

    Require valid-user

</Location>

五、优化

若团队成员比较多,为了减轻数据库的压力,提高验证响应速度,可以对redmine数据库进行小小的优化:

对redmine数据库中members表添加user_id、project_id、role_id联合索引。

事半功倍哦。