Subversion使用Redmine帐户验证简单应用、高级应用以及优化
这是原创: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联合索引。 事半功倍哦。
一、简介
上一篇: 如何把redmine的数据从sqlite导入到mysql
下一篇: redmine