简介

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

事半功倍哦。