SVN Beginning-2
SVN版本问题解决方案:
1、svn: Expected version '3' of repository; found version '5' / svn: Expected format '3' of repository; found format '5'
把home/svnroot/repository/test/format文件中的5改成3就可以了. 
2、svn: Expected FS format '1'; found format '2'
把home/svnroot/repository/test/db/format文件中的2改成1就可以了.
Linux环境下Subversion,apache2,ssl配置安装(FC4系统)
/////////////////////////////////////////////////////////// 
工具包
httpd-2.2.4 
下载地址
[url=http://apache.justdn.org/httpd/]http://apache.justdn.org/httpd/[/url] 
apr-1.2.8 
apr-util-1.2.8 
下载地址
[url=http://apache.justdn.org/apr/]http://apache.justdn.org/apr/[/url] 
openssl 
openssl-0.9.7d.tar.gz 
下载地址
http://www.openssl.org/source/ 
证书软件
ssl.ca-0.1.tar.gz 
下载地址
http://www.openssl.org/contrib/ssl.ca-0.1.tar.gz 
SVN 
下载地址
[url=http://www.iusesvn.com/bbs/download/subversion-1.4.0.tar.gz]http://www.iusesvn.com/bbs/download/subversion-1.4.0.tar.gz[/url] 
////////////////////////////////////////////////////////////////////// 
开始安装
安装apr,apr-util 
tar zxvf apr-1.2.8.tar.gz 
cd apr-1.2.8 
./configure --prefix=/usr/local/apr 
make 
make install 
tar zxvf apr-util-1.2.8.tar.gz 
cd apr-util-1.2.8 
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr make 
make install 
# tar zxvf openssl-0.9.8d.tar.gz 
# cd openssl-0.9.8d 
# ./config --prefix=/usr/local/openssl 
# make 
# make install 
安装apache 
tar zxvf httpd-2.2.3.tar.gz 
cd httpd-2.2.3 
./configure --prefix=/usr/local/apache2 --enable-so --enable-rewrite=share --enable-proxy=share --enable-proxy-ajp=share --enable-dav=share --enable-dav-fs --with-apr=/usr/local/apr/ --with-apr-util=/usr/local/apr-util/ --enable-ssl=static --with-ssl=/usr/local/ssl --enable-mods-shared=all //此语句意思是把所有模块都添加上,在这里可以不写
make 
make install 
其中/usr/local/ssl目录自己建
安装SVN 
tar zxvf subversion-1.4.2.tar.gz 
cd subversion-1.4.2 
./configure --with-apxs=/usr/local/apache2/bin/apxs --prefix=/usr/local/subversion --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --with-ssl --with-zlib --enable-maintainer-mode 
make 
make install 
/////////////////////////////////////////////////////////// 
配置
1.//创建库文件
# mkdir /home/svnroot/repository //进入subversion的bin目录
# cd /usr/local/subversion/bin 
# ./svnadmin create /home/svnroot/repository/test //创建仓库"test" 
# ls –l /home/svnroot/repository/test //看看是不是多了些文件,如果是则说明Subversion安装成功了
# cd /usr/local/subverion/bin 
# ./svn import /home/user/import file:///home/svnroot/repository/test –m "init" //这条语句将把路径/home/user/import下找到的文件导入到你创建的Subversion 仓库中去,其中/user/import/下有自己的项目.提交后的修订版为1。
apache进程的权限:因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在 /usr/local/apache2/conf/httpd.conf 文件中配置,找到文件中的这两行:
User daemon # 将daemon改为svnroot,
Group daemon 
2.修改Apache配置文件
# cd /usr/local/apache2/bin 
# ./apachect1 start //启动Apache 
# vi /opt/apache2/conf/httpd.conf //在最下面添加
#LoadModule dav_svn_module modules/mod_dav_svn.so 
#LoadModule authz_svn_module modules/mod_authz_svn.so //如果有可不写
<Location /svn> 
DAV svn 
SVNParentPath /home/svnroot/repository/ //svn父目录
AuthzSVNAccessFile /home/svnroot/repository/authz.conf //权限配置文件
AuthType Basic //连接类型设置
AuthName "Subversion.zoneyump" //连接框提示
AuthUserFile /home/svnroot/repository/authfile //用户配置文件
Require valid-user //采用何种认证
</Location> 
#"Require valid-user"告诉apache在authfile中所有的用户都可以访问。如果没有它,则只能第一个用户可以访问新建库
3.创建用户配置文件
#cd /usr/local/apache2/bin 
#htpasswd -c /home/svnroot/repository/authfile wooin //其中authfile是通过来创建的
4.配置用户访问权限: 
vi /home/svnroot/repository/authz.conf //示例
[groups] 
admin = mangosoft 
[/] 
@admin = rw 
[test:/] 
@admin = rw 
wooin = rw 
为了简化配置,3个版本库共用1个权限配置文件/home/svnroot/repository/pwd.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。
注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups] 
<用户组名> = <用户1>,<用户2> 
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录] 
@<用户组名> = <权限> 
<用户名> = <权限> 
其中,方框号内部分可以有多种写法: 
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/home/svnroot/repository。这样,/就是表示对全部版本库设置权限。
test:/,表示对版本库test设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
5. 不让其他人有该目录的权限
# chown -R svnroot:daemon /home/svnroot/repository //,这里的用户名可以自己定
6.检验是否成功
重启apache 
cd /usr/local/apache2/bin/ 
./apachectl restart 
//打开浏览器访问[url=http://localhost/svn/test/] 
http://localhost/svn/test/ //如果有东西显示就说明成功。
注意:如果没成功在/usr/local/apache2/htdocs/下建一个favicon.ico文件. 
//////////////////////////////////////////////////////// 
基本应用
1. 权限管理
1)增加用户
# htpasswd [-c] /home/svnroot/repository/authfile wooin //第一次设置用户时使用-c表示新建一个用户文件。回车后输入用户密码,
# htpasswd authfile 用户名(加入新的用户) //完成对用户 的增加
2)权限分配
# vi /home/svnroot/repository/authz.conf 
[test:/] //这表示,仓库test的根目录下的访问权限
wooin = rw //test仓库wooin用户具有读和写权限
bao = r //test仓库bao用户具有读权限
[test2:/] //test2仓库根目录下的访问权限
wooin = r //wooin用户在test2仓库根目录下只有读权限
bao = //bao用户在 test2仓库根目录下无任何权限
[/] //这个表示在所有仓库的根目录下
* = r //这个表示对所有的用户都具有读权限
#[groups] //这个表示群组设置
#svn1-developers = wooin, bao //这个表示某群 组里的成员
#svn2-developers = wooin 
#[svn1:/] 
#@svn1-developers = rw //如果在前面加上@符号,则表 示这是个群组权限设置
将这个设置完成后。重启Apache,就可以通过
http://localhost/svn/test 
这个URL来访问仓库了,当然,受权限的限制,必须是合法用户才能访问且具有相应的权限
2. 在/etc/profile的结尾设置一些svn启动时要做的工作
# start apache server for svn 
/usr/sbin/apachectl start 
export SVN_EDITOR=vi 
3. 如果linux的登录用户名密码都和svn的其中一个用户名密码相同时,在checkout的时候不会要求输入用户名密码直接就可以checkout出来。比如:linux有个用户wooin,svn也有一个用户wooin,并且密码都是一样的,当用wooin登录linux后,执行checkout,可以直接提取出源码文件,不用输入现ば畔ⅰ?
4. 在svn使用过程中牵扯到几种权限:文件系统的权限,linux系统权限,svn用户的权限,apache进程的权限。
文件系统的权限,linux系统权限:这里相同的意思,就是平时大家使用linux时文件夹和文件的访问权限。在 svn建立仓库,文件夹,配置文件的时候用svnroot用户,并将仓库权限设置为700,不允许其他用户直接通过文件系统查看,只能由svnroot进行管理。
apache进程的权限:因为所有跟仓库传输的操作都是通过apache进程进行的,所以即使你给svn用户设置了很大的权限,但是apache进程没有访问仓库或者相关文件的权限也没有用,apache进程的权限设置在 /usr/local/apache2/conf/httpd.conf 文件中配置,找到文件中的这两行:
User daemon # 将daemon改为svnroot,让apache进程以svnroot的身份运行
Group daemon 
svn用户的权限:就是在authz.conf文件中设置的权限信息,是svn用来管理仓库访问权限的。
5. 重新部署SVN仓库
需要将目前的某个仓库导出,并导入到另一个仓库(可以导入到该仓库的指定目录下), 
要用到以下的命令:
# svnadmin dump /home/svnroot/sonatina/ > stn.dump // 导出所有版本到stn.dump文件中
# svnadmin dump /home/svnroot/sonatina/ --revision 10 > stn.r10.dump // 或者也可以只导出其中一个版本
# svnadmin dump /home/svnroot/sonatina/ --revision 0:10 > stn.r0-10.dump // 或者也可以导出多个版本,比如0-10版本
# svnadmin load /home/svnroot/sonatinab/ --parent-dir trunk < stn.r0-10.dump // 导入到sonatinab/trunk目录下,如果不指定--parent-dir,则会导入到根目录sonatinab/下
////////////////////////////////////////////////////////// 
使用ssh方式验证: 
cd /home/usr/local/subversion/bin 
./svn list svn+ssh://ip地址/home/svnroot/repository/test 
如果出现这个问题: 
subversion/libsvn_repos/repos.c:1004: (apr_err=165005) 
svn: Expected version '3' of repository; found version '5' 
把home/svnroot/repository/test/format文件中的5改成3就可以了. 
/////////////////////////////////////////////////////// 
使用https方式验证
vi /usr/local/apache/conf/http.conf 
# Secure (SSL/TLS) connections 
Include conf/extra/httpd-ssl.conf //把此处的#去掉
# 
# Note: The following must must be present to support 
# starting without SSL on platforms with no /dev/random equivalent 
# but a statically compiled-in mod_ssl. 
# 
# cd /usr/local/apache2 
# ./bin/apachectl start 
Syntax error on line 108 of /usr/local/apache2/conf/ssl.conf: 
SSLCertificateFile: file '/usr/local/apache2/conf/server.key' does not exist or is empty 
这又是什么原因呢?因为我们没有配置ssl,需要生成ssl需要的证书。
以前使用apache1+mod_ssl的时候,make之后有一个这样的步骤
$ make certificate 
可以用来生成ssl所用到的证书。
现在没有这个工具了,只能自己动手生成了,对证书不熟悉的人,有一个工具可以使用:http://www.openssl.org/contrib/ssl.ca-0.1.tar.gz 
# cd /usr/local/apache2/conf 
# tar zxvf ssl.ca-0.1.tar.gz 
# cd ssl.ca-0.1 
# ./new-root-ca.sh (生成根证书) 
No Root CA key round. Generating one 
Generating RSA private key, 1024 bit long modulus 
...........................++++++ 
....++++++ 
e is 65537 (0x10001) 
Enter pass phrase for ca.key: (输入一个密码) 
Verifying - Enter pass phrase for ca.key: (再输入一次密码) 
...... 
Self-sign the root CA... (签署根证书) 
Enter pass phrase for ca.key: (输入刚刚设置的密码) 
........ 
........ (下面开始签署) 
Country Name (2 letter code) [MY]: CN 
State or Province Name (full name) [Perak]: liaoning 
Locality Name (eg, city) [Sitiawan]: dalian 
Organization Name (eg, company) [My Directory Sdn Bhd]: jishikeyan 
Organizational Unit Name (eg, section) [Certification Services Division]: ACSTAR 
Common Name (eg, MD Root CA) []: yong 
Email Address []: yong@yong.com.cn 
这样就生成了ca.key和ca.crt两个文件,下面还要为我们的服务器生成一个证书:
# ./new-server-cert.sh server (这个证书的名字是server) 
...... 
...... 
Country Name (2 letter code) [MY]: CN 
State or Province Name (full name) [Perak]: liaoning 
Locality Name (eg, city) [Sitiawan]: dalian 
Organization Name (eg, company) [My Directory Sdn Bhd]: jishikeyan 
Organizational Unit Name (eg, section) [Secure Web Server]: ACSTAR 
Common Name (eg, www.domain.com) []: localhost 
Email Address []: yong@yong.com.cn 
这样就生成了server.csr和server.key这两个文件。
还需要签署一下才能使用的:
# ./sign-server-cert.sh server 
CA signing: server.csr -> server.crt: 
Using configuration from ca.config 
Enter pass phrase for ./ca.key: (输入上面设置的根证书密码) 
Check that the request matches the signature 
Signature ok 
The Subject's Distinguished Name is as follows 
countryName :PRINTABLE:'CN' 
stateOrProvinceName :PRINTABLE:'liaoning' 
localityName :PRINTABLE:'liaoning' 
organizationName :PRINTABLE:'jishikeyan' 
organizationalUnitName:PRINTABLE:'ACSTAR' 
commonName :PRINTABLE:'localhost' 
emailAddress :IA5STRING:'yongl@yong.com.cn' 
Certificate is to be certified until Jul 16 12:55:34 2005 GMT (365 days) 
Sign the certificate? [y/n]: y 
1 out of 1 certificate requests certified, commit? [y/n] y 
Write out database with 1 new entries 
Data Base Updated 
CA verifying: server.crt <-> CA cert 
server.crt: OK 
下面要按照ssl.conf里面的设置,将证书放在适当的位置。
# chmod 400 server.key 
# cd .. 
# mv ssl.ca-0.1/server.key server.key 
# mv ssl.ca-0.1/server.crt server.crt 
然后就可以启动啦!
# cd /usr/local/apache2 
# ./bin/apachectl start 
在浏览器中https://127.0.0.1/svn/test就可以进行https用户验证啦! 
subversion验证
./svn list https://localhost/svn/test 
验证“https://localhost:443”的服务器凭证时发生错误:
- 本凭证并不是由受信任的权威机权所核发。请手动利用指纹以验证
凭证的有效性!
- 本凭证的主机名称不符。
凭证信息:
- 主机名称:www.yong.com 
- 有效期间:自 Jan 25 07:55:48 2007 GMT 至 Jan 25 07:55:48 2008 GMT - 发行者:yong, jishi, dalian, liaoning, CN 
- 指纹:49:c4:12:38:5e:03:df:52:64:eb:f4:02:b8:a4:f3:b0:2c:f7:8d:2a(R)拒绝,(t)暂时接受 或 (p)永远接受?t 
填写证书密码
用户名
密码
登录成功!!!!! 
////////////////////////////////////////////////////// 
subversion基本操作
1.从服务器中拷贝库文件
#cd /usr/local/subversion/bin 
#./svn checkout http://ip地址/svn/test 
[root@localhost bin]# ./svn checkout http://192.168.9.5/svn/test 
认证领域:<http://192.168.9.5:80> Subversion.zoneyump 
“root”的密码:
认证领域:<http://192.168.9.5:80> Subversion.zoneyump 
用户登录名:gy 
“gy”的密码:
A test/index.html 
A test/dianhuaben 
A test/dianhuaben/chaxun.jsp 
A test/dianhuaben/modify.jsp 
A test/dianhuaben/work 
A test/dianhuaben/work/tldCache.ser 
A test/dianhuaben/work/org 
A test/dianhuaben/work/org/apache 
A test/dianhuaben/work/org/apache/jsp 
A test/dianhuaben/work/org/apache/jsp/addtel_jsp.java 
A test/dianhuaben/work/org/apache/jsp/selectAllTel_jsp.java 
A test/dianhuaben/work/org/apache/jsp/addtel_jsp.class 
A test/dianhuaben/work/org/apache/jsp/selectAllTel_jsp.class 
A test/dianhuaben/work/SESSIONS.ser 
A test/dianhuaben/.tomcatplugin 
A test/dianhuaben/.project 
A test/dianhuaben/modifytel.jsp 
A test/dianhuaben/WEB-INF 
A test/dianhuaben/WEB-INF/_desktop.ini 
A test/dianhuaben/WEB-INF/lib 
A test/dianhuaben/WEB-INF/src 
A test/dianhuaben/WEB-INF/web.xml 
A test/dianhuaben/WEB-INF/.cvsignore 
A test/dianhuaben/WEB-INF/classes 
A test/dianhuaben/WEB-INF/classes/com 
A test/dianhuaben/WEB-INF/classes/com/Telbook.java 
A test/dianhuaben/WEB-INF/classes/com/Telbook.class 
A test/dianhuaben/WEB-INF/classes/com/DataBaseConnection.java 
A test/dianhuaben/WEB-INF/classes/com/DataBaseConnection.class 
A test/dianhuaben/WEB-INF/classes/com/TelBean.java 
A test/dianhuaben/WEB-INF/classes/com/TelBean.class 
A test/dianhuaben/modifydel1.jsp 
A test/dianhuaben/addtel.jsp 
A test/dianhuaben/modify.html 
A test/dianhuaben/chanxun.jsp 
A test/dianhuaben/addtel.html 
A test/dianhuaben/.classpath 
A test/dianhuaben/deletetel.jsp 
A test/dianhuaben/deltel.jsp 
A test/dianhuaben/selectAllTel.jsp 
A test/dianhuaben/index.html 
A test/dianhuaben/.cvsignore 
取出修订版 1。
2. 发布你的修改给别人,你可以使用Subversion的提交(commit)命令
#./svn commit 项目名或文件名
[root@localhost bin]# ./svn commit test/index.html 
日志信息未改变,或是未指定
a)中断,c)继续,e)编辑
c 
正在发送 test/index.html 
传输文件数据. 
提交后的修订版为 3。
3.状态查询(status)
#./svn status 路径/项目名
L some_dir # svn已经在.svn目录锁定了some_dir 
M bar.c # bar.c的内容已经在本地修改过了
M baz.c # baz.c属性有修改,但没有内容修改
X 3rd_party # 这个目录是外部定义的一部分
? foo.o # svn并没有管理foo.o 
! some_dir # svn管理这个,但它可能丢失或者不完
~ qux # 作为file/dir/link进行了版本控制,但类型已经改变
I .screenrc # svn不管理这个,配置确定要忽略它
A + moved_dir # 包含历史的添加,历史记录了它的来历
M + moved_dir/README # 包含历史的添加,并有了本地修改
D stuff/fish.c # 这个文件预定要删除
A stuff/loot/bloo.h # 这个文件预定要添加
C stuff/loot/lump.c # 这个文件在更新时发生冲突
C stuff/loot/glub.c # 文件在更新时发生属性冲突
R xyz.c # 这个文件预定要被替换
S stuff/squawk # 这个文件已经跳转到了分支
K dog.jpg # 文件在本地锁定;有锁定令牌
O cat.jpg # 文件在版本库被其他用户锁定
B bird.jpg # 文件本地锁定,但锁定发生错误
T fish.jpg # 文件本地锁定,但锁定丢失
4.检查修改的方式是svn diff命令,你可以通过不带参数的svn diff精确的找出你所做的修改
#./svn diff 项目名
root@localhost bin]# ./svn diff test 
Index: test/index.html 
=================================================================== 
--- test/index.html (修订版 2)
+++ test/index.html (工作拷贝)
@@ -1,6 +1,6 @@ 
<html> 
<head> 
- <title>人才库</html> 
+ <title>人才库资料</html> 
<meta context="text/html;charset=UTF-8"> 
</head> 
<body> 
输出的格式为统一区别格式(unified diff format),删除的行前面加一个-,添加的行前面有一个+ 
svn diff命令也打印文件名和打补丁需要的信息,所以你可以通过重定向一个区别文件来生成“补丁”
#./svn diff 项目名 > 文件名
[root@localhost bin]# ./svn diff test > haha 
[root@localhost bin]# ls 
haha svn svndumpfilter svnserve svnversion 
stn.dump svnadmin svnlook svnsync test 
生成一个haha文件
5.添加文件或目录(add)
#./svn add 项目名/新建文件或目录
6.删除文件或目录(delete)
#./svn delete 项目名/删除的文件或目录
svn delete http://ip地址/svn_dir/repository/project_dir 这条命令刚好可以用来删除
7.列出仓库中的项目(list)
svn list --verbose 
#./svn list --verbose file:///home/svnroot/repository/test/ 
[root@localhost bin]# ./svn list --verbose file:///home/svnroot/repository/test/ 
1 root 529 1月 25 14:16 .classpath 
1 root 4 1月 25 14:16 .cvsignore 
1 root 12288 1月 25 14:16 .genggai1.jsp.swp 
1 root 425 1月 25 14:16 .project 
1 root 358 1月 25 14:16 .tomcatplugin 
1 root 1月 25 14:16 WEB-INF/ 
1 root 10 1月 25 14:16 _desktop.ini 
1 root 29269 1月 25 14:16 a.gif 
1 root 1172 1月 25 14:16 chaxun.jsp 
1 root 1245 1月 25 14:16 genggai.jsp 
1 root 1787 1月 25 14:16 genggai1.jsp 
1 root 707 1月 25 14:16 genggai2.jsp 
6 wooin 1月 26 12:10 hehe/ 
4 wooin 1047 1月 26 11:48 index.html 
1 root 3719546 1月 25 14:16 love.mp3 
1 root 3073 1月 25 14:16 rencaiku.txt 
1 root 1243 1月 25 14:16 shanchu.jsp 
1 root 409 1月 25 14:16 shanchu1.jsp 
1 root 1073 1月 25 14:16 tianjia.html 
1 root 813 1月 25 14:16 tianjia.jsp 
1 root 1月 25 14:16 work/ 
//////////////////////////////////////////////////////////////////////// 
subversion的分支与合并
1.建立分支
#cd /usr/local/subversion/bin 
#./svn copy http://192.168.9.53/svn/test http://192.168.9.53/svn/test/mycopy -m "copy a branch" 
2.在分支上工作(导出分支到本地) 
#./svn checkout http://192.168.9.53/svn/test/mycopy mycopy1 
3.合并
#./svn merge -r 15:16 http://192.168.9.53/svn/test/mycopy test