论坛风格切换切换到宽版
  • 2016阅读
  • 4回复

[问题求助][CentOS] svn用户使用mysql验证 [复制链接]

上一主题 下一主题
离线tantan886.
 
发帖
2044
C币
-140694
威望
374
贡献值
1
银元
-1
铜钱
4597
人人网人气币
0
只看楼主 倒序阅读 使用道具 楼主  发表于: 2009-05-01
请问svn用户能用my.sql数据库验证吗?.

[ 本帖最后由 timdcn 于 20.0.9-10-19 16:45 编辑 ].


最佳答案gamester88
http://upload.bbs.csuboy.com/Mon_1004/126_7121_c2515fb4e40125e.gif[/img]http://snakeskin.javaeye.com/blog/147324虚拟主机

SVN的安装和配置
技术准备
检.查软件包your_package是否安装.
#rp.m -qa | grep. your_package[成人用品]
安装y.our_package软件包    美容
#r.pm -ivh your_package电脑
或者
#rpm -Uvh your_p.ackage虚拟主机
步骤1、检查并安装.SVN以及相关软件包    健康
请确认下面软件包有没有安装,如果没有安装,请到rh.el5/centos5光盘找到.这些软件包并安装    健康
openssl-0.9.8.b-8.3.el5    外汇
openssl-devel-0.9.8b-8.3.e..l5.
mod_ssl.-2.2.3-6.el5           婚庆
mod_auth_mysql.-3.0.0-3.1投资
mysql-server-5.0.22.-2.1学习
mysq.l-5.0.22-2.1域名
mysql-devel-.5.0.22-2.1           女人
subv.ersion-1.4.2-2.el5教育
mod_dav_svn-1.4.2-2..el5--------------彩票
如果安装正常的.话,应该在/etc/httpd/module.s目录下能找到这些模块域名
m.od_authz_svn.so外贸
mod_dav_svn.so
mod_au.th_mysql.so.
步骤2、初始化reposito.ry    外汇
创建svn的项目库父路径,我把/svn/repo.s做为svn的项目库父路径。这个目录是任意的,如果是多个项目库则.必须在同一个父路径下          婚庆
#mkdir /svn/rep.os电脑
我们通过.如下命令初始化.一个svn项目库TelecomRepositorys.
#svnadm..in create /svn/repos/TelecomRepositorys--- 印刷
重复上面的命.令创建多个项目库,如(广告)
#svnadmin. create /svn/repo.s/OtherRepositorys    外汇
或者你指定SVN库的存储方式
#svnadmin create --fs-type fsfs /svn/.repos/T.elecomRepositorys.
或者
#svnad.mi.n create --fs-type bdb /svn/repos/TelecomRepositorys.
默认是bdb(Berkeley DB)的存.储方式,不过一般.人更喜欢fsfs的存储库方式.
步骤3、创建登陆用户文件[如果用数据.库认证的话,此步可忽略.]          婚庆
在/sv.n目录下创建登陆用户文件.htpasswd以及2个用户test1,te.st2           鲜花
#htpasswd -c /svn/.htpasswd ..test1--------------彩票
#htpasswd /s.vn/.htpasswd t.est2投资
步骤4:创建认证数据库[如果用登陆用户文件认证的话,此步可..忽略]健康
登陆mysql
#mysql -u roo.t -p            杀毒
创建数据库svn_auth
mysql>create da.tabase. svn_auth;[成人用品]
mysql>user svn_auth; .             汽车
创建用户svn
mysql>.GRANT ALL PRIVILEGES ON *..* .TO svn@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;           建材
创建表users
my.sql> CREATE TABLE u.sers (.
-> .  user_nam.e CHAR(30) NOT NULL,.
->   u..ser_passwd CHAR(20) NOT NULL,.
->   PR.IMARY KEY (u.ser_name)(广告)
-> );
添加2个测试帐号
mysql.> ins.ert into users values('test1', ENCRYPT('password'));--------------彩票
mysql> insert into user values('test2', ENCRYPT('pas.sword'));.(广告)
mysql>commit;
步骤5、SVN访问控制
在/svn目.录下创建访问控制文件文件svnaccess,名字任意,不过在以.后的配置过程中你必须使用正确的名字,文件内容为--- 印刷
[groups]  
# harryharry._and_sally = harry,sally   .             女人
[/]  
*=rw  
我们可以看到.最后2行才是有效的,意思是.对所有的项目,所有人都有读写(rw)的权限,当然我们还可以对某个项目单独进行限制,设置如下虚拟主机
[groups]  
# harryharry_and_sally = harry,sally    .. [成人用品]
  
