資料庫(Oracle 11g)使用expdp每周進行數據備份並上傳到備份伺服器

来源:https://www.cnblogs.com/wxwbblog/archive/2022/06/27/16406027.html
-Advertisement-
Play Games

學校需要將之前的生產資料庫備份到華為雲,之後實現每周自動備份 ...


1.看看資料庫情況

1.1先看了下表空間情況,生產環境表空間大概90G,用了才一半不到

查看所有表空間及使用情況
SELECT
  B.FILE_NAME 物理文件名,
  B.TABLESPACE_NAME 表空間名稱,
  B.BYTES/1024/1024 大小M,
  (B.BYTES-SUM(NVL(A.BYTES,0)))/1024/1024 已使用M,
  SUBSTR((B.BYTES-SUM(NVL(A.BYTES,0)))/(B.BYTES)*100,1,5) 使用率
FROM DBA_FREE_SPACE A,DBA_DATA_FILES B
WHERE A.FILE_ID=B.FILE_ID
GROUP BY B.TABLESPACE_NAME,B.FILE_NAME,B.BYTES
ORDER BY B.TABLESPACE_NAME;

image

2.資料庫備份

2.1登陸資料庫

[root@]$ sqlplus / as sysdba

2.2創建邏輯目錄

執行這個操作並不會在Linux中創建/opt/data_backup這個文件,最後需要手動去創建該文件才能進行備份。
SQL> create directory back_dir as '/opt/backup'
SQL> select * from dba_directories; #查看所有邏輯目錄,看是否創建成功

2.3給資料庫用戶文件操作許可權#dbuser為資料庫用戶名,更具實際情況更改

Grant read,write on directory back_dir to dbuser;

2.3創建物理目錄

[root@]$ mkdir -p /opt/backup #-p 確保目錄名稱存在,不存在的就建一個,可使用參數創建多級目錄

1.3備份資料庫

[root@]$ expdp dbuser/passwd@192.168.110.9:1521/orcl dumpfile=dbback.dmp log=log.log directory=back_dir schemas=cbyxy
exedp有很多參數,這裡是用到的一些解釋
dbuser/passwd@192.168.110.9:1521/orcl #導出用戶名/密碼@資料庫IP/資料庫SID
dumpfile=導出的文件名.dmp
log=導出過程的日誌名.log
directory=備份放的路徑名,用的之前的邏輯目錄名
schemas=要備份的資料庫用戶名字
FULL=y #加上意思為導出整個資料庫就不需要schemas參數了
也可以按表空間導出TABLESPACES=
表名導出TABLES=
等等還有很多參數自行瞭解

3.shell腳本實現自動備份

點擊查看代碼
#!/bin/bash
#導入環境變數,根據具自己實際情況填寫
export ORACLE_BASE=/home/oracle/app
export ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/dbhome_1
export PATH=$ORACLE_HOME/bin:$PATH
export LOCAL_IP=192.168.110.183:1521
export BACKUP_USER_IP_DIR=root@192.168.110.187:/opt/   #備份伺服器的用戶,ip,保存地址
export ORACLE_USER_NAME=system #資料庫的用戶密碼根據實際情況填寫,備份整個庫最好使用system或sys管理員用戶
export ORACLE_USER_PASSWD=Abc123556..
export ORACLE_SID=orcl #不知道可以使用Oracle用戶執行echo $ORACLE_SID,或者SQL> SELECT instance_name FROM v$instance
export DATA_DIR=/opt/backup   #與資料庫中的邏輯地址相同,用來儲存備份文件
export DELTIME=`date -d "7 days ago" +%Y%m%d` # -d "7 days ago" 為獲取七天前的日期,以日期命名方便任務自動刪>除
export BAKUPTIME=`date +%Y%m%d` #備份日期年月日
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK #定義語言地域和字元集屬性的環境變數,根據自己資料庫情況修改
mkdir -p $DATA_DIR
echo "Starting bakup..."
echo "Backup file path $DATA_DIR/$BAKUPTIME.dmp"
expdp $ORACLE_USER_NAME/$ORACLE_USER_PASSWD@$LOCAL_IP/$ORACLE_SID dumpfile=$BAKUPTIME.dmp log=$BAKUPTIME.log directory=expdp full=y
echo "backup file success..."
tar -zcvPf $DATA_DIR/$BAKUPTIME.tar.gz $DATA_DIR/$BAKUPTIME.dmp --remove-files ##-P:指定絕對路徑 --remove-files :打包後刪除原文件
echo "tar the file backup successfully"
echo "scp to":$BACKUP_IP
scp $DATA_DIR/$BAKUPTIME.tar.gz $BACKUP_USER_IP_DIR #遠程伺服器防火牆有限制scp埠需要加:-P 埠號
rm -f $DATA_DIR/$DELTIME.log #刪除之前的備份
echo "Bakup completed."

