Oracle数据库卡顿如何优化?

*命令行登录:使用 SQLPlus**

*SQLPlus** 是Oracle官方命令行工具,适合服务器环境或远程连接。

步骤 1:配置环境变量

# 加载Oracle环境变量(根据实际安装路径调整)
source /u01/app/oracle/product/19.0.0/dbhome_1/bin/oracle_env.sh
# 或直接写入 ~/.bash_profile
echo 'export ORACLE_HOME=/u01/app/oracle/product/19.0.0/dbhome_1' >> ~/.bash_profile
echo 'export PATH=$ORACLE_HOME/bin:$PATH' >> ~/.bash_profile
source ~/.bash_profile

步骤 2:登录数据库

# 基础登录(需交互输入密码)
sqlplus username/password@hostname:port/service_name
# 推荐方式:隐藏密码(避免泄露)
sqlplus /nolog
SQL> CONNECT username@hostname:port/service_name
Enter password: ********  # 手动输入密码(不显示明文)
# 本地登录(无需网络)
sqlplus / as sysdba        # 以SYSDBA身份登录本地实例(需OS认证)
sqlplus username/password  # 本地非特权用户

常见错误处理

  • ORA-12162: TNS 解析错误
    检查 $ORACLE_HOME/network/admin/tnsnames.ora 配置:

    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = your_host)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)  # 或 SID = orcl
        )
      )
  • ORA-01017: 用户名/密码无效
    确认密码大小写(Oracle密码默认区分大小写),或联系DBA重置密码。

图形界面登录:使用 SQL Developer

Oracle SQL Developer 是官方免费图形工具,适合复杂查询和管理。

步骤 1:安装并启动

  • 下载:Oracle SQL Developer 官网
  • 启动(需Java环境):
    unzip sqldeveloper-*.zip
    cd sqldeveloper
    ./sqldeveloper.sh

步骤 2:创建数据库连接

  1. 点击 “新建连接” 图标(绿色加号)。
  2. 填写参数:
    • 连接名:自定义标识(如 Prod_DB
    • 用户名/密码:数据库账号
    • 连接类型Basic(默认)或 TNS(需配置本地Net Service)
    • 主机名:数据库服务器IP或域名
    • 端口1521(默认)
    • 服务名:数据库全局标识(如 orcl
  3. 点击 “测试” 验证连接,成功后点击 “连接”

安全提示

  • 勾选 “保存密码” 时确保本地环境安全(仅限个人设备)。
  • 生产环境建议通过 SSH隧道 连接(在SQL Developer的“SSH”标签页配置)。

安全最佳实践

  1. 最小权限原则
    • 避免使用 SYSDBA 执行常规操作,为每个用户分配合理权限:
      CREATE USER app_user IDENTIFIED BY "StrongP@ss123";
      GRANT CONNECT, RESOURCE TO app_user;
  2. 密码保护
    • 禁止命令行明文密码:改用 CONNECT 交互输入或使用钱包(Oracle Wallet)。
  3. 网络加密
    • 启用 SQLNET.ENCRYPTION(配置 sqlnet.ora)防止流量嗅探。
  4. 审计日志
    • 开启数据库审计(DBA权限):
      AUDIT CREATE SESSION;  -- 记录所有登录尝试

故障排查要点

  • 监听器问题
    检查监听状态:lsnrctl status,确认服务已注册。
  • 防火墙拦截
    确保Linux防火墙放行数据库端口(默认1521):

    sudo firewall-cmd --zone=public --add-port=1521/tcp --permanent
    sudo firewall-cmd --reload
  • 权限不足
    本地登录需OS认证:将用户加入 dba 组(usermod -aG dba oracle_user)。

引用说明

  • Oracle官方文档:SQL*Plus 入门指南
  • Oracle SQL Developer 使用手册:下载与配置
  • 安全规范参考:Oracle Database Security Guide

重要提示:生产环境操作前备份数据,敏感信息(如密码、IP)需脱敏处理,本文步骤基于Oracle 19c及Linux RHEL 8验证,其他版本可能略有差异。

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

(0)
酷番叔酷番叔
上一篇 2025年7月21日 09:39
下一篇 2025年7月21日 10:15

相关推荐

  • 如何系统性地测试Linux操作系统?核心步骤、方法与实用工具有哪些?

    测试Linux系统是确保其稳定性、性能和安全性的关键环节,涵盖基础功能、性能指标、安全防护及兼容性等多个维度,以下是详细的测试方法和步骤,帮助全面评估Linux系统状态,系统基础功能测试基础功能测试是Linux测试的起点,主要验证核心模块是否正常运行,启动与关机测试检查系统是否能正常启动,通过dmesg查看启动……

    2025年9月8日
    5200
  • Linux如何快速停止音乐播放?

    通过播放器自身控制图形界面播放器(如Rhythmbox、Clementine、Spotify)直接点击播放器界面上的 停止按钮(通常为方形图标),快捷键:空格键:播放/暂停,Ctrl + S 或 Ctrl + X:停止(具体取决于播放器,可在设置中查看快捷键),命令行播放器(如MPlayer、mpv、cmus……

    2025年7月27日
    5900
  • 在Linux操作系统中,如何通过具体命令或程序耗尽磁盘IO性能?

    在Linux系统中,磁盘I/O是影响系统性能的关键因素之一,当磁盘I/O资源被过度消耗时,会导致系统响应缓慢、进程阻塞,甚至服务完全不可用,要理解如何耗尽磁盘I/O,需要从高并发读写操作、不当的I/O调度策略、文件系统特性、磁盘自身性能限制以及进程异常行为等多个维度进行分析,高并发读写操作:瞬间榨干I/O带宽磁……

    2025年10月2日
    3000
  • Linux系统如何新建swap交换空间?

    在Linux系统中,swap(交换空间)作为物理内存的补充,当系统内存不足时,会将部分暂时不用的数据写入swap,从而释放内存供其他进程使用,避免系统因内存耗尽而崩溃,本文将详细介绍如何在Linux系统中新建swap文件,包括完整操作步骤、注意事项及验证方法,检查当前swap状态在新建swap前,需先确认系统是……

    2025年10月7日
    2800
  • 桌面用户怎样通过图形界面设置?

    在Linux系统中将界面语言切换为英文显示,是用户常见的需求,无论是误设了其他语言,还是需要在英文环境下工作,以下提供两种可靠方法(图形界面和终端命令),适用于大多数主流发行版(如Ubuntu、Debian、CentOS、Fedora),操作前请确保拥有管理员权限,打开系统设置点击桌面左上角「Applicati……

    2025年7月30日
    5900

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信