[T.elecomRepositorys:/]               杀毒
test1=r  
*=rw  
意思是对于项目库Tele.comRepositorys,用户test1只有读权限,其他人有读.写权限    健康
步骤.6、Apache和SVN集成电影
编辑apache的配置文件/etc/http.d/conf/httpd.conf文件或者./etc/httpd/con.f.d/subversion.conf文件           鲜花
如果你使用登陆文件认证的方式(步骤3),添.加如下.内容 .
<Location. /svn>  域名
DAV svn     .                 .     电脑
SVNParentPath /svn/repos   .      .                      健康
AuthzSVNAccessFile /svn/svnaccess               .        .                杀毒
Aut.hType Basic                     .      --- 印刷
AuthName "SVN .Repositorys"              .             (广告)
AuthUserFile /svn/.htpasswd          .           .          外汇
Require valid-user .     (        游戏          )
</Location>  
如果你使用数据库认证的方式(步骤4),添.加如下内容.
<Location /svn>        .            .  
DA.V svn           .                       女人
SVN.ParentPath /sv.n/repos                       健康
AuthzSVNAccessFile /svn/svn..access                       .
AuthName "SVN Repositorys."                      . 服务器
AuthType Basic           .     .       .
AuthMYSQLEnab.le on                  .     (        游戏          )
A.uthMYSQLUser svn                 .      --- 印刷
AuthMySQL.Password passwo.rd                           外汇
AuthMYSQLDB svn_..auth                       域名
AuthMYSQLUserTabl.e users           .                       建材
AuthMY.S.QLNameField user_name                                 婚庆
AuthMYSQLPa.sswordField user_passwd       .                (广告)
Require valid-us.er   .            .
</.Location>    教育
我们可以看到/s.vn/svnaccess,/svn/.htpasswd是我们创建的文件,如.果名字自定义的话,请在http.con.f配置正确,同样需要正确配置的还有数据库用户svn,数据库svn_auth,表名users等等。.
步.骤7、安全访问设置[必须设.置,否则svn无法访问]电脑
修改目录的属主和访问权限
#.chown apache..apache -R /svn.
#chmod 755 -R. /svn 健康
修改SELinux的设置
禁.用SELinux(强烈.不推荐)或者在SELinux图形管理界面中勾上Disable SELinux protection for. httpd daemon这个.选项,否则apache这个虚拟用户无法访问/svn目录,当然你也可以用更好的方法设置apache的访问权限.           鲜花
步骤8、.重新启动Apache服务器虚拟主机
执行如下命令
#servic.e httpd restart--------------彩票
  或者
#/e.tc/init.d/httpd restart..
键入下面的url看是否能正确的.访问svn。外贸
http://localhost/svn/TelecomRepositorys虚拟主机


评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
离线liuqhe.
发帖
2082
C币
-593658
威望
412
贡献值
2
银元
-2
铜钱
4835
人人网人气币
0
只看该作者 沙发  发表于: 2010-04-13
Re:[CentOS]
http://snakeskin.javaeye.com/blog/147324

SVN的安装和配置
技术准备
检查软件包your_package是否安装
#rpm -qa | grep your_package
安装your_package软件包
#rpm -ivh your_package
或者
#rpm -Uvh your_package
步骤1、检查并安装SVN以及相关软件包
请确认下面软件包有没有安装,如果没有安装,请到rhel5/centos5光盘找到这些软件包并安装
openssl-0.9.8b-8.3.el5
openssl-devel-0.9.8b-8.3.el5
mod_ssl-2.2.3-6.el5
mod_auth_mysql-3.0.0-3.1
mysql-server-5.0.22-2.1
mysql-5.0.22-2.1
mysql-devel-5.0.22-2.1
subversion-1.4.2-2.el5
mod_dav_svn-1.4.2-2.el5
如果安装正常的话,应该在/etc/httpd/modules目录下能找到这些模块
mod_authz_svn.so
mod_dav_svn.so
mod_auth_mysql.so
步骤2、初始化repository
创建svn的项目库父路径,我把/svn/repos做为svn的项目库父路径。这个目录是任意的,如果是多个项目库则必须在同一个父路径下
#mkdir /svn/repos
我们通过如下命令初始化一个svn项目库TelecomRepositorys
#svnadmin create /svn/repos/TelecomRepositorys
重复上面的命令创建多个项目库,如
#svnadmin create /svn/repos/OtherRepositorys
或者你指定SVN库的存储方式
#svnadmin create --fs-type fsfs /svn/repos/TelecomRepositorys
或者
#svnadmin create --fs-type bdb /svn/repos/TelecomRepositorys
默认是bdb(Berkeley DB)的存储方式,不过一般人更喜欢fsfs的存储库方式
步骤3、创建登陆用户文件[如果用数据库认证的话,此步可忽略]
在/svn目录下创建登陆用户文件.htpasswd以及2个用户test1,test2
#htpasswd -c /svn/.htpasswd test1
#htpasswd /svn/.htpasswd test2
步骤4:创建认证数据库[如果用登陆用户文件认证的话,此步可忽略]
登陆mysql
#mysql -u root -p
创建数据库svn_auth
mysql>create database svn_auth;
mysql>user svn_auth;
创建用户svn
mysql>GRANT ALL PRIVILEGES ON *.* TO svn@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
创建表users
mysql> CREATE TABLE users (
->   user_name CHAR(30) NOT NULL,
->   user_passwd CHAR(20) NOT NULL,
->   PRIMARY KEY (user_name)
-> );
添加2个测试帐号
mysql> insert into users values('test1', ENCRYPT('password'));
mysql> insert into user values('test2', ENCRYPT('password'));
mysql>commit;
步骤5、SVN访问控制
在/svn目录下创建访问控制文件文件svnaccess,名字任意,不过在以后的配置过程中你必须使用正确的名字,文件内容为
[groups]  
# harryharry_and_sally = harry,sally    
[/]  
*=rw  
我们可以看到最后2行才是有效的,意思是对所有的项目,所有人都有读写(rw)的权限,当然我们还可以对某个项目单独进行限制,设置如下
[groups]  
# harryharry_and_sally = harry,sally    
  
