解决ORA-12514,SQLPlus连接localhost:1521失败?

启动Oracle数据库服务

切换至Oracle用户

su - oracle  # 必须使用Oracle安装账户

启动监听器(Listener)

lsnrctl start  # 启动监听服务
lsnrctl status # 验证状态(显示"STATUS=READY"即成功)

启动数据库实例

sqlplus / as sysdba  # 以DBA身份登录SQL*Plus
SQL> STARTUP;        # 启动数据库实例
SQL> SELECT status FROM v$instance;  # 验证状态(返回"OPEN"即成功)

设置开机自启(可选)

sudo systemctl enable oracle-rdbms.service  # 适用于配置了Systemd的系统

连接Oracle数据库的常用方法

*命令行工具(SQLPlus)**

sqlplus username/password@hostname:port/service_name```
#### 2. **图形化工具(推荐)**
- **Oracle SQL Developer**  
  下载地址:[Oracle官网](https://www.oracle.com/database/sqldeveloper/)  
  配置步骤:  
  1. 输入主机名、端口(默认1521)、服务名(如ORCLCDB)  
  2. 填写用户名/密码  
  3. 测试连接 → 保存
- **DBeaver**  
  开源工具,支持多数据库([官网下载](https://dbeaver.io/))
#### 3. **通过Python脚本连接**
```python
import cx_Oracle
conn = cx_Oracle.connect('user', 'password', 'host:port/service_name')
cursor = conn.cursor()
cursor.execute("SELECT * FROM dual")
print(cursor.fetchone())

常见问题解决

监听器启动失败

  • 原因:端口冲突或配置错误
  • 解决
    lsnrctl stop          # 停止监听
    vi $ORACLE_HOME/network/admin/listener.ora  # 检查端口(默认1521)
    lsnrctl start         # 重新启动

数据库无法OPEN

  • 错误ORA-01081: cannot start already-running instance
    SQL> SHUTDOWN IMMEDIATE;  # 先关闭实例
    SQL> STARTUP;             # 重新启动
  • 错误ORA-01157: cannot identify/lock data file
    检查数据文件路径:

    SQL> SELECT name FROM v$datafile;  # 验证文件是否存在

连接超时

  • 检查防火墙:
    sudo firewall-cmd --list-ports | grep 1521  # 查看端口开放
    sudo firewall-cmd --add-port=1521/tcp --permanent  # 开放端口
  • 验证服务名:
    tnsping ORCLCDB  # 测试服务名解析

安全注意事项

  1. 最小权限原则:避免使用sysdba执行常规操作。
  2. 定期备份
    RMAN> BACKUP DATABASE PLUS ARCHIVELOG;  # 使用RMAN工具
  3. 更新补丁:定期安装Oracle Critical Patch Updates(CPU)。

引用说明

  • Oracle官方文档:Database Administrator’s Guide
  • Linux服务管理:Systemd手册
  • 连接工具参考:SQL Developer教程

重要提示:操作前确保已正确安装Oracle数据库(包括环境变量ORACLE_HOMEPATH配置),生产环境建议由专业DBA执行关键操作。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4773.html

(0)
酷番叔酷番叔
上一篇 2025年6月17日 13:44
下一篇 2025年6月17日 14:08

相关推荐

  • Ubuntu升级24.04卡住?速解方案

    在Linux系统中,使用telnet测试服务器端口连通性是网络故障排查的常用手段,以下为详细操作指南,所有步骤均基于主流Linux发行版(如Ubuntu、CentOS)验证,确保专业性和可靠性:Telnet的作用与原理功能:telnet是TCP/IP协议族中的终端仿真协议,通过建立TCP连接测试目标服务器的端口……

    2025年7月1日
    5400
  • 如何快速安装linuxdeployqt打包Linux应用?

    核心打包工具推荐使用 linuxdeployqt(推荐)原理:自动收集Qt依赖库、生成桌面文件并创建AppDir目录(符合Linux桌面标准),步骤:chmod +x linuxdeployqt-continuous-x86_64.AppImage# 打包步骤mkdir MyAppDircp myapp MyA……

    2025年8月5日
    3600
  • Linux如何查看系统是32位还是64位?

    在Linux系统中,系统位数(32位或64位)是指CPU架构和操作系统支持的数据处理宽度,直接影响内存寻址能力、软件兼容性和系统性能,正确查看系统位数对安装软件、编译程序或排查问题至关重要,以下是Linux中查看系统位数的多种方法,涵盖命令行工具、系统文件及包管理器等场景,结合原理、操作步骤和示例说明,使用un……

    2025年9月28日
    1800
  • 如何制作优盘Linux启动盘?操作步骤与方法有哪些?

    制作优盘Linux(也称为“Live USB”)是一种便携式的Linux系统部署方式,用户可以通过优盘启动完整的Linux环境,无需安装到硬盘即可体验系统、进行数据恢复或随身携带个人工作环境,以下是详细的制作步骤和注意事项,涵盖工具准备、系统选择、制作流程及后续使用,准备工作在开始制作前,需确保以下材料和工具准……

    2025年10月4日
    800
  • linux如何追踪软连接

    使用ls -l命令查看软连接指向的目标,或用readlink直接显示

    2025年8月9日
    3300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信