Oracle数据库服务器地址变更与监听配置修改完整指南

一、前言

在企业IT运维中,Oracle数据库服务器地址变更是常见的运维操作。本文将详细介绍如何安全、高效地完成Oracle数据库服务器地址变更及相关的监听配置修改工作,确保数据库服务在迁移后能够正常运行。

二、准备工作

1. 环境检查

  • 确认新旧服务器IP地址(如从192.168.1.135迁移到192.168.1.59)
  • 检查Oracle数据库版本:SELECT * FROM v$version;
  • 确认当前监听状态:lsnrctl status

2. 备份重要文件

bash 复制代码
# 备份监听器配置文件
cp $ORACLE_HOME/network/admin/listener.ora $ORACLE_HOME/network/admin/listener.ora.bak
cp $ORACLE_HOME/network/admin/tnsnames.ora $ORACLE_HOME/network/admin/tnsnames.ora.bak

# 备份spfile(如使用)
CREATE PFILE='/tmp/pfile.ora' FROM SPFILE;

三、服务器地址变更步骤

1. 修改监听器配置(listener.ora)
ora 复制代码
# 原配置
LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.135)(PORT = 1521))
    )
  )

# 修改为
LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.59)(PORT = 1521))
    )
  )
2. 修改local_listener参数
sql 复制代码
-- 检查当前值
SELECT value FROM v$parameter WHERE name = 'local_listener';

-- 修改参数(分步执行更安全)
ALTER SYSTEM SET local_listener='' SCOPE=BOTH;
ALTER SYSTEM SET local_listener='(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.59)(PORT=1521))' SCOPE=BOTH;

-- 强制服务注册
ALTER SYSTEM REGISTER;
3. 更新tnsnames.ora文件
ora 复制代码
# 原配置
ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.135)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )

# 修改为
ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.59)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )

四、验证步骤

1. 监听器状态验证
bash 复制代码
lsnrctl stop
lsnrctl start
lsnrctl status
2. 服务注册验证
bash 复制代码
lsnrctl services
3. 数据库连接测试
bash 复制代码
tnsping ORCL
sqlplus system/password@ORCL

五、常见问题解决方案

1. ORA-12514: TNS监听程序无法识别服务
  • 检查local_listener参数是否正确
  • 确认监听器是否在新IP上运行
  • 检查防火墙设置
2. ORA-02097: 参数修改无效
sql 复制代码
-- 先重置参数再设置
ALTER SYSTEM RESET local_listener SCOPE=SPFILE;
ALTER SYSTEM SET local_listener='(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.59)(PORT=1521))' SCOPE=BOTH;
3. 服务未自动注册
  • 手动执行:ALTER SYSTEM REGISTER;
  • 检查PMON进程是否正常运行
  • 查看警报日志获取详细信息

六、回滚方案

如果变更失败,可按以下步骤回退:

  1. 恢复listener.ora和tnsnames.ora备份
  2. 重置local_listener参数
  3. 重启监听器
  4. 强制服务重新注册

七、总结

Oracle服务器地址变更需要谨慎操作,重点注意:

  1. 提前做好完整备份
  2. 按顺序修改listener.ora、数据库参数和tnsnames.ora
  3. 每步操作后立即验证
  4. 准备完善的回滚方案

通过以上步骤,可以确保Oracle数据库在服务器地址变更后仍能提供稳定的服务。建议在非业务高峰期进行此类变更,并通知相关应用团队配合测试。

相关推荐
Maple_land12 分钟前
Linux进程第五讲:PPID与bash的关联、fork系统调用的原理与实践操作(上)
linux·运维·服务器·centos·bash
Li zlun1 小时前
MySQL 性能监控与安全管理完全指南
数据库·mysql·安全
running thunderbolt1 小时前
项目---网络通信组件JsonRpc
linux·服务器·c语言·开发语言·网络·c++·性能优化
影子24011 小时前
Windows Server2016 服务器安装JDK,一直卡在“应用程序正在为首次使用作准备,请稍候” ,导致jdk安装失败解决方案
运维·服务器·windows·jdk
养生技术人1 小时前
Oracle OCP认证考试题目详解082系列第48题
运维·数据库·sql·oracle·database·开闭原则·ocp
海阳宜家电脑2 小时前
Lazarus使用TSQLQuery更新的一点技巧
数据库·lazarus·tsqlquery
_OP_CHEN2 小时前
Linux 系统编程:(一)从历史演进到 XShell 远程登录实操
linux·运维·服务器·centos·unix·xshell
一條狗2 小时前
学习日报 20251007|深度解析:基于 Guava LoadingCache 的优惠券模板缓存设计与实现
java·oracle·loadingcache
丨我是张先生丨2 小时前
SQLSERVER 查找存储过程中某个变量
数据库
为java加瓦3 小时前
Rust 的类型自动解引用:隐藏在人体工学设计中的魔法
java·服务器·rust