码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • docker、docker-compose部署oracle,plsql连接远程oracle


    一、docker部署oracle

    1. 下载镜像并启动容器

    # 拉取阿里oracle_11g的镜像
      docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
    # 创建容器并启动
      docker run -d -p 1521:1521 --name oracle11g registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

    2. 进入oracle容器内修改配置


    # 进入容器内配置(以root用户进入)

    docker exec -it -u root oracle11g bash


    # 修改oracle环境变量
      vi /etc/profile
    编辑追加下面3行

    1. export ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_2
    2. export ORACLE_SID=helowin
    3. export PATH=$ORACLE_HOME/bin:$PATH

    保存编辑  esc shift+q   wq 回车

    修改profile后使它立即生效的命令
      source /etc/profile 或 . /etc/profile

    # 创建软链
      ln -s $ORACLE_HOME/bin/sqlplus /usr/bin

    3. 修改用户密码、创建用户

    # 切回oracle用户并修改sys、system用户密码
      sqlplus / as sysdba(约等于sqlplus /nolog +  conn /as sysdba)

      alter user system identified by system;
      alter user sys identified by sys;
      // 创建用户  
      create user testUsr identified by 123;
      // 并给用户赋予权限
      grant connect,resource,dba to testUsr;
    若出现database not open, 进入SQL命令行去 alter database mount;alter database open;

    刷新刚才改密码操作
    ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED

    4. 验证端口

    可以去其他服务器使用telnet验证

    telnet oracle所在宿主机ip 1521

    ---- 至此已经部署完了,看plsql配置 ----
    数据库状态的指令: 在sql命令行下 startup、 shutdown指令
    监控状态:             oracle用户下 lsnrctl status

    一图流:

     

    二、docker-compose部署oracle

    TODO

    三、plsql连接远程oracle

    注:连接一、二里docker部署的oracle


    1. 下载plsql和instant_client,最好版本匹配或高一点点(百度找链接)


    2. 配置plsql


    plsql的工具->首选项->连接,里配置主目录和oci库
    oracle主目录:
    D:\****\instantclient_12_2
    oci库:
    D:\****\instantclient_12_2\oci.dll

    3 修改instant_client的tnsnames.ora


    在instant_client的目录里找network\admin\tnsnames.ora(没有就自己创建)
    D:\software\instantclient_12_2\network\admin

    docker_oracle =
     (DESCRIPTION =
       (ADDRESS_LIST =
         (ADDRESS = (PROTOCOL = TCP)(HOST = oracle容器ip)(PORT =1521))
       )
       (CONNECT_DATA =
         (SERVICE_NAME = helowinXDB)
       )
    )

    service_name对应oracle容器里的服务名,可以在进入容器内oracle用户下lsnrctl status选一个

    4. plsql连接登录

    四、出现的问题

    1. 启动容器时出现WARNING: IPv4 forwarding is disabled. Networking will not work.
    答案:https://blog.csdn.net/cljdsc/article/details/115207336

    2. 不是叫你修改oracle容器里的tnsnames.ora和listener.ora。

    看了些资料修改了导致无法连接

    参考资料:

    Docker 拉取 oracle 11g镜像配置_荡漾-的博客-CSDN博客_docker 访问oracle

    docker警告:WARNING: IPv4 forwarding is disabled. Networking will not work._杰哥的技术杂货铺的博客-CSDN博客

  • 相关阅读:
    springboot基于Java Web的华家医疗器械商城设计与实现毕业设计源码261620
    串口转HID键盘鼠标芯片沁恒微电子CH9329
    【计算机网络】TCP协议
    Java物业管理系统+数据库应用程序开发[JavaSE+JDBC+idea控制台+MySQL]
    Windows11 配置Cuda cuDNN Pytorch环境
    pytorch中的while for 循环 导出onnx的问题
    Java ReentrantLock锁源码走读
    jenkins、ant、selenium、testng搭建自动化测试框架
    【AGC】如何快速部署Serverless抽奖模板
    Java数据结构算法:算法的空间复杂度分析
  • 原文地址:https://blog.csdn.net/qq_35911589/article/details/126949735
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号