linux服务器下搭建svn

系统:ubuntu

  1. 安装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之前记得先清理一下本地缓存:

linux服务器下搭建svn_第1张图片

    3. 文件上没有svn绿色对号的图标。

linux服务器下搭建svn_第2张图片

本地创建文件,就可以提交了。

那么问题来了,如果我想使用这些代码呢?要知道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
#没错误的话,这样就可以看到新上传的文件了。



你可能感兴趣的:(linux服务器下搭建svn)