[TelecomRepositorys:/]  
test1=r  
*=rw  
意思是对于项目库TelecomRepositorys,用户test1只有读权限,其他人有读写权限
步骤6、Apache和SVN集成
编辑apache的配置文件/etc/httpd/conf/httpd.conf文件或者/etc/httpd/conf.d/subversion.conf文件
如果你使用登陆文件认证的方式(步骤3),添加如下内容
<Location /svn>  
DAV svn                          
SVNParentPath /svn/repos                          
AuthzSVNAccessFile /svn/svnaccess                          
AuthType Basic                          
AuthName "SVN Repositorys"                          
AuthUserFile /svn/.htpasswd                          
Require valid-user      
</Location>  
如果你使用数据库认证的方式(步骤4),添加如下内容
<Location /svn>                      
DAV svn                      
SVNParentPath /svn/repos                      
AuthzSVNAccessFile /svn/svnaccess                      
AuthName "SVN Repositorys"                      
AuthType Basic                      
AuthMYSQLEnable on                      
AuthMYSQLUser svn                      
AuthMySQLPassword password                      
AuthMYSQLDB svn_auth                      
AuthMYSQLUserTable users                      
AuthMYSQLNameField user_name                      
AuthMYSQLPasswordField user_passwd                      
Require valid-user              
</Location>    
我们可以看到/svn/svnaccess,/svn/.htpasswd是我们创建的文件,如果名字自定义的话,请在http.conf配置正确,同样需要正确配置的还有数据库用户svn,数据库svn_auth,表名users等等。
步骤7、安全访问设置[必须设置,否则svn无法访问]
修改目录的属主和访问权限
#chown apache.apache -R /svn
#chmod 755 -R /svn
修改SELinux的设置
禁用SELinux(强烈不推荐)或者在SELinux图形管理界面中勾上Disable SELinux protection for httpd daemon这个选项,否则apache这个虚拟用户无法访问/svn目录,当然你也可以用更好的方法设置apache的访问权限.
步骤8、重新启动Apache服务器
执行如下命令
#service httpd restart
  或者
#/etc/init.d/httpd restart
键入下面的url看是否能正确的访问svn。
http://localhost/svn/TelecomRepositorys


发帖
2073
C币
-139650
威望
368
贡献值
1
银元
-4
铜钱
4512
人人网人气币
0
只看该作者 板凳  发表于: 2010-04-13
Re:[CentOS]
3楼你好。我现在的问题是用你这个方法是可以验证的。但是我用bugzilla的数据表,里面的密码加密方式是SHA-256,这个加密方式mod_auth_mysql好像不支持,请问有办法解决吗


离线xxtyshun.
发帖
2035
C币
-627287
威望
357
贡献值
4
银元
-1
铜钱
4444
人人网人气币
0
只看该作者 地板  发表于: 2010-04-13
Re:[CentOS]
这个我不是很清楚啊,我这里的svn用的不是数据库的用户,所以没有怎么弄过这个


发帖
2099
C币
-235665
威望
403
贡献值
1
银元
-1
铜钱
4673
人人网人气币
0
只看该作者 4楼 发表于: 2010-04-13
Re:[CentOS]
能帮忙看下嘛,这个问题我网上找了好久,都没找到解决方案呢


快速回复
限100 字节
如果您在写长篇帖子又不马上发表,建议存为草稿
 
上一个 下一个