91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux運維CentOS系統SVN雙備份Shell腳本的示例分析

發布時間:2021-07-16 11:40:58 來源:億速云 閱讀:141 作者:小新 欄目:服務器

這篇文章主要為大家展示了“Linux運維CentOS系統SVN雙備份Shell腳本的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Linux運維CentOS系統SVN雙備份Shell腳本的示例分析”這篇文章吧。

前言

SVN是Subversion的簡稱,是一個開放源代碼的版本控制系統,采用了分支管理系統。說得簡單一點SVN就是用于多個人共同開發同一個項目,共用資源的目的。

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

備份策略說明

使用CentOS 6系列系統,安裝vsftpd,修改配置參數。此外vsftpd的備份目錄可以做RAID1或RAID5。
執行腳本將svn項目進行本地目錄備份,然后將備份文件上傳到FTP服務器上,已實現雙備份。

備份步驟

安裝并配置vsftpd

使用yum直接安裝即可。

yum -y install vsftpd

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

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

[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這條語句需要重點強調一下,其作用是對用戶登錄權限進行限制,即所有本地用戶登錄vsftpd時只能在自己的家目錄下,這是基于安全的考慮,本實例腳本也會基于這點,要是使用本腳本在實際的生產環境,需要注意該點。

創建ftp登錄用戶

在備份服務器上創建備份用戶,本次創建用戶svn,并為其分配密碼,還應該將其家目錄更改為備份目錄,本地備份目錄為:/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倉庫

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

rpm -qa subversion
yum -y install subversion
##創建版本庫
svnadmin create /data/svn  //這里的文件目錄自己隨便設置 
##配置svnserve,上述版本庫`/data/svn `建立后在文件夾下會生成conf文件夾,進入`/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自己設置 

##配置文件`authz`最后加上以下兩行(這兩行解決了 SVN客戶端解決authorization failed問題)

[/] 
* = rw  

##啟動svnserve即可:
svnserve -d -r /home/myrepos/

備份腳本

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

#!/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

以上是“Linux運維CentOS系統SVN雙備份Shell腳本的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永和县| 嘉义市| 方山县| 赣榆县| 威信县| 同仁县| 泸州市| 竹山县| 太康县| 周口市| 江都市| 巫溪县| 河源市| 三门县| 鲜城| 东山县| 定西市| 永新县| 汉阴县| 夏邑县| 福贡县| 饶河县| 尉氏县| 子洲县| 高碑店市| 龙泉市| 南汇区| 上虞市| 徐闻县| 峨山| 荥经县| 金阳县| 灵宝市| 南雄市| 六安市| 额敏县| 通海县| 新干县| 乌鲁木齐市| 揭阳市| 瑞安市|