人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

詳解Linux運(yùn)維CentOS系統(tǒng)SVN雙備份Shell腳本

發(fā)布日期:2022-07-15 12:37 | 文章來源:gibhub

SVN是Subversion的簡稱,是一個開放源代碼的版本控制系統(tǒng),采用了分支管理系統(tǒng)。說得簡單一點(diǎn)SVN就是用于多個人共同開發(fā)同一個項(xiàng)目,共用資源的目的。

作為一個代碼管理工具,備份操作顯得尤為重要,這里采取這樣的備份策略:在執(zhí)行本地備份的同時,讓Shell腳本自動上傳數(shù)據(jù)到另一臺FTP備份服務(wù)器中,這種異地備份策略成本比較小,無需存儲,而且安全系統(tǒng)高,想到與雙備份,本地和異地同時出現(xiàn)數(shù)據(jù)損壞的概率是低很多的。

備份策略說明

使用CentOS 6系列系統(tǒng),安裝vsftpd,修改配置參數(shù)。此外vsftpd的備份目錄可以做RAID1或RAID5。
執(zhí)行腳本將svn項(xiàng)目進(jìn)行本地目錄備份,然后將備份文件上傳到FTP服務(wù)器上,已實(shí)現(xiàn)雙備份。

備份步驟

安裝并配置vsftpd

使用yum直接安裝即可。

yum -y install vsftpd

修改配置,由于要進(jìn)行上傳操作,所以要允許用戶上傳。為安全性考慮,不建議匿名用戶操作。

修改配置后,將不必要的vsftpd.conf參數(shù)屏蔽,顯示為:

[root@private ~]# grep -v "^#" /etc/vsftpd/vsftpd.conf | grep -v "^$"
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=YES
chroot_local_user=YES
listen=YES
pam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES

chroot_local_user=YES這條語句需要重點(diǎn)強(qiáng)調(diào)一下,其作用是對用戶登錄權(quán)限進(jìn)行限制,即所有本地用戶登錄vsftpd時只能在自己的家目錄下,這是基于安全的考慮,本實(shí)例腳本也會基于這點(diǎn),要是使用本腳本在實(shí)際的生產(chǎn)環(huán)境,需要注意該點(diǎn)。

創(chuàng)建ftp登錄用戶

在備份服務(wù)器上創(chuàng)建備份用戶,本次創(chuàng)建用戶svn,并為其分配密碼,還應(yīng)該將其家目錄更改為備份目錄,本地備份目錄為:/data/backup/svn-backup/,這樣更方便備份工作,以下腳本以此類推。

[root@private ~]# useradd -d /data/backup/svn-backup/ svn
[root@private ~]# echo "svnpasswd" | passwd --stdin svn
Changing password for user svn.
passwd: all authentication tokens updated successfully.

配置svn倉庫

首先檢查操作系統(tǒng)上面是否安裝了subversion,一般centos操作系統(tǒng)都默認(rèn)安裝了此軟件,如果沒有安裝使用如下命令快速安裝

rpm -qa subversion
yum -y install subversion
##創(chuàng)建版本庫
svnadmin create /data/svn  //這里的文件目錄自己隨便設(shè)置 
##配置svnserve,上述版本庫`/data/svn `建立后在文件夾下會生成conf文件夾,進(jìn)入`/data/svn/conf`下面會有下面3個文件
[root@private svn]# ls conf/
authz passwd svnserve.conf 
##需要修改`svnserve.conf`修改以下幾個部分:
anon-access = read 
auth-access = write 
password-db = passwd 
authz-db = authz 
##修改`passwd`文件為:
[users] 
username = password  //這里的username和password自己設(shè)置 
##配置文件`authz`最后加上以下兩行(這兩行解決了 SVN客戶端解決authorization failed問題)
[/] 
* = rw  
##啟動svnserve即可:
svnserve -d -r /home/myrepos/ 

備份腳本

本腳本設(shè)置輪詢周期為30天一次,Shell會自動刪除30天以前的文件。在vsftpd建立相應(yīng)的備份用戶svn腳本內(nèi)容如下:

#!/bin/bash
SVNDIR="/data"
SVNADMIN="/usr/bin/svnadmin"
DATE=$(date +%Y-%m-%d)
OLDDATE=$(date +%Y-%m-%d -d'30 days')
BACKDIR="/data/backup/svn-backup"
[ -d ${BACKDIR} ] || mkdir -p ${BACKDIR}
LogFile=${BACKDIR}/svnbak.log
[ -f ${LogFile} ] || touch ${LogFile}
mkdir ${BACKDIR}/${DATE}
for PROJECT in svn
do
  cd $SVNDIR
  $SVNADMIN hotcopy $PROJECT $BACKDIR/$DATE/$PROJECT --clean-logs
  cd $BACKDIR/$DATE
  tar zcvf ${PROJECT}_svn_${DATE}.tar.gz $PROJECT > /dev/null
  rm -rf $PROJECT
  sleep 2
done
HOST=localhost
FTP_USERNAME=svn
FTP_PASSWORD=Haiyuan
cd ${BACKDIR}/${DATE}
ftp -i -n -v <<!
open ${HOST}
user ${FTP_USERNAME} ${FTP_PASSWORD}
bin
cd ${OLDDATE}
mdelete *
cd ..
rmdir ${OLDDATE}
mkdir ${DATE}
cd ${DATE}
mput *
bye

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持本站。

美國快速服務(wù)器

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實(shí)時開通

自選配置、實(shí)時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部