centos7 搭建svn服务器&客户端的访问&备份迁移
当今用于版本控制的软件程序主要的有svn和git,其它软件咱不熟悉,今天记录下搭建svn服务器和svn客户端使用;
使用环境:
虚拟机为centos7系统,svn服务器安装在centos7系统平台上,svn客户端分别在windows7和centos7系统上使用;
1、安装svn服务器:
]# yum install subversion
2、配置svn服务器:
建立svn版本库根目录及相关目录即svndata及密码权限命令svnpasswd;
]# mkdir -p /application/{svndata,svnpasswd}
svndata目录:作为存放svn的根目录;
svnpasswd目录:作为存放登录svn的用户和密码;
3、启动svn服务:
]# svnserve -d -r /application/svndata/
参数:
-d:表示后台运行守护模式;
-r:表示svn服务的根目录;
检测svn端口3690是否已经监听:
netstat -lntup | grep 3690
4、建立版本库:
在/application/svndata/目录下,创建项目sadoc:
]# svnadmin create /application/svndata/sadoc
会自动创建出一系列固定的目录:
]# tree /application/svndata/sadoc
/application/svndata/sadoc
├── conf
│ ├── authz
│ ├── passwd
│ └── svnserve.conf
├── db
│ ├── current
│ ├── format
│ ├── fsfs.conf
│ ├── fs-type
│ ├── min-unpacked-rev
│ ├── revprops
│ │ └── 0
│ │ └── 0
│ ├── revs
│ │ └── 0
│ │ └── 0
│ ├── transactions
│ ├── txn-current
│ ├── txn-current-lock
│ ├── txn-protorevs
│ ├── uuid
│ └── write-lock
├── format
├── hooks
│ ├── post-commit.tmpl
│ ├── post-lock.tmpl
│ ├── post-revprop-change.tmpl
│ ├── post-unlock.tmpl
│ ├── pre-commit.tmpl
│ ├── pre-lock.tmpl
│ ├── pre-revprop-change.tmpl
│ ├── pre-unlock.tmpl
│ └── start-commit.tmpl
├── locks
│ ├── db.lock
│ └── db-logs.lock
└── README.txt
主要目录说明:
conf目录:主要是配置文件、登录用户、密码认证;
hooks目录:主要是svn的钩子脚本模板,使用时去掉.tmpl后缀即可,钩子脚本实际上就是代码提交前后,可以分别执行的脚本,脚本可用perl、shell、python等语言编写,该目录里面脚本文件名代表提交代码执行的不同时机,如提交代码前执行的脚本pre-commit,提交代码后执行的脚本post-commit,更多详情自行学习;
5、修改配置文件:
]# vim /application/svndata/sadoc/conf/svnserve.conf
anon-access = none
#不允许匿名访问,read为允许匿名访问;
auth-access = write
#允许可写;
password-db = /application/svnpasswd/passwd
#密码数据库
authz-db = /application/svnpasswd/authz
#控制权限数据库
注意:配置文件必须顶格写;
把用户和密码文件放到自定义的目录中:
]# cp authz passwd /application/svnpasswd/
改权限:
]# chmod 700 /application/svnpasswd/*
配置passwd文件:
[users]
oldboy = oldboysecret
test = testsecret
test1 = test1secret
passwd配置文件说明:
格式为:svn账号=svn密码
账号和密码可随意指定;
配置authz:
[groups]
#定义组信息,注意:用户账号在passwd里;
ett_sa = oldboy,test1
ett_wangguan = test
[sadoc:/]
@ett_sa = rw
@ett_wangguan = r
test = r
authz配置文件说明:
1.权限配置文件中出现的用户必须已经在用户配置文件中定义;
2.对权限配置文件的修改立即生效,不必重启svn;
3.一个用户组可包含多个用户,用户间用逗号分隔;
4.版本库目录格式:
[<版本库>://项目目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方括号内部分可有多种写法:
[/]:表示根目录及以下,根目录是svnserve启动时指定的,[/]表示对全部版本库设置权限;
[repos:/]:表示对版本库repos设置权限;
[repos:/sadoc]:表示对版本库repos中的sadoc项目设置权限;
[repos:/sadoc/oldboy]:表示对版本库repos中的sadoc项目的oldboy目录设置权限;
权限主体可以是用户、用户组或*,用户组在前面加@,*表示全部用户;
权限可以是w、r、wr和空,空表示没有任何权限;
authz中每个参数都要顶格写,开头不能有空格;
对于组,要以@开头,而用户不需要;
6、重启svn服务:
]# pkill svnserve
]# svnserve -d -r /application/svndata/
注意:
更改svnserve.conf需要重启svn,更改authz、passwd文件时不需要重启;
检查3690端口是否处于监听状态,至此svn服务器搭建完成;下面是svn客户端的安装与使用;
分别说明在windows平台和centos7平台上的svn客户端安装和使用:
svn客户端访问方式:
subversion可通过多种方式访问--本地磁盘服务,或各种各样不同的网络协议,但一个版本库地址永远都是一个url,url方案反映了访问方法;
1.file:// 直接版本库服务(本地磁盘或访问方法;
2. http:// 通过webdav协议服务支持subversion的apache服务器;
3.https:// 与http://相似,但是用ssl加密;
4.svn:// 通过未认证的tcp/ip自定义协议访问svnserve服务器;
5. svn+ssh:// 通过认证并加密的tcp/ip自定义协议访问svnserve服务器;
1、windows平台:
下载svn客户端安装即可,都是鼠标操作,比较容易;
主要说明后续的使用步骤:
1.在本地创建svn目录:如创建svn-test目录;
2.在该目录上右击,选择SVN Checkout:
然后,根据弹框,填写svn服务器地址、用户名等信息;首次使用svn用checkout,会要求输入用户名和密码;
保存认证信息在缺省目录:%APPDATA%\Subversion\auth目录下,在运行cmd窗口输入:
%APPDATA%\Subversion\auth即可,
即C:\Users\sshss\AppData\Roaming\Subversion\auth

