惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

H
Help Net Security
T
ThreatConnect
SecWiki News
SecWiki News
F
Future of Privacy Forum
AWS News Blog
AWS News Blog
C
Cisco Blogs
A
Arctic Wolf
Vercel News
Vercel News
The GitHub Blog
The GitHub Blog
Scott Helme
Scott Helme
V
V2EX
博客园 - 叶小钗
阮一峰的网络日志
阮一峰的网络日志
K
Kaspersky official blog
G
Google Developers Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
P
Privacy International News Feed
C
Cyber Attacks, Cyber Crime and Cyber Security
N
News | PayPal Newsroom
Schneier on Security
Schneier on Security
NISL@THU
NISL@THU
Microsoft Azure Blog
Microsoft Azure Blog
量子位
The Hacker News
The Hacker News
Stack Overflow Blog
Stack Overflow Blog
Security Latest
Security Latest
M
Microsoft Research Blog - Microsoft Research
Google Online Security Blog
Google Online Security Blog
博客园_首页
C
CXSECURITY Database RSS Feed - CXSecurity.com
I
InfoQ
Google DeepMind News
Google DeepMind News
Y
Y Combinator Blog
The Cloudflare Blog
Microsoft Security Blog
Microsoft Security Blog
Martin Fowler
Martin Fowler
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
Troy Hunt's Blog
F
Fox-IT International blog
S
Security @ Cisco Blogs
博客园 - 司徒正美
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
C
Comments on: Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
L
LINUX DO - 最新话题
GbyAI
GbyAI
Project Zero
Project Zero
腾讯CDC
T
Tailwind CSS Blog

DEV Community

