如何修改RAC数据库名_NID工具在集群环境下的改名步骤

RAC环境改数据库名必须停所有实例,否则触发控制文件不一致和ORA-01102错误;需用srvctl stop database停库,nid命令须同时指定DBNAME和SETNAME=Y,之后同步修改参数文件、OCR、监听及ASM路径。rac环境用nid改数据库名前必须停掉所有实例在rac中直接对一个节点执行nid,其他节点还在跑,会触发控制文件不一致、数据文件被占用等错误,nid大概率失败并报ora-01102: cannot mount database in exclusive mode。这不是权限或路径问题,是rac本质决定的------nid必须独占访问所有数据文件和控制文件。实操建议:用srvctl stop database -d <db_name>停整个数据库,不是只停单个实例确认所有实例都已关闭:ps -ef | grep pmon 应无对应实例进程检查OCR中数据库状态:crsctl stat res -t | grep -A 2 <db_name>,确保显示OFFLINE别跳过这步去"试一下单节点",失败后可能留下损坏的控制文件头nid命令里SETNAME和DBNAME参数的区别DBNAME改的是数据字典里记录的数据库名(vdatabase.name),SETNAME改的是数据库唯一标识符(dbid不变,但name和db_unique_name都会被更新)。RAC环境下必须同时设两者,否则启动时报ORA-01103: database name 'OLD' in control file is not 'NEW'。常见错误现象:只改DBNAME,没加SETNAME=Y,后续startup mount就卡住。实操建议:完整命令示例:nid TARGET=/ DBNAME=newdb SETNAME=YTARGET=/表示用当前连接的实例(需已shutdown immediate),不能写具体用户名密码执行后会提示"Database name changed to NEWDB",但此时只是数据文件头和控制文件里的名字变了,还没生效如果中途Ctrl+C中断,别重试------先用strings ORACLE_HOME/dbs/control01.ctl | head -20确认是否残留旧名,再决定是否恢复控制文件改完名后RAC启动失败:控制文件路径、参数文件、OCR没同步nid不碰任何配置文件,它只改数据文件和控制文件内部字段。所以即使nid成功,RAC启动时仍会因找不到控制文件、参数文件里还是旧db_name、或者OCR注册信息未更新而失败。 橙篇 百度文库发布的一款综合性AI创作工具

相关推荐
aXin_ya2 小时前
Redis 高级篇(最佳实践)
数据库·redis·缓存
zhangchaoxies2 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
Luca_kill2 小时前
MCP数据采集革命:从传统爬虫到智能代理的技术进化
爬虫·python·ai·数据采集·mcp·webscraping·集蜂云
zhangchaoxies2 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
霖霖总总2 小时前
[Redis小技巧32]Redis分布式锁的至暗时刻:从原理演进到时钟跳跃的终极博弈
数据库·redis·分布式
ZC跨境爬虫3 小时前
Scrapy分布式爬虫(单机模拟多节点):豆瓣Top250项目设置与数据流全解析
分布式·爬虫·python·scrapy
sg_knight3 小时前
设计模式实战:命令模式(Command)
python·设计模式·命令模式
石榴树下的七彩鱼3 小时前
图片修复 API 接入实战:网站如何自动去除图片水印(Python / PHP / C# 示例)
图像处理·后端·python·c#·php·api·图片去水印
Polar__Star3 小时前
C#怎么操作Chart图表控件 C#如何用WinForms Chart控件绑定数据绘制统计图表【控件】
jvm·数据库·python