Oracle 備份與恢復 (Docker部署版)

来源:https://www.cnblogs.com/blogof-fusu/archive/2022/08/17/16596306.html
-Advertisement-
Play Games

Oracle 備份與恢復 (Docker部署版) 一,宿主機設置定時備份腳本 1.檢查Oracle容器是否正常運行 docker ps 2.進入容器,創建shell腳本 #oracle11g 是容器名 docker exec -it oracle11g bash #創建資料庫dump的目錄 mkdi ...


Oracle 備份與恢復 (Docker部署版)

一,宿主機設置定時備份腳本

1.檢查Oracle容器是否正常運行

docker ps

image-20220817181211418

2.進入容器,創建shell腳本

#oracle11g 是容器名
docker exec -it oracle11g bash
#創建資料庫dump的目錄
mkdir -p /home/oracle/dump/
cd /home/oracle/dump/
#編寫腳本並插入如下內容
vi dump.sh
#!/bin/bash
whoami
su - oracle <<!
whoami
cd /home/oracle/dump
exp CQDX_JXGLXX/unicorn owner=CQDX_JXGLXX file=exp_xxx.dmp log=exp_xxx.log buffer=6000000
#腳本保存後賦予可執行許可權
chmod 777 dump.sh

3.在宿主機創建定時任務執行容器內腳本並拷貝至宿主機

#首先退出制宿主機,然後創建保存目錄
mkdir -p /home/oracle/
cd /home/oracle/
#創建shell腳本
vi oracle.sh
#添加如下內容
#!/bin/bash
docker exec -u 0 oracle11g bash -c "cd /home/oracle/;./dump.sh"
docker cp oracle11g:/home/oracle/dump /home/oracle/

備註:bash -c 後面是需要在oracle容器內部執行的指令。分別指,是進入到腳本所在的目錄,執行腳本。

4.設置定時任務

#首先查看是否安裝crontab
service crond status

image-20220817171313544

#如果沒有就執行安裝命令
yum install cronie
#啟動服務
service crond start 

crontab的其他命令

#重啟服務
service crond restart 
#關閉服務
service crond stop 
#重新載入服務
service crond reload 
#查看狀態
service crond status 

確定已經啟動crontab後就創建定時任務

#執行後會出現一個可編輯的界面
crontab -e
#末尾添加定時任務指令,可以按需求調整執行時間
30 18 * * 5 bash /home/oracle/oracle.sh
#查看是否設置成功
crontab -l

備註:時間格式如下

f1 f2 f3 f4 f5 program
  • 其中 f1 是表示分鐘,f2 表示小時,f3 表示一個月份中的第幾日,f4 表示月份,f5 表示一個星期中的第幾天。program 表示要執行的程式。
  • 當 f1 為 * 時表示每分鐘都要執行 program,f2 為 * 時表示每小時都要執行程式,其餘類推
  • 當 f1 為 a-b 時表示從第 a 分鐘到第 b 分鐘這段時間內要執行,f2 為 a-b 時表示從第 a 到第 b 小時都要執行,其餘類推
  • 當 f1 為 */n 時表示每 n 分鐘個時間間隔執行一次,f2 為 */n 表示每 n 小時個時間間隔執行一次,其餘類推
  • 當 f1 為 a, b, c,... 時表示第 a, b, c,... 分鐘要執行,f2 為 a, b, c,... 時表示第 a, b, c...個小時要執行,其餘類推
*    *    *    *    *
-    -    -    -    -
|    |    |    |    |
|    |    |    |    +----- 星期中星期幾 (0 - 6) (星期天 為0)
|    |    |    +---------- 月份 (1 - 12) 
|    |    +--------------- 一個月中的第幾天 (1 - 31)
|    +-------------------- 小時 (0 - 23)
+------------------------- 分鐘 (0 - 59)

例:

周五每天下午 5:00執行腳本

0 17 * * 5 bash /home/oracle/oracle.sh

二,拷貝到目標伺服器

1.配置ssh免密

#首先在安裝Oracle的伺服器上
cd /root/.ssh/
#如果沒有該目錄則執行
ssh-keygen -t rsa
#然後一直回車,重新進入該目錄
cd /root/.ssh/
ll

image-20220817173156272

#如果沒有authorized_keys就新建一個
touch authorized_keys

切換到目標伺服器,同樣如果沒有.ssh目錄就執行ssh-keygen -t rsa,然後進入.ssh目錄

#查詢密鑰
cat id_rsa.pub

image-20220817181308297

然後複製此處查詢出的密鑰,繼續回到安裝Oracle的伺服器

#編輯authorized_keys,把剛纔的密鑰複製進去,然後保存
vi authorized_keys

回到目標伺服器測試能否遠程登錄

ssh root@<Oracle伺服器Ip>

image-20220817181355415

2.繼續在目標伺服器編寫定時任務

#新建備份文件夾
mkdir -p /home/oracle/
vi scp.sh
#腳本內添加
#!/bin/bash
scp -r root@<Oracle宿主機IP>:/home/oracle/dump /home/test/oracle/