Stop Making Your AI Chatbot Slower: Streaming Responses with Spring AI and Server-Sent Events Annotations in Spring Boot What is the Model Context Protocol (MCP)? Gemini CLI Skills: Teaching Your Terminal Agent How to Think 🧠 What the Heck is an API? FairLens AI: An Intelligent Dashboard for Automated Bias Auditing RAG vs Fine-Tuning- Choosing Right Strategy for Modern AI Applications AI Metrics Decoded: From Parameters to TOPS I made git merge finish itself — in VS Code, in my terminal, and in CI You just can’t miss this… Redis Essentials: Architecture, Caching, and Setup Docker with AI: A Practical Guide to Running LLMs, Agents and MCP Design to Code #5: Using AI to Build a Design System Analyzing 1,000 Engineering Problems Through GitHub Data Open Graph protocol: canonical reference How a 400-Engineer SaaS Company Cut PR-to-Production from 4.2 Days to 6.4 Hours with Claude Code Multi-Agent DevOps 💬 Embedded AI Chatbots vs Popup Bubbles — Which One Creates Better Engagement? Bajándole todos los minutos posibles al CI del backend con mas de 1000 tests Harness Engineering: Stop Re-Prompting Your Coding Agent Every Session HTML meta referrer: canonical reference AWS MCP Server Just Gave AI Agents Your Cloud Keys — Here's Why That Should Worry You Announcing the Trust Identity Protocol (TIP): HTTPS for the AI Era We built the feature in two days. Making it reliable took two weeks. LuisCore /for-agents.json — agent bootstrap — daily syndication · 2026-05-26 A Curious Journey Into Reverse Engineering an AI-Generated Python .exe Part 2: Enterprise Decision Intelligence Architecture: AI Governance, Threshold Policy Engines, and Operational AI Systems I will continue using Devise with Rails 8! The Developer's Guide to Picking the Right AI Code Model in 2026 (I Spent $500 So You Don’t Have To) 30 Kubernetes Tasks Every CKA Candidate Should Practice Before Exam Day Why Some Websites Feel Instantly Better to Use Advanced React Patterns I Wish I Knew 5 Years Ago ¿Cómo optimizar algoritmos en arreglos y listas con la técnica de dos punteros? I scanned 8 popular open source repos with one command. Here's what I found. mcp-probe v1.6.0: Stricter GitHub Actions checks for MCP CI gates How we connect two strangers' webcams fast (and keep the TURN bill small) LLM Agents Are Now Finding Zero-Days: How AI is Autonomously Rewriting the Rules of Vulnerability Research Minimal Code Doesn’t Mean Stable Code How I manage 40+ skills across Claude Code, Codex, and .agents folders Hardening Stealth Browser Fingerprint Integrity and State Persistence Quick Tip: Benchmarking Multimodal APIs in Under 10 Minutes How I Slashed My AI API Bill by 92% in 2026 — A Cost Optimizer's Speed Benchmark Guide How I Slashed My AI API Bill by 95% — A Practical Guide for 2026 A Go outbox library that runs inside your own DB transaction How I Built a Credit Optimizer That Saves 30-75% on AI Agent Costs (Open Architecture) The Missing POP: How I Ported a Yul Contract to Huff by Reading Every Opcode The Moment the Config Parser Became the Bottleneck Churn Tool Stack by Revenue Stage ($5K to $50K+) What I Learned Exploring AI-Generated 3D: A Hands-On Tour of Meshy, Tripo, and Three.js Day 15 - Software Composition Analysis(SCA) Contributing Upstream Instead of Forking: My grape-swagger-rails Story Behind The Badge: How We Built 2,000 Hackable Badges For Temporal Replay Access Control Doesn't Scale Linearly -- Part 3 33x faster than Rust: Why I stopped waiting for my compiler and built my own. I Built My First Production AWS Project as a Career Changer Why Detecting PII Matters More Than Ever JSON Schema in 10 Minutes — Validation, Types & Real Examples Python Tasks How I Started My Cybersecurity Journey as an SQA Engineer 🔐 Why "fancy fonts" in Discord and Instagram bios turn into boxes ☁️ GKE private cluster setup — common mistakes and how to avoid them I Thought a Username Didn’t Matter… Until I Saw How Much People Care About It Claude for Small Business: 382K Day-One Buyer's Guide I Built a Diagnostic Toolkit for PyTorch Because I Was Tired of Guessing Why Models Fail How I Built an AI-Powered Incident RCA Platform with LangGraph and RAG The Paywall Was a Painted Door Sonnet hallucinated. My agent stored it as fact. How React-Style Time-Slicing Keeps UIs Responsive 这个 Princeton 开源项目让 AI 自己修 Bug,19K Stars 但 90% 的人只用了 1% 功能 🔥 SWE-agent's 5 Hidden Uses Nobody Told You About 🔥 Decompiling Serial Number U-36: Python TERCOM Reconstruction, Cryptographic Logistical Forensics, and Swarm Consensus Fault Tolerance Microservices Patterns You Cannot Outrun a Wave I Fired My Entire Node.js Stack — Rust Rebuilt It in 3 Weeks (The Ugly Truth) BoxAgnts Introduction (2) — AI Agent Toolbox Cursor 3 ships parallel AI agents. Here is the multi-agent workflow that actually works. Prisma-7 A Complete Beginners Guide (With Free Cloud Database!) Akses HDD Rumah dari Laptop Kantor Pakai Tailscale + SMB (Tanpa VPN Ribet) Content Pipeline in MonoGame: Why I Don't Use It Debug Log #1 — The Pipeline That Looked Broken Data Structures in JavaScript: When to Use What (2026) BGP Route Flap Damping: A Solution or a New Problem? First look at AWS DevOps Agent The Next Big “Cult App” Probably Isn’t Another Social Media Platform From Template to Production-Shaped: An AI-Native Dev Flow for Go Side Projects Idempotency Keys: The API Pattern That Saves You From Duplicate Payments and Phantom Records Everyone's Building Jarvis. Nobody's Even Close. The Moment the Jaeger Tracer Exhausted Itself and What We Switched To How to Fix Tool-Use Loops in Autonomous Coding Agents Months of self-testing: Citations shine, other features remain unproven. Claude Code for Canary Deployments: How I Ship to 1% of Users Before Breaking Everything Your recurring scraper is re-downloading data that didn't change. Here's the 15-line fix (conditional GET) 20 Years of GPUs in Numbers: How FLOPS & TDP Grew, and Who Led the NVIDIA vs AMD Race (open dataset, 13.5k GPUs) Espressif Reveals CoreBoard and Korvo Dev Kits for ESP32-S31 Composable Abstraction Layer: o pattern que faltava entre Pinia e seus componentes Vue Your GitHub Actions Logs Are Leaking LLM Keys and Your SIEM Isn't Catching It Solving Complex Logic with Claude and Research Papers Building TheEpicBook: A Deep Dive into a Node.js Monolithic Web Application Haber yazilimi, haber scripti, haber sistemi: ayni urun, uc ayri arama niyeti Predicting Blood Glucose Fluctuations: Building a Transformer-based CGM Forecaster with PyTorch & InfluxDB Pre-task hooks: the one-line wire-up that gives your Hono agent shared memory
ORA-00215 오류 원인과 해결 방법 완벽 가이드
umzzil nng · 2026-05-26 · via DEV Community

