Oracle 數據庫報 ora-00257 錯誤并且執行alter system switch logfile 命令卡死的解決過程

Oracle 數據庫報 ora-00257 錯誤并且執行alter system switch logfile 命令卡死的解決過程

726日下午,某醫院用戶的 HIS 系統無法連接,報如下錯誤:

在這里插入圖片描述

在這里插入圖片描述

初步判斷是歸檔日志問題。

用戶的 HIS 系統數據庫是雙節點 Oracle 11g Rac 集群。登錄服務器之后發現使用 sqlplus 可以登錄系統,但是執行 alter system switch logfile; 命令時系統無反應,出現卡死狀態。

這應該是 Oracle 的日志不能歸檔,導致無法切換日志。用戶反映HIS客戶斷無法連接數據庫,導致醫院業務停止。

解決過程如下:

步驟1:使用 v$flash_recovery_area_usage 視圖查看歸檔日志的空間利用率。發現達到 99.95%,如下圖所示:

在這里插入圖片描述

步驟2:使用 rman 刪除歸檔日志。

命令如下:

rman target /
DELETE ARCHIVELOG UNTIL TIME 'SYSDATE-7';
CROSSCHECK ARCHIVELOG ALL; 
DELETE EXPIRED ARCHIVELOG ALL;

執行以上命令后發現 7 天之前的歸檔日志并沒有被刪除。原因是 DELETE ARCHIVELOG 命令只刪除做過備份的歸檔文件。

使用如下命令繼續刪除歸檔文件:

DELETE ARCHIVELOG UNTIL TIME 'SYSDATE-7';
DELETE FORCE ARCHIVELOG UNTIL TIME 'SYSDATE-7';  -- 強制刪除歸檔日志,不管有沒有做過備份
DELETE EXPIRED ARCHIVELOG ALL;

刪除之后查詢 v$flash_recovery_area_usage 視圖信息,發現日志文件數量由 697 個減少為 290 個,但REDO LOG對應的PERCENT_SPACE_USED參數的值卻變成了1455.6%(正常值應該為 0-100)。執行 alter system switch logfile; 命令時系統仍然處于卡死狀態。
查詢發現:當 V$FLASH_RECOVERY_AREA_USAGE 顯示 ARCHIVED LOG 使用率超過 100% 時,說明閃回恢復區空間已耗盡,會導致:

(1)歸檔失敗(出現 ORA-00257 錯誤);
(2)數據庫掛起(DML 操作阻塞);
(3)日志切換卡死(ALTER SYSTEM SWITCH LOGFILE 無響應)。

SQL> select * from v$flash_recovery_area_usage;FILE_TYPE	     PERCENT_SPACE_USED PERCENT_SPACE_RECLAIMABLE NUMBER_OF_FILES
-------------------- ------------------ ------------------------- ---------------
CONTROL FILE			0 				0				0
REDO LOG				0 				0				0
ARCHIVED LOG			1455.6 			0     			 290
BACKUP PIECE			0 				0				0
IMAGE COPY				0 				0				0
FLASHBACK LOG			0 				0				0
FOREIGN ARCHIVED LOG	 0 			 	0	 	 		0
7 rows selected.

步驟3:考慮到業務需要,臨時修改歸檔日志存放的地址,然后再查找原因。

系統配置有 dg,參數log_archive_dest_1log_archive_dest_2 的配置如下:

log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=hisdb'
log_archive_dest_2='SERVICE=dghisdb LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=dghisdb'

執行如下操作切換歸檔日志存放的地址:

-- 在兩個節點上分別創建目錄:/u01/app/oracle/gdbak0726
-- 然后執行下面的命令切換歸檔日志的地址
alter system set log_archive_dest_2='location=/u01/app/oracle/gdbak0726' scope=both;

執行上面的命令之后,過了幾分鐘,發現系統恢復正常。用戶反映可以登錄系統了,業務恢復正常。執行alter system switch logfile 命令時也比較順利。

=====================================================================================================

=============== 問題最終解決 =========================================================================

=====================================================================================================

到晚上八點半,醫院下班之后,把歸檔日志的地址恢復為原來的參數。命令如下:

alter system set log_archive_dest_2='SERVICE=dghisdb LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=dghisdb' scope=both;

執行以上命令之后,發現執行alter system switch logfile 命令時仍然卡死。

查詢發現, v$flash_recovery_area_usage 視圖中 ARCHIVED LOG 對應的參數 PERCENT_SPACE_USED 的值與參數db_recovery_file_dest_size有關,把參數db_recovery_file_dest_size的值調大即可。

查看參數db_recovery_file_dest_size的值:

SQL> show parameter DB_RECOVERY_FILE_DEST_SIZENAME				     TYPE	 VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest_size	     big integer 5G

執行下面的命令把參數db_recovery_file_dest_size的值修改為 50G:

alter system set db_recovery_file_dest_size=50G scope=both;

然后查詢 v$flash_recovery_area_usage 視圖信息:

SQL> select * from v$flash_recovery_area_usage;FILE_TYPE	     PERCENT_SPACE_USED PERCENT_SPACE_RECLAIMABLE NUMBER_OF_FILES
-------------------- ------------------ ------------------------- ---------------
CONTROL FILE			0 				0				0
REDO LOG				0 				0				0
ARCHIVED LOG			145.56 			0     			 290
BACKUP PIECE			0 				0				0
IMAGE COPY				0 				0				0
FLASHBACK LOG			0 				0				0
FOREIGN ARCHIVED LOG	 0 			 	0	 	 		0
7 rows selected.

再次把參數db_recovery_file_dest_size的值修改為 100G:

alter system set db_recovery_file_dest_size=100G scope=both;

然后查詢 v$flash_recovery_area_usage 視圖信息,發現ARCHIVED LOG選項對應的PERCENT_SPACE_USED參數的值已下降到100以內。

SQL> select * from v$flash_recovery_area_usage;FILE_TYPE	     PERCENT_SPACE_USED PERCENT_SPACE_RECLAIMABLE NUMBER_OF_FILES
-------------------- ------------------ ------------------------- ---------------
CONTROL FILE				0					0				0
REDO LOG					0					0				0
ARCHIVED LOG				72.78				72.43			290
BACKUP PIECE				0					0				0
IMAGE COPY					0					0				0
FLASHBACK LOG				0					0				0
FOREIGN ARCHIVED LOG		0					0				07 rows selected.

過了幾分鐘,用戶反映業務恢復正常了。說明通過修改參數db_recovery_file_dest_size的值是可以的解決問題的。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/916599.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/916599.shtml
英文地址,請注明出處:http://en.pswp.cn/news/916599.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ArKTS:List 數組