image

4.添加定時任務

[root@ ]$ crontab -e
添加行:* 1 * * 6 /opt/back.sh #每個星期的星期六早上執行備份任務

點擊查看代碼
*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----- 星期中星期幾 (0 - 6) (星期天 為0)
|    |    |    +---------- 月份 (1 - 12) 
|    |    +--------------- 一個月中的第幾天 (1 - 31)
|    +-------------------- 小時 (0 - 23)
+------------------------- 分鐘 (0 - 59)

4.參考文章

https://www.cnblogs.com/xwdreamer/p/3511047.html
https://www.cnblogs.com/farmer-y/p/5888432.html
https://blog.csdn.net/weixin_41607523/article/details/110817646
https://blog.csdn.net/XUEYUTIANQI/article/details/113976558


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

-Advertisement-
Play Games
更多相關文章
  • (註:此筆記預設操作系統為centOS7) 文件許可權 超級管理員用戶(root)可以修改任何文件,普通用戶才有許可權這個概念。 文件許可權就是文件的訪問許可權,即哪些用戶和群組可以訪問文件以及執行怎麼樣的操作。 Linux/Unix系統是典型的多用戶系統,不同的用戶處於不同的地位,對文件和目錄有不同的訪問 ...
  • 一、前期準備 測試環境:VMware Workstation / centos8 1)增加一塊磁碟 2)查看新增磁碟(lsblk),發現沒找到新增的磁碟 3)解決查不到新增磁碟問題 重新掃描SCSI匯流排添加設備, $ echo "- - -" > /sys/class/scsi_host/host0 ...
  • 前提:關閉selinux和防火牆 SElinux: setenforce 0 vim /etc/selinux/config-->disabled 防火牆: firewall-cmd --set-default-zone=trusted iptables -F 1.下載安裝包: 使用yum info ...
  • Windows 10 啟動谷歌瀏覽器Chrome失敗(應用程式無法啟動,因為應用程式的並行配置不正確)解決方法 ...
  • 配置免密登錄伺服器及下載備份文件#!/bin/bash BACKUP=192.168.30.233 #一行寫一個IP BACKUP_PASSWD="lxzl_root*#2021" #root密碼 MYSQLBACKUP=192.168.30.232 #一行寫一個IP MYSQLBACKUP_PAS ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 將網路上的文件下載到使用 Linux 操作系統的電腦上,需要用到 wget 指令,使用該指令可能會面臨兩個問題。 首先,如何獲取文件的下載 url?這需要你在瀏覽器上找到要下載文件的鏈接地址,然後右鍵 → 複製鏈接地址,既可獲取該文件的下載 u ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 本地或遠程阿裡雲伺服器開啟redis服務(安裝redis過程省略) windows內打開cmd命令進入redis安裝目錄輸入redis-server.exe啟動或是直接雙擊文件夾內的redis-server.exe啟動 linux啟動命令僅需輸入 ...
  • 一、直播介紹 5月30日,袋鼠雲一站式全自動化運維管家ChengYing(承影)正式開源,我們深知將開源不是結束,而恰恰是開始,如何讓更多的小伙伴們更好的瞭解ChengYing、使用ChengYing、建設ChengYing,是開源項目團隊的同學一直在思考的問題。 為了更好的幫助大家瞭解ChengY ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...