svn

Svn 版本系统安装

Posted by Sunday on 2018-03-29

安装

1
2
3
4
5
apt-get install libapr1-dev libaprutil1-dev
tar xf subversion-1.8.17.tar.gz
cd subversion-1.8.17
./configure --prefix=/usr/local/svnserve
make && make install

依赖解决

1
2
3
4
5
6
7
8
9
10
11
12
13
An appropriate version of sqlite could not be found.  We recommmend
3.7.15.1, but require at least 3.7.12.
Please either install a newer sqlite on this system
or
get the sqlite 3.7.15.1 amalgamation from:
http://www.sqlite.org/sqlite-amalgamation-3071501.zip
unpack the archive using unzip and rename the resulting
directory to:
/usr/local/src/subversion-1.8.11/sqlite-amalgamation

解决:
http://www.sqlite.org/sqlite-amalgamation-3071501.zip
mv sqlite-amalgamation-3071501 sqlite-amalgamation

配置环境

1
2
echo "export PATH=/usr/local/svnserve/bin:\$PATH"  > /etc/profile.d/svn.sh
source /etc/profile.d/svn.sh

查看

1
2
3
svn --version
svn, version 1.8.17 (r1770682)
compiled Apr 15 2017, 19:20:26 on x86_64-unknown-linux-gnu


配置

创建目录

1
mkdir -p /data/svn

创建版本库

1
svnadmin creata /data/svn/project

创建目录会生成

1
2
3
4
5
6
7
8
9
10
11
12
root@sunday:/data/svn/project# ls -l
total 24
drwxr-xr-x 2 root root 4096 Apr 15 22:51 conf
drwxr-sr-x 6 root root 4096 Apr 15 22:02 db
-r--r--r-- 1 root root 2 Apr 15 19:38 format
drwxr-xr-x 2 root root 4096 Apr 15 23:09 hooks
drwxr-xr-x 2 root root 4096 Apr 15 19:38 locks

root@sunday:/data/svn/project# ls -l conf
-rw-r--r-- 1 root root 1144 Apr 15 22:51 authz #权限
-rw-r--r-- 1 root root 348 Apr 15 21:47 passwd #帐号密码
-rw-r--r-- 1 root root 3994 Apr 15 22:51 svnserve.conf #主服务配置

配置主服务

1
2
3
4
5
vim /data/svn/project/conf/svnserve.conf
anon-access = none #非鉴权用户不允许匿名访问
auth-access = write #鉴权用户允许写入
password-db = passwd #指定用户名口令文件名。除非指定绝对路径,否则文件位置为相对路径
authz-db = authz #指定权限配置文件名,同上,默认也为相对路径

配置帐号密码

1
2
3
4
5
vim /data/svn/project/conf/passwd
[users] #帐号 = 密码
seven = seven
sunday = sunday
tao = tao

配置权限

1
2
3
4
5
6
7
8
9
vim /data/svn/project/conf/

admin = seven #定义组
user = sunday,tao

[/]
@admin = rw #引用组
@user = r
* =

临时启动服务

1
svnserve -d -r /data/svn --pid-file=/var/run/svnserve.pid --log-file=/data/logs/svn/svnserve.log

开机启动

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
cat /etc/systemd/system/svnserve.service 

[Unit]
Description=Subversion protocol daemon
After=syslog.target network.target

[Service]
Type=forking
ExecStart=/usr/local/svnserve/bin/svnserve -d -r /data/svn --log-file=/data/logs/svn/svnserve.log --pid-file=/var/run/svnserve.pid
ExecReload=/bin/kill -HUP $MAINPID
KillMode=process
Restart=on-failure

[Install]
WantedBy=multi-user.tar

启动服务

1
2
systemctl enable svnserve
systemctl start svnserve

Hooks同步

钩子(Hooks)提交后自动同步

1.将WEB目录checkout才能调用hooks post-commit 自动update

1
svn co svn://192.168.10.20/project /data/web/demo.sundayhk.com --username=xxx

2.配置Hooks

cd /data/svn/project/hooks
cp post-commit.tmpl post-commit
chmod +x post-commit
vim post-commit

1
2
3
4
5
6
7
8
9
10
11
#!/bin/sh
REPOS="$1"
REV="$2"
TXN_NAME="$3"
WEB=/data/web/demo.sundayhk.com #放代码路径
LOG=/data/logs/svn/sundayhk.com_update.log #日志
export LANG=en_US.UTF-8
#svn update 同步到 web目录
/usr/local/svnserve/bin/svn update --accept theirs-conflict --username xxx --password xxx $WEB >> $LOG 2>&1
chown -R www:www $WEB #修改文件用户,默认同步文件用户为root
#chmod -R www:www $WEB


SVN命令

1、将服务器版本库文件提取到本地目录
svn checkout svn://192.168.10.20/project
简写:svn co

2、往版本库中添加新的文件
svn add test.php #添加test.php
svn add *.php #添加当前目录下所有的php文件
ps:将新的文件预定添加到版本库中(svn add并没提交到服务器,需要svn up才会提交),前提是版本库中没有这个文件,这个文件必须是新的。

3、将改动的文件提交到版本库
svn commit -m “add test file for my test” test.php
简写:svn ci file -m “注释信息”

4、加锁/解锁
svn lock -m “lock test file” test.php
svn unlock PATH

5、更新到某个版本
svn update -r 200 test.php 将版本库中的文件test.php还原到版本200
svn update 如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
svn update test.php 更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit

6、查看文件或者目录状态
1)svn status path(目录下的文件和子目录的状态,正常状态不显示)
【?:未提交;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
2)svn status -v path(显示文件和子目录状态)
第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
简写:svn st

7、svn delete svn://192.168.10.20/project/test.php -m “delete test file”
或者直接svn delete test.php 然后再svn ci -m ‘delete test file‘,推荐使用这种svn diff -r 200:201 path 对比

8、查看日志
svn log test.php 显示这个文件的所有修改记录,及其版本号的变化

9、查看文件详细信息
svn info test.php

10、比较差异
svn diff test.php 将修改的文件与基础版本比较
svn diff -r 200:201 test.php 对版本200和版本201比较差异
简写:svn di

11、将两个版本之间的差异合并到当前文件
svn merge -r 200:205 test.php 将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下

12、SVN 帮助
svn help
svn help ci

13、版本库下的文件和目录列表
svn list path
显示path目录下的所有属于版本库的文件和目录
简写:svn ls

14、恢复本地修改
svn revert: 恢复原始未改变的工作副本文件 (恢复大部份的本地修改)。
用法: revert PATH…
注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复被删除的目录

16、解决冲突
svn resolved: 移除工作副本的目录或文件的“冲突”状态。
用法: resolved PATH…
注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的相关文件,然后让 PATH 可以再次提交。

18、输出指定文件或URL的内容。
svn cat 目标[@版本]…如果指定了版本,将从指定的版本开始查找。
svn cat -r PREV filename > filename (PREV 是上一版本,也可以写具体版本号,这样输出结果是可以提交的)

svnserve详细使用