一種:/**# encoding: utf-8# 版權所有 2025 ©涂聚文有限公司? # 許可信息查看:言語成了邀功盡責的功臣,還需要行爲每日來值班嗎# 描述: 數組# Author : geovindu,Geovin Du 涂聚文.# IDE : DevEco Studio 5.1.1 …

Spring Boot 3整合Spring AI實戰:9輪面試對話解析AI應用開發

Spring Boot 3整合Spring AI實戰:9輪面試對話解析AI應用開發 第1輪:基礎配置與模型調用 周先生:cc,先聊聊Spring AI的基礎配置吧。如何在Spring Boot 3項目中集成Ollama? cc:我們可以通過OllamaConfig.java…

標準SQL語句示例

一、基礎操作1. 數據庫操作-- 1. 創建數據庫 CREATE DATABASE 數據庫名稱 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;-- 2. 刪除數據庫 DROP DATABASE IF EXISTS 數據庫名稱;-- 3. 選擇數據庫 USE 數據庫名稱;-- 4. 顯示所有數據庫 SHOW DATABASES;-- 5. 查看數據庫創…

STM32-基本定時器

一.基本定時器簡介 STM32F1 系列共有 8 個定時器,分別為:基本定時器、通用定時器、高級定時器。基本定時器 TIM6 和 TIM7 是一個 16 位的只能向上計數的定時器,只能定時,沒有外部IO。 二.基本定時器功能 上圖為基本定時器的功能框…

ofd文件轉pdf

主要后端使用Java實現&#xff0c;前端可隨意搭配http請求添加依賴&#xff1a;<!-- OFD解析與轉換庫 --><dependency><groupId>org.ofdrw</groupId><artifactId>ofdrw-converter</artifactId><version>1.17.9</version></…

4.應用層自定義協議與序列化

1.應用層程序員寫的一個個解決我們實際問題, 滿足我們日常需求的網絡程序, 都是在應用層1.1再談“協議”協議是一種 "約定". socket api 的接口, 在讀寫數據時, 都是按 "字符串" 的方式來發送接收的. 如果我們要傳輸一些 "結構化的數據" 怎么辦呢…

【QT搭建opencv環境】

本文參考以下文章&#xff1a; https://blog.csdn.net/weixin_43763292/article/details/112975207 https://blog.csdn.net/qq_44743171/article/details/124335100 使用軟件 QT 5.14.2下載地址&#xff1a;download.qt.io 選擇版本&#xff1a;Qt 5.14.2 Qt 5.14.2百度網盤鏈接…

golang--函數棧

一、函數棧的組成結構&#xff08;棧幀&#xff09; 每個函數調用對應一個棧幀&#xff0c;包含以下核心部分&#xff1a; 1. 參數區 (Arguments) 位置&#xff1a;棧幀頂部&#xff08;高地址端&#xff09;內容&#xff1a; 函數調用時傳入的參數按從右向左順序壓棧&#xff…

【FAQ】創建Dynamics 365 Sales環境

參考文章&#xff1a;5 分鐘內安裝 Dynamics 365 Sales 步驟 1&#xff1a;訪問 Power Platform 管理中心 導航到make.powerapps.com&#xff0c;然后點擊右上角的齒輪圖標。選擇管理中心&#xff0c;或者訪問aka.ms/ppac訪問 Power Platform 管理中心。 第 2 步&#xff1a…

【數據庫】使用Sql Server將分組后指定字段的行數據轉為一個字段顯示,并且以逗號隔開每個值,收藏不迷路

大家好&#xff0c;我是全棧小5&#xff0c;歡迎來到《小5講堂》。 這是《Sql Server》系列文章&#xff0c;每篇文章將以博主理解的角度展開講解。 溫馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不對之處望指正&#xff01; 目錄前言示例數據集數…

7.項目起步(1)

1&#xff0c;項目起步-初始化項目并使用git管理創建項目并精細化配置src目錄調整git 管理項目2項目起步-配置別名路徑聯想提示什么是別名路徑聯想提示如何進行配置 &#xff08;自動配置了&#xff09;{"compilerOptions" : {"baseUrl" : "./",…

【C++詳解】深入解析繼承 類模板繼承、賦值兼容轉換、派生類默認成員函數、多繼承與菱形繼承

文章目錄一、繼承概念二、繼承定義定義格式繼承后基類成員訪問方式的變化類模板的繼承三、基類和派?類間的轉換(賦值兼容轉換)四、繼承中的作用域隱藏規則兩道筆試常考題五、派生類的默認成員函數四個常見默認成員函數實現?個不能被繼承的類六、繼承與友元七、繼承與靜態成員…

加法器 以及ALU(邏輯算術單元)

加法器框架&#xff0c;首先介紹原理&#xff0c;然后引入一位加法器最后再引入多位加法器最后引入帶符號的加法器這一節涉及到的硬件電路的知識理解就好&#xff0c;實在看不懂就跳過&#xff0c;但是封裝以后的功能必須看懂。這是一個一般的加法過程涉及到的必要元素圖中已經…

設計模式實戰:自定義SpringIOC(親手實踐)

上一篇&#xff1a;設計模式實戰&#xff1a;自定義SpringIOC&#xff08;理論分析&#xff09; 自定義SpringIOC&#xff08;親手實踐&#xff09; 上一篇文章&#xff0c;我們介紹了SpringIOC容器的核心組件及其作用&#xff0c;下面我們來動手仿寫一個SpringIOC容器&#…

力扣面試150(42/150)

7.28 20. 有效的括號 給定一個只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判斷字符串是否有效。 有效字符串需滿足&#xff1a; 左括號必須用相同類型的右括號閉合。左括號必須以正確的順序閉合。每個右括號都有一…

基于黑馬教程——微服務架構解析(二):雪崩防護+分布式事務

之前的兩篇文章我們介紹了微服務的基礎概念及其服務間通信機制。本篇將深入探討微服務的核心保障&#xff1a;服務保護與分布式事務。一、微服務保護問題描述&#xff1a; 在一個購物車的微服務中&#xff0c;倘若某一項服務&#xff08;服務A&#xff09;同一時刻訪問的數據十…

LeetCode: 429 N叉樹的層序遍歷

題目描述給定一個 N 叉樹&#xff0c;返回其節點值的層序遍歷&#xff08;即從左到右&#xff0c;逐層訪問每一層的所有節點&#xff09;。示例輸入格式&#xff08;層序序列化&#xff09;&#xff1a;輸入示意&#xff1a;1/ | \3 2 4/ \5 6輸出&#xff1a;[[1], [3,2,4…

使用phpstudy極簡快速安裝mysql

使用 phpStudy 極簡快速安裝 MySQL 的完整指南&#xff1a; 一、phpStudy 簡介 phpStudy 是一款 Windows 平臺下的 PHP 環境集成包&#xff0c;包含&#xff1a; Apache/Nginx PHP 5.x-7.x MySQL 5.5-8.0 phpMyAdmin 二、安裝步驟 1. 下載安裝包 訪問官網下載&#xf…

git lfs使用

apt install git lfs 或者下載二進制文件加到環境變量 https://github.com/git-lfs/git-lfs/releases git lfs install git lfs clone huggingface文件路徑 如果訪問不了hugggingface.co用hf-mirror.com替代&#xff0c;國內下載速度還是挺快的 先按照pip install modelscope m…

6、CentOS 9 安裝 Docker

&#x1f433; CentOS 9 安裝 Docker 最全圖文教程&#xff08;含鏡像源優化與常見問題解決&#xff09;標簽&#xff1a;CentOS 9、Docker、容器技術、開發環境、國內鏡像源 適合讀者&#xff1a;后端開發、運維工程師、Linux 初學者&#x1f4cc; 前言 在 CentOS 9 上安裝 Do…