umzzil nng

ORA-00215란?

ORA-00215 에러는 Oracle 데이터베이스가 시작(STARTUP) 또는 마운트(MOUNT) 과정에서 유효한 컨트롤 파일(Control File)을 단 하나도 찾지 못했을 때 발생하는 치명적인 에러입니다. 컨트롤 파일은 데이터베이스의 물리적 구조 정보(데이터 파일 위치, 리두 로그 파일 위치, SCN 정보 등)를 담고 있는 핵심 바이너리 파일로, 이 파일 없이는 Oracle 인스턴스가 데이터베이스를 마운트하거나 오픈할 수 없습니다. 주로 초기화 파라미터 파일(SPFILE 또는 PFILE)의 CONTROL_FILES 파라미터 설정이 잘못되었거나, 실제 파일이 존재하지 않을 때 이 에러가 트리거됩니다.


주요 발생 원인

1. CONTROL_FILES 파라미터 경로 오기재 또는 파일 누락

가장 빈번한 원인으로, init.ora 또는 SPFILE 내의 CONTROL_FILES 파라미터에 지정된 경로가 실제 파일 시스템상의 경로와 일치하지 않을 때 발생합니다. 스토리지 마이그레이션, 서버 이전, 또는 단순한 오타로 인해 경로가 틀리게 설정된 경우가 대표적이며, Oracle은 지정된 경로에서 파일을 찾지 못하면 즉시 이 에러를 반환합니다.

2. 컨트롤 파일 물리적 삭제 또는 손상

운영 중 실수로 컨트롤 파일이 OS 레벨에서 삭제되거나, 디스크 장애·파일 시스템 오류로 인해 파일이 물리적으로 손상(corrupt)된 경우입니다. Oracle은 기본적으로 다중화(Multiplexing)된 컨트롤 파일을 권장하는데, 다중화가 되어 있지 않은 단일 구성 환경에서 이런 사고가 발생하면 복구가 매우 까다로워집니다. 파일이 0바이트로 비워지거나 부분적으로 덮어씌워진 경우도 동일한 에러를 유발합니다.

3. 데이터베이스 재생성(RECREATE) 또는 복제(CLONE) 후 파라미터 미수정

운영 데이터베이스를 복제하여 개발 또는 테스트 환경을 구성할 때, 원본 SPFILE을 그대로 복사하면 CONTROL_FILES 파라미터가 원본 경로를 그대로 가리키게 됩니다. 새로운 환경의 디렉토리 구조가 다르거나 컨트롤 파일이 아직 생성되지 않은 상태에서 인스턴스를 기동하면 ORA-00215가 발생합니다. 특히 RMAN을 활용한 Duplicate 작업 후 수동으로 파라미터를 조정하다 실수가 발생하는 경우가 많습니다.


해결 방법

원인 1 해결: CONTROL_FILES 파라미터 경로 확인 및 수정

먼저 현재 파라미터 파일이 어떤 경로를 참조하고 있는지 확인합니다. SPFILE 기반이라면 STARTUP NOMOUNT 이전 단계에서 PFILE로 덤프하거나, OS에서 strings 명령으로 내용을 확인합니다.

