系统:ubuntu
安装svn。
rot@rot-virtual-machine:/$ sudo apt-get install subversion
2. 建立svn仓库。svn存储上传文件版本数据的地方。
rot@rot-virtual-machine:/$ sudo mkdir /home/.svn #(使用隐藏文件夹)
rot@rot-virtual-machine:/$ cd /home/.svn
rot@rot-virtual-machine:/home/.svn$ mkdir pythonapp
rot@rot-virtual-machine:/home/.svn$ svnadmin create /home/.svn/pythonapp
rot@rot-virtual-machine:/home/.svn$ cd pythonapp
rot@rot-virtual-machine:/home/.svn/pythonapp$ ll #如果创建成功,会发现很多相关文件
3. 配置和管理svn。
rot@rot-virtual-machine:/home/.svn/pythonapp$ cd conf
rot@rot-virtual-machine:/home/.svn/pythonapp/conf$ vim svnserve.conf
1). 每个仓库的配置文件在$repos/conf/下,vi svnserve.conf,配置项在[general]下:
anon-access:匿名用户的权限,可以为read,write和none,默认值read。不允许匿名用户访问:anon-access = none
auth-access:认证用户的权限,可以为read,write和none,默认值write。
password-db:密码数据库的路径,去掉前边的#默认是passwd,那么就指的是当前目录下的passwd文件
authz-db:认证规则库的路径,去掉前边的#。
注意:这些配置项的行都要顶格,否则会报错。修改配置后需要重启svn才能生效。
2). 配置passwd文件
这是每个用户的密码文件,比较简单,就是“用户名=密码”,采用的是明码。如allen=111111
3). 配置authz文件
1. [groups] section:为了便于管理,可以将一些用户放到一个组里边,比如:owner=allen,ellen
2. groups下边的sections表示对一个目录的认证规则,比如对根目录的认证规则的section为[/]。设置单用户的认证规则时一个用户一行,如:
[/]
allen=rw #allen对根目录的权限为rw
ellen=r #ellen对根目录的权限为r
如果使用group,需要在group名字前加@,如
@owner=rw #group owner中的用户均为rw,等价于上边的两句话
启动时如果从/home/.svn/astar启动,/就是astar目录,用如上方式以astar目录为根设置权限。
如果从/home/.svn/启动,每个仓库根还是自己的起始目录。可以采用如上方式设置astar的权限,也可以采用如下方式:
[astar:/]
@owner=rw
设置test的权限如下:
[test:/]
@harry_and_sally = rw
简言之,每个仓库的根目录(/)就是自己的起始目录;[repos:/]这种方式只适用于多仓库的情况;[/]适合于单仓库和单仓库的方式。
4). 不能跨越仓库设置权限。
4. 启动和停止svn
1). 启动:
1. 从astar目录启动,svnserve -d -r /home/.svn/pythonapp,根目录(/)是pythonapp,authz中规则的配置使用section[/]。访问方式为:
svn://192.168.0.87/
2. 从.svn目录启动,svnserve -d -r /home/.svn,根目录(/)是.svn,authz中对astar的配置使用section[pythonapp:/] 访问方式为:
svn://192.18.0.87/pythonapp
如果需要svn自启动,把命令加入/etc/rc.local中
2). 检查svn服务器是否已经启动(svn默认使用3690端口):netstat -an | grep 3690
3). 停止:killall svnserve
4). 加入自启动 。
在/etc/rc.d/rc.local文件中增加这么一行
svnserve -d -r /home/.svn/pythonapp &
5. svn客户端使用。(windows)
1. 下载安装svn客户端。
2. checkout,填写服务端url svn://192.168.118.130
报错了:Unable to connect to a repository at URL 'svn://192.168.118.130'
1. 先看服务端,svn服务是否启动。ps -ef | grep svn,也可以在浏览器访问http://192.168.118.130:3690
2. 仔细核对配置文件是否有问题。
3. authz 中用户的权限设置有问题。
修改完,重新checkout之前记得先清理一下本地缓存:
3. 文件上没有svn绿色对号的图标。
本地创建文件,就可以提交了。
那么问题来了,如果我想使用这些代码呢?要知道svn提交以后,在服务端svn目录里面是找不到源码的,它对提交的源码进行了处理。
1. 先在服务器上checkout 出来一份代码。
# svn://192.168.118.130 svn地址
# /home/rot/pythonapp/dffyb/app/ 代码工作目录
rot@rot-virtual-machine:/$ svn co svn://192.168.118.130 /home/rot/pythonapp/dffyb/app/ --username rot
2. svn钩子的使用。
rot@rot-virtual-machine:/home/.svn/pythonapp/hooks$ ll
# 各种钩子的模版文件
# start-commit.tmpl 提交前触发事务
# pre-commit.tmpl 提交完成前触发事务
# post-commit.tmpl 提交完成时触发事务
# pre-revprop-change.tmpl 版本属性修改前触发事务
# post-revprop-change.tmpl 版本属性修改后触发事务
rot@rot-virtual-machine:/home/.svn/pythonapp/hooks$ sudo cp post-commit.tmpl post-commit
rot@rot-virtual-machine:/home/.svn/pythonapp/hooks$ vim post-commit
# 加入一下代码
REPOS="$1"
REV="$2"
SVN_PATH=/usr/bin/svn
WEB_PATH=/home/rot/pythonapp/dffyb/app
SVN_USER=rot
SVN_PASS=svn123
WEB_USER=rot
LOG_PATH=/tmp/svn.log
echo `date "+%Y-%m-%d %H:%M:%S"` >> $LOG_PATH
echo `whoami`,$REPOS,$REV >> $LOG_PATH
$SVN_PATH update $WEB_PATH --username $SVN_USER --password $SVN_PASS --no-auth-cache >> $LOG_PATH
chown $WEB_USER.$WEB_USER -R $WEB_PATH
# 在客户端添加一个文件,手动执行一下脚本,看有没bug
rot@rot-virtual-machine:/home/.svn/pythonapp/hooks$ sudo ./post-commit
rot@rot-virtual-machine:/home/.svn/pythonapp/hooks$cd /home/rot/pythonapp/dffyb/app
#没错误的话,这样就可以看到新上传的文件了。