该目录上右击: 
继续操作:
点击ok
这样即可完成
3.在创建的目录里,编写代码,然后在该目录右击,选择SVN Commit提交代码即可
4.如果要拉取,svn服务器上的代码,右击该目录,选择SVN Update即可;
具体功能,自行学习下,点击鼠标就行了;
2、centos7平台:
主要步骤即svn命令说明:
1.导入svn原始目录:
先创建svn目录:
]# mkdir /data/oldboy -p
在其目录下,创建3个目录:
]# cd /data/oldboy; mkdir trunk branch tags -p
导入:
]# svn import /data/oldboy svn://192.168.255.12/sadoc/ -m "import tree"
2.从svn库提取数据:
]# mkdir /data/test
]# svn checkout svn://192.168.255.12/sadoc /data/test --username oldboy --password oldboysecret
或简写:
]# svn co svn://192.168.255.12/sadoc /data/test --username=oldboy --password=oldboysecret
或:
]# svn co file:///application/svndata/sadoc /data/test --username=oldboy --password=oldboysecret
注意:首次使用svn用checkout;后面再用提取数据不用再使用用户名和密码:
3.查看svn中的数据:
]# svn list --verbose svn://192.168.255.12/sadoc
或:
]# svn ls --verbose svn://192.168.255.12/sadoc
]# svn cat svn://192.168.255.12/sadoc/trunk/test1.txt
4.向svn中提交数据:
]# touch /data/test/trunk/test2.txt
]# svn add /data/test/trunk/test2.txt
]# svn ci -m "test2.txt" /data/test/trunk/test2.txt
ci简称:commit;
co简称:checkout;
注意:提交时,先add,再commit;
5.svn钩子脚本使用(仅演示一个)
仅演示post-commit脚本使用:
]# vim /application/svndata/sadoc/hooks/post-commit
注释掉默认执行语句,添加:
touch /tmp/$(date +%F).log
添加执行权限:
]# chmod 755 post-commit
在windows客户端上,修改数据后执行commit,在linux命令行上查看,是否执行了该钩子脚本;
即在/tmp目录下创建了一个以时间命名的.log文件;
注意:
1、钩子脚本的权限要允许svn执行,一般设为chmod 755 post-commit;
2、写钩子脚本时,尽可能定义变量,主要是用过的命令的路径,因为svn考虑安全问题,不会调用系统环境变量;
3、在svn update之前,一定要先手动checkout一份出来,还有这里一定要加上用户和密码;
下面再讲讲我怎么备份svn然后迁移的,也是centos7的版本
1.svn备份 svn备份方式对比分析 一般采用三种方式:
- svnadmin dump
- svnadmin hotcopy
- svnsync 这三种方式各有优缺点,我就不讲了.虽然官方推荐用第一种,但我用的是第二种,为什么用第二种?因为简单,快速
- 源服务器上用命令用 svnadmin hotcopy
- 我的目录是: /opt/svn/test
- test就是项目文件夹
[root@svn-test test]# ls conf db format hooks locks README.txt
[root@svn-test test]# cd ..
[root@svn-test svn]# svnadmin hotcopy test backupSvn
备份OK了!
压缩一下 tar -zcvf backupSvn.tar.gz backupSvn
因为是同网段的局域网,所以直接把备份好的压缩包传到目标机器上如下:scp /opt/svn/test/conf/svnserve.conf @172.23.100.23:/opt/svn/test/conf/
进入目标机器后解压 tar -zxvf backupSvn.tar.gz
把解压后的文件夹名改成与目标机器备份的项目文件名同名,我的项目文件名是test,如下: mv backupSvn test
赋予权限: chmod -R o+rw /opt/svn/test
优缺点分析:
第一种 svnadmin dump是官方推荐的备份方式,优点是比较灵活,可以全量备份也可以增量备份,并提供了版本恢复机制。
缺点是:如果版本比较大,如版本数增长到数万、数十万,那么dump的过程将非常慢;备份耗时,恢复更耗时;不利于快速进行灾难恢复。
个人建议在版本数比较小的情况下使用这种备份方式。
第二种 svnadmin hotcopy原设计目的估计不是用来备份的,只能进行全量拷贝,不能进行增量备份;
优点是:备份过程较快,灾难恢复也很快;如果备份机上已经搭建了svn服务,甚至不需要恢复,只需要进行简单配置即可切换到备份库上工作。
缺点是:比较耗费硬盘,需要有较大的硬盘支持(俺的备份机有1TB空间,呵呵)。
第三种 svnsync实际上是制作2个镜像库,当一个坏了的时候,可以迅速切换到另一个。不过,必须svn1.4版本以上才支持这个功能。
优点是:当制作成2个镜像库的时候起到双机实时备份的作用;
缺点是:当作为2个镜像库使用时,没办法做到“想完全抛弃今天的修改恢复到昨晚的样子”;而当作为普通备份机制每日备份时,操作又较前2种方法麻烦。
svnadmin dump方式
SVN迁移需要做如下操作:
1. 将原来的Repository导出为一个文件dumpfile 。
#svnadmin dump 原先的repos的目录路径(/repository/directory) > dumpfile
#svnadmin dump /opt/svn/iitshare/ > /var/tmp/iitshare_20130626
2. 在另外一台机器上配置同样的SVN服务器。
参考:linux SVN安装及配置图解教程
3. 将dumpfile导入到新的repository 目录中。
#svnadmin load 新建的repos的目录路径(/repository/directory) < dumpfile
#svnadmin load /opt/svn/iitshare/ < /var/tmp/iitshare_20130626
4. 将原先服务器的配置文件备份后复制到新服务器中
#/opt/svn/iitshare/conf目录下
authz、passwd、svnserve.conf文件
svnadmin hotcopy方法
1. 备份
#svnadmin hotcopy /opt/svn/iitshare/ /var/tmp/iitshare_20130626 –clean-logs
如果你传递–clean-logs选项,svnadmin会执行热拷贝操作,然后删除不用的Berkeley DB日志文件。
你可以在任何时候运行这个命令得到一个版本库的安全拷贝,不管其它进程是否使用这个版本库。
2. 还原
#svnadmin hotcopy /var/tmp/iitshare_20130626 /opt/svn/iitshare/
centos7 搭建svn服务器&客户端的访问&备份迁移的更多相关文章
- centos7搭建svn服务器及客户端设置
centos7搭建svn服务器及客户端设置 centos7貌似预装了svn服务(有待确认),因此我们直接启动该服务即可 一.svn服务端配置(服务器IP假设为192.168.100.1) 步骤1:创建 ...
- CentOS7 搭建 SVN 服务器
CentOS7 搭建 SVN 服务器 介绍SVN: SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS.CVS,它采用了分支管理系统,它的设计目标就是取代CVS.互联网上 ...
- ubuntu搭建svn服务器并htpp访问版本库并svn与web同步
Ubuntu搭建SVN服务器多版本库 1 介绍 Subversion是一个自由,开源的版本控制系统,这个版本库就像一个普通的文件服务器,不同的是,它可以记录每一次文件和目录的修改情况.这样就可 ...
- CentOS搭建svn服务器支持https访问
在CentOS6.3 64位机器上配置SVN服务器,并设置只允许HTTPS连接,可以配置多个repos源,每个源都拥有自己的组和成员,用于权限控制. 安装相关软件 Apache yum install ...
- centos7搭建svn服务器并支持http方式访问
因为公司其他人员需要,需要在服务器上搭建svn服务,途中遇到不少问题,做下记录 第一步,安装svn 默认centos7是已经安装了svn即subversion 检查是否安装 rpm -qa subve ...
- centos7 搭建svn服务器
1.安装svn服务器: yum install subversion 2.配置svn服务器: 建立svn版本库根目录及相关目录即svndata及密码权限命令svnpasswd: mkdir -p /a ...
- Aliyun搭建svn服务器外网访问报错权限配置失败错误
搭建完后所有的配置如下 [root@iZuf655czz7lmtn8v15tsjZ conf]# pwd /home/SVN/conf [root@iZuf655czz7lmtn8v15tsjZ co ...
- CentOS7搭建SVN服务器
首先,你得有个VPS,我用的是搬瓦工. 安装步骤如下:1.yum install subversion2.查看安装版本 svnserve --version 3.创建SVN版本库目录 mkdir ...
- centos7下SVN服务器如何搭建
Centos7 搭建svn服务器 linux(centos)下SVN服务器如何搭建?说到SVN服务器,想必大家都知道,可以是在LINUX下如何搭建SVN服务器呢?那么今天给大家分享一下linux(ce ...
随机推荐
- (2.3)DDL增强功能-流程化控制与动态sql
1.流程控制 在T-SQL中,与流程控制语句相关的关键字有8个: BEGIN...END BREAK GOTO CONTINUE IF...ELSE WHILE RETURN WAITFOR 其实还可 ...
- centos Linux系统日常管理2 tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课
centos Linux系统日常管理2 tcpdump,tshark,selinux,strings命令, iptables ,crontab,TCP,UDP,ICMP,FTP网络知识 第十五节课 ...
- Java8新特性(转载)
1.Lambda表达式 Lambda表达式(也称为闭包)是整个Java 8发行版中最受期待的在Java语言层面上的改变.使用 Lambda 表达式可以使代码变的更加简洁紧凑. Lambda允许把函数作 ...
- Openstack(十三)部署管理服务horizon
13.1horizon介绍 horizon是openstack的管理其他组件的图形显示和操作界面,通过API和其他服务进行通讯,如镜像服务.计算服务和网络服务等结合使用,horizon基于python ...
- java8工具类使用
1:map的使用 computeIfPresent ,如果键已经存在,将键和值作为参数传到函数式中,计算返回新的值 import java.util.HashMap; import java.util ...
- adb shell top 命令
原文地址https://blog.csdn.net/kittyboy0001/article/details/38562515 原文地址https://blog.csdn.net/u010503912 ...
- Django组件补充(缓存,信号,序列化)
Django组件补充(缓存,信号,序列化) Django的缓存机制 1.1 缓存介绍 1.缓存的简介 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增,删,查,改,渲染模板,执行业务逻辑 ...
- SQL Server 一些使用小技巧
1.查询的时候把某一个字段的值拼接成字符串 以下是演示数据. 第一种方式:使用自定义变量 ) SET @Names='' -- 需要先赋值为空字符串,不然结果会是 null SELECT @Names ...
- Python: 字符串格式化format()函数的使用
python从2.6开始支持format,新的更加容易读懂的字符串格式化方法,从原来的% 模式变成新的可读性更强的 花括号声明{}.用于渲染前的参数引用声明, 花括号里可以用数字代表引用参数的序号, ...
- RedHot 不能联网 ifconfig命令只显示lo 不显示eth0的解决方法!
1.修改eth0 具体步骤如下 vi /etc/sysconfig/network-scripts/ifcfg-eth0, i,进入insert编辑模式,具体参数设置如下: DEVICE=eth0 B ...