-- PFILE을 통해 NOMOUNT 상태로 기동 후 파라미터 확인
STARTUP NOMOUNT PFILE='/u01/app/oracle/admin/ORCL/pfile/init.ora';

-- 현재 인식된 CONTROL_FILES 파라미터 값 확인
SHOW PARAMETER CONTROL_FILES;

-- 또는 V$PARAMETER 뷰에서 확인
SELECT NAME, VALUE
FROM   V$PARAMETER
WHERE  NAME = 'control_files';

Enter fullscreen mode Exit fullscreen mode

파라미터 경로가 잘못된 경우, PFILE을 직접 편집하거나 SPFILE을 수정합니다.

-- PFILE 직접 수정 후 재기동 (vi 편집기 등으로 수정)
-- init.ora 예시 내용:
-- control_files = ('/u01/app/oracle/oradata/ORCL/control01.ctl',
--                  '/u02/app/oracle/oradata/ORCL/control02.ctl')

-- SPFILE 수정 시 (NOMOUNT 상태에서 가능)
ALTER SYSTEM SET CONTROL_FILES=
  '/u01/app/oracle/oradata/ORCL/control01.ctl',
  '/u02/app/oracle/oradata/ORCL/control02.ctl'
SCOPE=SPFILE;

-- 이후 재기동
SHUTDOWN ABORT;
STARTUP;

Enter fullscreen mode Exit fullscreen mode


원인 2 해결: 컨트롤 파일 복구

다중화된 컨트롤 파일 중 일부만 손상된 경우, 정상적인 컨트롤 파일을 손상된 위치로 복사합니다.

# OS 레벨에서 정상 컨트롤 파일 복사 (DB가 정지된 상태)
cp /u01/app/oracle/oradata/ORCL/control01.ctl \
   /u02/app/oracle/oradata/ORCL/control02.ctl

Enter fullscreen mode Exit fullscreen mode

-- 복사 후 데이터베이스 재기동
STARTUP;

-- 기동 후 컨트롤 파일 상태 확인
SELECT NAME, STATUS FROM V$CONTROLFILE;

Enter fullscreen mode Exit fullscreen mode

모든 컨트롤 파일이 소실된 경우 RMAN 백업을 활용하여 복구합니다.

-- RMAN을 통한 컨트롤 파일 복구
RMAN TARGET /

-- 자동 백업된 컨트롤 파일 복구
RESTORE CONTROLFILE FROM AUTOBACKUP;

-- 복구 후 MOUNT 상태로 전환
ALTER DATABASE MOUNT;

-- 데이터베이스 불완전 복구 수행 (필요 시)
RECOVER DATABASE USING BACKUP CONTROLFILE UNTIL CANCEL;

-- RESETLOGS로 오픈
ALTER DATABASE OPEN RESETLOGS;

Enter fullscreen mode Exit fullscreen mode

컨트롤 파일 백업조차 없는 최악의 시나리오에서는 CREATE CONTROLFILE 명령으로 재생성해야 합니다.

-- 컨트롤 파일 재생성 (데이터 파일 및 리두 로그 파일 목록 사전 파악 필요)
-- alert log 또는 기존 trace 파일에서 목록 확인 후 실행
STARTUP NOMOUNT;

CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS NOARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 '/u01/app/oracle/oradata/ORCL/redo01.log' SIZE 50M,
  GROUP 2 '/u01/app/oracle/oradata/ORCL/redo02.log' SIZE 50M,
  GROUP 3 '/u01/app/oracle/oradata/ORCL/redo03.log' SIZE 50M
DATAFILE
  '/u01/app/oracle/oradata/ORCL/system01.dbf',
  '/u01/app/oracle/oradata/ORCL/sysaux01.dbf',
  '/u01/app/oracle/oradata/ORCL/undotbs01.dbf',
  '/u01/app/oracle/oradata/ORCL/users01.dbf'
CHARACTER SET AL32UTF8;

-- 이후 복구 및 오픈
RECOVER DATABASE;
ALTER DATABASE OPEN;

Enter fullscreen mode Exit fullscreen mode

