SVN库实时同步设置

为了安全起见,SVN服务器除了做定时全量备份和增量备份以外,如条件允许,可做实时备份。

这需要2台机器,一台是master server,另一台做mirror server。master做主服务,mirror不对外服务或设置只读(除了同步账号可写外)

另外如果master负载比较高,可以把一些只读的应用设置为从mirror读取,例如Jenkins编译。(需保证实时同步一直工作)

步骤如下(这里以linux sever为例):

加下面代码段到pre-revprop-change以允许svnsync改写svn库属性:

if [ "$USER" = "svnsync" ]; then exit 0; fi

echo "Only the svnsync user can change revprops" >&2

SVN实时备份脚本,替换repo目录下的hook/post-commit,需服务器有python支持

#!/usr/bin/python

#coding=utf-8

import os

import commands

import sys

import logging

def init_log(log_level,logpath):

logger = logging.getLogger()

‘‘‘

from logging.handlers import RotatingFileHandler

ro_hdlr=RotatingFileHandler(logpath, maxBytes=0,backupCount=5)

logger.addHandler(ro_hdlr)

ro_hdlr.doRollover()

‘‘‘

hdlr = logging.FileHandler(logpath)

formatter = logging.Formatter(‘%(asctime)s [%(levelname)-8s %(module)s:%(lineno)d] %(message)s‘)

hdlr.setFormatter(formatter)

logger.addHandler(hdlr)

logger.setLevel(log_level)

return logger

repos=os.path.basename(sys.argv[1])

log=init_log(0,‘/data/svnsynclog/‘ + repos + ‘_sync.log‘)

log.info("*"*20+repos)

output=commands.getoutput(‘/usr/bin/svnsync sync --non-interactive --username svnsync --password svnsync http://10.0.80.21/svn/‘+repos)

log.info(‘sync log :‘+output)

设置svnsync账号有master上的读取权限,mirror上的读写权限

然后提交一些变更测试一下,是否能实时同步过去。同步的日志放在/data/svnsynclog(设置成自己的目录)

OK, 完成。

手工从master到mirror的同步命令:

svnsync init --username svnsync http://10.0.80.21/svn/test http://10.0.80.20/svn/test

svnsync sync --username svnsync http://10.0.80.21/svn/test

时间: 2024-10-13 20:25:26

SVN库实时同步设置的相关文章

使用svn钩子脚本控制svn库的实时备份

Svn镜像库实时同步实现 一, 配置rsync的同步机制先实现能手动同步 环境:svn源码库 192.168.115.120 Svn镜像库 192.168.115.121 1,在源码库中配置rsync服务 (配置文件默认没有需要手动建立 /etc/rsyncd.cong) 上面 [ UGOR]就是要更新的模块,然后启动服务 rsync –deamo查看服务状态lsof –I 873 注:认证账户格式为 用户:密码,文件权限为 600, (rsync.pass) 2,在镜像库中同步内容执行 rsy

搭建两个实时同步的SVN服务器

服务器系统版本:# cat /etc/redhat-release CentOS release 6.4 (Final) 结构:SVN服务器1 主库IP 192.168.16.201SVN服务器2 从库IP 192.168.16.202 搭建目标:在SVN服务器1上执行svn ci操作,SVN服务器2上的版本库会同步更新. 说明: 本文只涉及到搭建简单的SVN服务器,并不涉及配置Apache的高级配置以及SVN结合LDAP认证登陆.1.搭建两个SVN服务器###在这一部分,如无特殊说明,所有操作

svn库两地开发之代码数据的同步包括vpn连接的全套解决方案

应用环境:在北京的svn服务器提供代码归档服务为开发和本地的持续集成编译测试环境,成都开发人员每个人都需要vpn连接并且不稳定.后来成都部署了本地持续集成环境换取代码,从北京同步完全不现实.触使了成都本地同步北京代码的必要性. 实现方式: 1.首先想到的是使用svn的镜像同步工具来同步即svnsync.但是通过这个方式同步数据,第一同步时不能有代码的提交,同步起来速度比较慢.后续同步(使用hook用北京的提交触同步命令)也很容易出现文件被锁的情况. 2.第二种方式使用linux的rsync的工具

基于OGG的Oracle与Hadoop集群准实时同步介绍

Oracle里存储的结构化数据导出到Hadoop体系做离线计算是一种常见数据处置手段.近期有场景需要做Oracle到Hadoop体系的实时导入,这里以此案例做以介绍.Oracle作为商业化的数据库解决方案,自发性的获取数据库事务日志等比较困难,故选择官方提供的同步工具OGG(Oracle GoldenGate)来解决. 安装与基本配置 环境说明 软件配置 角色 数据存储服务及版本 OGG版本 IP 源服务器 OracleRelease11.2.0.1 Oracle GoldenGate 11.2

rsync结合inotify实现实时同步

背景介绍 中小企业的web应用场景中,web服务器可能是由2台服务器组成,通过DNS的轮询作为负载均衡,此时就需要对2台服务器之间同步的实时性有较高的要求,上一篇文章所介绍的rsync+crontab就不能满足此需求,本章就来介绍使用rsync+inotify完成服务器之间的实时同步 实验说明 操作系统:CentOS6.8,inotify要求内核版本必须为2.6.13以上 源服务器:172.16.10.10/24 目标服务器:172.16.10.20/24 实验目的:将源服务器上的/rsync目

烂泥:rsync与inotify集成实现数据实时同步更新

本文首发于烂泥行天下. 上篇文章我们介绍了如何使用rsync同步文件,这篇文章我们再来介绍下,如何把rsync与inotify集成实现数据的实时同步. 要达到这个目的,我们需要分以下几个步骤: 1.rsync的优点与不足 2.inotify是什么 3.检测OS是否支持inotify 4.inotify相关参数详解 5.inotify监控的文件事件类似 6.inotify-tools是什么 7.安装inotify-tools 8.inotifywait使用详解 9.inotifywatch使用详解

企业实时同步方案----Rsync+Sersync

在博文企业实时同步方案----Sersync介绍中我们详细介绍了Sersync的原理,设计架构以及和 Inotify 等等的优势区别.这里我就带大家一起来做一下 Rsync +Sersync 这个同步分发架构案例. 实验环境介绍: 内核版本:2.6.32-431.el6.x86_64 系统采用最小化安装,系统经过了基本优化,selinux为关闭状态,iptables为无限制模式 源码包存放位置:/root Rsync客户端+Sersync服务器(SERSYNC),承担角色MASTER,IP:17

rsync+inotify实现实时同步

1.数据同步: A服务器的一个目录同步到B服务器上的一个目录 方法是: 可以在A服务器上把这个目录共享(如ftp,http等),然后B服务器上写shell脚本,用crontab做定时任务下载过来(数据同步不实时) 实时同步 方法是: rsync远程目录实时同步 drbd远程存储实时同步(很老的方案) 共享存储,就是同一个磁盘设备同时被很多人用 分布式存储(云存储) 2.同步.异步和远程同步 sync同步 async异步 rsync 远程同步 这里主要说rsync,在开始之前需要了解以下几个问题:

lsyncd 实时同步

1. 几大实时同步工具比较 1.1 inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify + rsync,但随着文件数量的增大到100W+,目录下的文件列表就达20M,在网络状况不佳或者限速的情况下,变更的文件可能10来个才几M,却因此要发送的文件列表就达20M,严重减低的带宽的使用效率以及同步效率:更为要紧的是,加入inotifywait在5s内监控到10个小文件发生变化,便会触发10个rsync同步操作,结果就是真正需要传输的才2-3M的文