設置定時任務

crontab -e
#因為Oracle宿主機的備份任務是設置到星期五的晚上六點半,為防止資料庫過大,所以scp的任務間隔時間要長一點
30 20 * * 5 bash /home/oracle/scp.sh
#查看是否設置成功
crontab -l

三,數據恢復

1.首先安裝Oracle(教程)

2.創建Oracle表空間和用戶,導入表結構

#進入安裝oracle的伺服器
docker exec -it -u root <服務名> bsah
#進入容器後切換oracle用戶
su - oracle
#進入oracle
sqlplus / as sysdba 

image-20220817181454151

#創建表空間
create tablespace YG_JXGLXX datafile '/home/oracle/app/oracle/oradata/helowin/tets02.dbf' size 1G reuse autoextend on next 50M maxsize unlimited default storage(initial 128k next 128k minextents 2 maxextents unlimited); 
#創建用戶並分配表空間
create user CQDX_JXGLXX identified by unicorn default tablespace YG_JXGLXX temporary tablespace TEMP;
#給用戶賦權
grant connect,dba,exp_full_database,imp_full_database to CQDX_JXGLXX with admin option;

img

3.導入流程

首先把備份的資料庫文件exp_xxx.dmp上傳到新庫伺服器

#然後拷貝到容器內部
docker cp ./exp_xxx.dmp oracle_11g:/home

#進入oracle容器
docker exec -it oracle_11g bash

# 臨時設置環境變數
export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_2

export ORACLE_SID=helowin   

export PATH=$ORACLE_HOME/bin:$PATH

export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"

cd ~

#需要根據實際調整賬號密碼 以及fromuser touser
imp CQDX_JXGLXX/unicorn fromuser=CQDX_JXGLXX touser=CQDX_JXGLXX file=/home/exp_xxx.dmp log=imp.log ignore=y

rm -f /home/exp_xxx.dmp

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

-Advertisement-
Play Games
更多相關文章
  • Vue——​​兩分鐘概述 Vue 是一個JavaScript 框架。 在其最簡單的模式中,您可以簡單地將核心 Vue 腳本包含在您的應用程式中,然後開始構建您的組件。 除此之外,對於更複雜的應用程式,您可以使用 Vue 自己的 CLI 創建(並最終發佈)一個 Vue 項目。 與大多數其他 JavaS ...
  • 在現實生活中,生命周期一詞往往代表著某些人或事物從生到死的過程,而在依賴註入框架中,生命周期中的“生與死”體現為服務實例的創建和釋放。實際上對於介紹依賴註入框架的生命周期而言,就是在介紹依賴註入容器採用什麼樣的方式創建和釋放服務實例。 多個容器之間的組織結構 在介紹生命周期之前,我們必須先對“多個容 ...
  • 一個例子形象的理解協程和線程的區別 Talk is cheap, show me the code! 所以,廢話先不說,先上代碼: 首先寫一個WebAPI介面 /// <summary> /// 測試介面 /// </summary> [RoutePrefix("api/test")] public ...
  • 第一章節(p0-p20) 1、Linux使用在哪些地方 1、LInux嵌入式工程師、Linux運維工程師 2、最主要在伺服器領域、(免費,穩定、高效) 3、嵌入式領域(對軟體進行裁剪) 4、以後在物聯網中會應用更加廣泛 2、Linux介紹 1、常見操作系統:Windows、IOS、Android、M ...
  • 用的openwrt路由器,家裡寬頻申請了動態公網ip,為了方便把22 80埠映射到公網,發現經常被暴力破解,自己寫了個臨時封禁ip功能的腳本,實現5分鐘內同一個ip登錄密碼錯誤10次就封禁這個ip 5分鐘,並且進行郵件通知 使用步驟 openwrt為19.07.03版本,其他版本沒有測試過 安裝b ...
  • 發現Rocky Linux已經升級了9.0版本,看著自己用著的8.5版本,躍躍欲試,於是就索性升級了。兩者的支持年限沒有太大的差別,先說我的想法:升不升級無所謂。 並不是9.0有什麼特別牛的特性,只是單純的想升級折騰一下而已。 記錄一下自己遷移的過程。 遷移過程 基本的參考都是來自:https:// ...
  • 本課程主要介紹 StoneDB-5.6 在 Ubuntu 20.04 LTS 下的手動編譯,在 CentOS 和 RedHat 的編譯詳見官方文檔。 如果想快速部署,詳見官方文檔 https://stonedb.io/zh/docs/getting-started/quick-deployment ...
  • 發佈和訂閱模式(Pub/Sub)是構建企業級 .NET 應用程式不可或缺的工具。Pub/Sub 是一種消息傳遞範式,消息的發送方(發佈者)不知道目標接收方(訂閱者)的任何信息。此外,發佈者和訂閱者之間不直接發生交互,而是依賴一種叫作主題的公共媒介。因此,這是一個鬆散耦合的消息模型。 現在,我們假設在... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...