⚠️ 주의: CREATE CONTROLFILE 실행 전 반드시 기존 데이터 파일과 리두 로그 파일의 정확한 경로와 목록을 파악해야 합니다. 잘못된 정보로 생성 시 추가적인 데이터 손실이 발생할 수 있습니다.


원인 3 해결: 복제 환경 파라미터 정정

-- NOMOUNT 상태에서 SPFILE을 PFILE로 덤프
CREATE PFILE='/tmp/init_new.ora' FROM SPFILE;

-- OS에서 init_new.ora 편집 후 CONTROL_FILES 경로 수정
-- 수정된 PFILE로 기동
STARTUP NOMOUNT PFILE='/tmp/init_new.ora';

-- 정상 기동 확인 후 SPFILE 재생성
CREATE SPFILE FROM PFILE='/tmp/init_new.ora';

-- 최종 재기동
SHUTDOWN IMMEDIATE;
STARTUP;

Enter fullscreen mode Exit fullscreen mode


예방 방법

1. 컨트롤 파일 다중화(Multiplexing) 및 자동 백업 설정

컨트롤 파일은 반드시 서로 다른 디스크(또는 ASM 디스크 그룹)에 최소 2~3개 이상 다중화하여 단일 장애 지점(SPOF)을 제거해야 합니다. 또한 RMAN의 CONFIGURE CONTROLFILE AUTOBACKUP ON 설정을 통해 모든 백업 작업 및 구조 변경 시 컨트롤 파일이 자동으로 백업되도록 구성하면, 재해 발생 시 신속한 복구가 가능합니다.

-- 컨트롤 파일 다중화 확인
SELECT NAME FROM V$CONTROLFILE;

-- RMAN 컨트롤 파일 자동 백업 활성화
RMAN TARGET /
CONFIGURE CONTROLFILE AUTOBACKUP ON;
CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO '/backup/rman/%F';

-- 현재 RMAN 설정 확인
SHOW ALL;

Enter fullscreen mode Exit fullscreen mode

2. 정기적인 컨트롤 파일 트레이스(Trace) 덤프 생성 및 보관

ALTER DATABASE BACKUP CONTROLFILE TO TRACE 명령을 주기적으로 실행하여 CREATE CONTROLFILE 스크립트가 포함된 트레이스 파일을 생성하고 안전한 위치에 보관하는 습관을 가져야 합니다. 이 스크립트는 모든 컨트롤 파일이 소실되는 극단적인 상황에서 데이터베이스 구조를 재구성하는 마지막 보루가 됩니다.

-- 컨트롤 파일 내용을 트레이스 파일로 덤프
ALTER DATABASE BACKUP CONTROLFILE TO TRACE;

-- 특정 파일로 직접 덤프 (Oracle 10g 이상)
ALTER DATABASE BACKUP CONTROLFILE TO TRACE AS '/backup/scripts/controlfile_script.sql' REUSE;

-- 이진 형태로도 별도 백업
ALTER DATABASE BACKUP CONTROLFILE TO '/backup/controlfile/control_backup.ctl' REUSE;

Enter fullscreen mode Exit fullscreen mode


관련 에러

  • ORA-00202: control file: '%s' — 특정 컨트롤 파일을 열거나 읽는 과정에서 발생하는 에러로, ORA-00215와 함께 출력되는 경우가 많습니다. 파일 권한(Permission) 문제나 파일 손상 시 주로 나타납니다.
  • ORA-00205: error in identifying control file — 컨트롤 파일을 식별하는 과정에서 발생하며, 파일이 존재하지만 내용이 유효하지 않거나 다른 데이터베이스의 컨트롤 파일이 잘못 배치된 경우에 발생합니다.
  • ORA-00206: error in writing (block %s, # blocks %s) of control file — 컨트롤 파일 쓰기 작업 실패 시 발생하며, 디스크 용량 부족이나 I/O 오류와 연관됩니다.
  • ORA-00210: cannot open the specified control file — 지정된 컨트롤 파일을 오픈할 수 없을 때 발생하며, OS 파일 권한 또는 경로 오류와 관련됩니다. ORA-00215 발생 전 선행 에러로 alert log에 함께 기록되는 경우가 흔합니다.