一、简介

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联合索引。

事半功倍哦。