安装
1 | apt-get install libapr1-dev libaprutil1-dev |
依赖解决
1 | An appropriate version of sqlite could not be found. We recommmend |
配置环境1
2echo "export PATH=/usr/local/svnserve/bin:\$PATH" > /etc/profile.d/svn.sh
source /etc/profile.d/svn.sh
查看1
2
3svn --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 | root@sunday:/data/svn/project# ls -l |
配置主服务
1 | vim /data/svn/project/conf/svnserve.conf |
配置帐号密码
1 | vim /data/svn/project/conf/passwd |
配置权限
1 | vim /data/svn/project/conf/ |
临时启动服务
1 | svnserve -d -r /data/svn --pid-file=/var/run/svnserve.pid --log-file=/data/logs/svn/svnserve.log |
开机启动
1 | cat /etc/systemd/system/svnserve.service |
启动服务
1 | systemctl enable svnserve |
Hooks同步
钩子(Hooks)提交后自动同步
1.将WEB目录checkout才能调用hooks post-commit 自动update1
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-commit1
2
3
4
5
6
7
8
9
10
11
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 是上一版本,也可以写具体版本号,这样输出结果是可以提交的)