Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
无法连接到docker容器外部的oracle_Oracle_Docker_Oracle Sqldeveloper_Docker For Windows_Oracle19c - Fatal编程技术网

无法连接到docker容器外部的oracle

无法连接到docker容器外部的oracle,oracle,docker,oracle-sqldeveloper,docker-for-windows,oracle19c,Oracle,Docker,Oracle Sqldeveloper,Docker For Windows,Oracle19c,我已经为oracle 19c创建了一个映像。我已使用以下命令启动容器 docker-run-name oracledb-d-p 1527:1521-p 5700:5500-e ORACLE\u PWD=password1-e ORACLE\u CHARACTERSET=AL32UTF8-v/d/docker-code/ORACLE-data-ORACLE/database:19.3.0-ee 创建容器后,我可以登录容器。我能够在容器内连接以下命令 ERROR: ORA-12170: TNS:Co

我已经为oracle 19c创建了一个映像。我已使用以下命令启动容器

docker-run-name oracledb-d-p 1527:1521-p 5700:5500-e ORACLE\u PWD=password1-e ORACLE\u CHARACTERSET=AL32UTF8-v/d/docker-code/ORACLE-data-ORACLE/database:19.3.0-ee

创建容器后,我可以登录容器。我能够在容器内连接以下命令

ERROR:
ORA-12170: TNS:Connect timeout occurred
sqlplus系统/password1@172.17.0.2:1527/ORCLCDB

在容器外部,通过cmd,我无法连接到该oracle实例

注意:我已经在windows计算机上的默认端口1521安装了oracle。

listener.ora

LISTENER =
(DESCRIPTION_LIST =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
    (ADDRESS = (PROTOCOL = TCP)(HOST = 172.17.0.2)(PORT = 1527))
  )
)

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = ORCLCDB)
      (ORACLE_HOME = /opt/oracle/product/19c/dbhome_1)
      (SID_NAME = ORCLCDB)
    )
   )


DEDICATED_THROUGH_BROKER_LISTENER=OFF
DIAG_ADR_ENABLED = off
ORCLCDB=172.17.0.2:1527/ORCLCDB
ORCLPDB1=
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 172.17.0.2)(PORT = 1527))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = ORCLPDB1)
    )
  )
tnsnames.ora

LISTENER =
(DESCRIPTION_LIST =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
    (ADDRESS = (PROTOCOL = TCP)(HOST = 172.17.0.2)(PORT = 1527))
  )
)

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = ORCLCDB)
      (ORACLE_HOME = /opt/oracle/product/19c/dbhome_1)
      (SID_NAME = ORCLCDB)
    )
   )


DEDICATED_THROUGH_BROKER_LISTENER=OFF
DIAG_ADR_ENABLED = off
ORCLCDB=172.17.0.2:1527/ORCLCDB
ORCLPDB1=
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 172.17.0.2)(PORT = 1527))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = ORCLPDB1)
    )
  )
我无法从SQL Developer或CMD连接。当我试图访问docker容器外部时,我能够得到超时错误

ERROR:
ORA-12170: TNS:Connect timeout occurred
请指导我解决这个问题


提前感谢。

确保所有容器网络接口都在侦听数据库通信,因此
0.0.0
。不要硬编码docker网桥网络地址(172..),因为该地址将在容器启动时分配。只需使用容器本地的默认端口1521即可。此端口-1521-是容器的本地端口,不暴露于主机操作系统。您将此端口发布到主机操作系统,在主机操作系统中您可以决定使用哪个端口,因此
-p 1522:1521

LISTENER =
(DESCRIPTION_LIST =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
    (ADDRESS = (PROTOCOL = TCP)(HOST = 0.0.0.0)(PORT = 1521))
  )
)
现在,您可以通过发出以下命令在主机操作系统上启动容器:

docker run --name oracledb -d -p 1522:1521 -p 5700:5500 -e ORACLE_PWD=password1 -e ORACLE_CHARACTERSET=AL32UTF8 -v /d/docker-code/oracle-data oracle/database:19.3.0-ee
现在应该可以了

sqlplus system/password1@localhost:1522/ORCLCDB
小费。现在,您可以从Docker Hub中提取Oracle XE 18c。如果仍然无法使用已构建的映像进行连接,我建议您测试此映像

docker run -d -p 1522:1521 --rm -e ORACLE_PASSWORD=Welcome_1 -v oracle-volume:/opt/oracle/oradata gvenzl/oracle-xe

docker container ls
CONTAINER ID   IMAGE              COMMAND                  CREATED             STATUS             PORTS                    NAMES
97ce7cd3d7ca   gvenzl/oracle-xe   "container-entrypoin…"   About an hour ago   Up About an hour   0.0.0.0:1522->1521/tcp   elegant_borg

sqlplus system/Welcome_1@localhost:1522/XE

SQL*Plus: Release 19.0.0.0.0 - Production on Mon May 31 10:21:18 2021
Version 19.8.0.0.0

Copyright (c) 1982, 2020, Oracle.  All rights reserved.

Last Successful login time: Mon May 31 2021 10:20:19 +02:00

Connected to:
Oracle Database 18c Express Edition Release 18.0.0.0.0 - Production
Version 18.4.0.0.0

system@XE> set echo on
system@XE> @pdbs
system@XE>
system@XE> col con_id format 999
system@XE> col dbid format 99999999999999999
system@XE> col name format a30
system@XE> col open_mode format a10
system@XE> col open_time format a38
system@XE>
system@XE> select p1.con_id, p1.dbid, p1.name, p2.status, p1.open_mode, p1.open_time
  2  from
  3    v$pdbs p1 join dba_pdbs p2 on (p1.con_id = p2.con_id);

CON_ID               DBID NAME                           STATUS     OPEN_MODE  OPEN_TIME
------ ------------------ ------------------------------ ---------- ---------- --------------------------------------
     2         1957965804 PDB$SEED                       NORMAL     READ ONLY  31.05.2021 06:54:00474 AM +00:00
     3         4267393270 XEPDB1                         NORMAL     READ WRITE 31.05.2021 06:54:01229 AM +00:00

2 rows selected.

system@XE>

祝你好运

您是否在Windows网络IP中添加了
172.17.0.2
?我的意思是你能ping
172.17.0.2
172.17.0.2
我不能ping这个ip。我没有在Windows网络中添加IP。如何添加它?以管理员身份运行命令提示符程序,然后运行
ipconfig
查看它是否存在。我对Windows中的Docker不太熟悉,但在Linux中它增加了。您的容器端口是1527,因此:-p[host\u port]:[container\u port]->-p 1521:1527。但是既然1521已经被采用了,make是另外一个东西->-p 1522:1527。现在您可以连接:sqlplus系统/password1@localhost:1522/ORCLCDB@BjarteBrandt-我是否需要在docker文件中或在为oracle 19c创建映像时更改某些内容?到目前为止,在创建docker映像时,我已将端口值从1521更改为1527。根据您建议的更改,我仍然无法连接容器外部。在docker容器中,我能够连接这个,
sqlplus系统/password1@localhost:1527/ORCLCDB
但在docker容器外部,我无法连接此,
sqlplus系统/password1@localhost:1522/ORCLCDB
谢谢@Bjarte,这是有效的!!