一键备份gitolite服务器的Shell脚本
2014-09-01 00:00
1021 查看
运行一次就能够把gitolite服务器上的仓库备份到本地. 第一次运行会创建远程仓库的本地镜像, 以后每次运行会把本地镜像更新.
本程序只支持 ssh方式
其他的git server貌似不会在 ssh git@xxx 的时候返回repo列表, 所以只能手动备份.
本程序只支持 ssh方式
其他的git server貌似不会在 ssh git@xxx 的时候返回repo列表, 所以只能手动备份.
#!/bin/sh server=serv_addr root_dir=`pwd` echo "whill back in dir: ${root_dir}" ssh "git@${server}" | awk '{print $1$2,$3}' | grep "^RW" | awk '{print $2}' | while read line do echo " " echo "-------------------------------------" if [ ! -d "${root_dir}/${line}.git" ]; then echo "repo not init on local, init it ..." mkdir -p "${root_dir}/${line}.git" cd "${root_dir}/${line}.git" cd .. git clone --mirror "git@${server}:${line}.git" else echo "repo already init on local, update it ..." cd "${root_dir}/${line}.git" git remote update git gc fi done
相关文章推荐
- 一键备份gitolite服务器的Shell脚本
- 服务器数据备份(shell 定时脚本备份mysql)
- 服务器数据备份(shell 定时脚本备份mysql)
- 备份远程服务器文件简单shell脚本
- Git学习-->如何通过Shell脚本自动定时将Gitlab备份文件复制到远程服务器?
- 在线备份MySQL及远程copy到远程备份服务器shell脚本
- 利用shell脚本,crontab,scp实现将一台服务器的目录备份到另一台服务器
- 两台服务器之间备份目录或文件的shell脚本
- shell脚本备份mysql里面所有数据库到远程服务器
- shell脚本备份本地服务器的文件到远程服务器
- ]利用shell脚本,crontab,scp实现将一台服务器的目录备份到另一台服务器
- Shell脚本分享:DebianLNMP一键安装服务器套件
- 服务器数据备份(shell 定时脚本备份mysql)
- 服务器数据备份(shell 定时脚本备份mysql)
- 监控服务器连通性的shell脚本
- ORACLE自动备份并且自动FTP到备份机的SHELL脚本
- ORACLE自动备份并且自动FTP到备份机的SHELL脚本(http://doc.linuxpk.com/456.html)
- Linux平台和Windows平台下两种自动备份MySQL数据的脚本(Shell&Bat)和步骤
- mysql备份与同步shell脚本