Linux(CentOS7)設置自動備份資料庫到阿裡雲OSS

来源:https://www.cnblogs.com/guodong-wei/archive/2018/05/11/9025466.html
-Advertisement-
Play Games

環境:阿裡雲伺服器CentOS7.4 + MySQL5.6 基本思路: 1、編寫shell腳本,備份資料庫到指定目錄下 2、編寫Python腳本,把文件上傳到OSS 3、把shell腳本和Python腳本添加Linux的crontab定時器,設置定時執行 首先,環境要配置好,Python環境,cen ...


環境:阿裡雲伺服器CentOS7.4 + MySQL5.6

基本思路:

1、編寫shell腳本,備份資料庫到指定目錄下

2、編寫Python腳本,把文件上傳到OSS

3、把shell腳本和Python腳本添加Linux的crontab定時器,設置定時執行

 

首先,環境要配置好,Python環境,centos 7 自帶Python,一般可以直接使用

查看Python版本:python -V

  

在創建一個目錄/opt/backMySQL/xxx,在目錄/opt/backMySQL下編寫一個shell腳本backup.sh

 1 #!/bin/sh
 2 cd /opt/backMySQL/xxx
 3 echo "You are in /opt/backMySQL/xxx"
 4 
 5 Now=$(date +"%Y-%m-%d")
 6 File=fileName-$Now.sql
 7 mysqldump -urooot -ppassword databaseName > $File
 8 echo "Your database backup successfully completed"
 9 #刪除昨天的文件
10 SevenDays=$(date -d -1day +"%Y-%m-%d")
11 
12 if [ -f /opt/backMySQL/xxx/fileName-$SevenDays.sql  ]
13 then
14  rm -rf /opt/backMySQL/xxx/fileName-$SevenDays.sql
15  echo "You have delete 1 tays ago bak file"
16 else
17  echo "1 days ago bak file not exist"
18 fi

把第6、12、14行中的fileName替換成你想要的文件名,第7行換成資料庫的用戶和密碼

執行這個腳本,就可以把資料庫備份到/opt/backMySQL/xxx目錄下了

再編寫一個Python腳本backupToOSS.py

# -I- coding: utf-8 -*-
import os
import oss2

path = '/opt/backMySQL/naner_zhongkong/'

auth = oss2.Auth('您的AccessKeyId','您的AccessKeySecret')
bucket = oss2.Bucket(auth,'您的Endpoint','您的Bucket名')

#獲取目錄下的所有文件
f_list = os.listdir(path)

for i in f_list:
    # os.path.splitext():分離文件名與擴展名
    if os.path.splitext(i)[1] == '.sql':
        fileName = i
        bucket.put_object_from_file('remote.txt','content of object')    
註意:Python語言縮進有規定語法,不能隨意縮進,記住縮進增加只用在以:結束的語句之後,縮進4個空格,而之後必須恢復到之前的縮進格式

執行:python backupToOSS.py

可以把文件上傳到OSS上了

設置定時器 crontab -e 表示在每天1:05執行backup.sh、每天1:15執行backupToOSS.py     定時具體設置參考 http://www.osyunwei.com/archives/5039.html   Linux定時執行Python腳本 https://www.cnblogs.com/zichun-zeng/p/4235585.html

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 比如Json.NET的JObject明明實現了IEnumerable<T>,具體來說是IEnumerable<KeyValuePair<string, JToken>>,按說JObject類型的對象是可以直接調用Select、Where等linq擴展方法的,但偏偏就是不行,代碼如下: 究竟是人性的扭 ...
  • 經緯度轉換為詳細地址信息 參考文檔:http://lbs.qq.com/webservice_v1/guide-gcoder.html 首先申請key,如果使用的是服務端請求webservice API ,申請密鑰的時候要選擇“服務端”,創建成功之後設置ip白名單,否則預設全部ip都可以使用的你的k ...
  • 本篇承接上篇內容,如果你不小心點擊進來,建議從第一篇開始完整閱讀,文章內容繼承性連貫性。 構建NetCore應用框架之實戰篇系列 一、簡介 1、登錄功能完成後,框架的雛形已經形成,有必要進行複習。 2、本篇簡單對框架代碼進行一些解釋。同時可以簡單理解框架的規範。 二、目錄結構規範 1、直接上圖,目錄 ...
  • C# 虹軟SDK視頻人臉識別和註冊 居然收到10元打賞,還不知道誰乾的,其實更好(自認為)的demo在https://github.com/catzhou2002/ArcFaceDemo 截屏留念: 當然,謝謝!謝謝鼓勵! ...
  • ARM Linux驅動篇 學習溫度感測器ds18b20的驅動編寫過程 原文地址: "http://www.cnblogs.com/NickQ/p/9026545.html " 一、開發板與ds18b20的入門 ds18B20是常用的數字溫度感測器,具有體積小,硬體開銷低,抗干擾能力強,精度高的特點。 ...
  • 訪問其官網,https://www.centos.org/,點擊Get CentOS Now,點擊alternative downloads,點擊CentOS 7列表中的x86_64,點擊http://mirrors.163.com/centos/7/isos/x86_64/,裡邊有幾個不同的版本。 ...
  • 系統環境:Windows 10 Pro 軟體版本:VMware 12 Pro 安裝鏡像:CentOS-7-x86_64-Everything-1804.iso 下載地址:https://www.centos.org/download/ 1.點擊創建新的虛擬機,選擇典型。 2.單擊瀏覽並選擇鏡像文件 ...
  • 21.1 為什麼要學習Shell編程 (1)Linux運維工程師在進行伺服器集群管理時,需要編寫Shell程式來進行伺服器管理。 (2)對於JavaEE和Python程式員來說,工作的需要,你的老大會要求你編寫一些Shell腳本進行程式或者是伺服器的維護,比如編寫一個定時備份資料庫的腳本。 (3)對 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...