[英]ASP.NET Core with Docker support: Connection refused
我有一个支持 Docker 的 ASP .NET Core (v2.0) 应用程序。 我想在启动我的应用程序时启动一个 Oracle 数据库。 这是我的 docker-compose 文件的样子:
version: '3'
services:
devarttestapp:
image: devarttestapp
build:
context: ./DevartTestApp
dockerfile: Dockerfile
oracledb:
image: sath89/oracle-12c
ports:
- "1521:1521"
我使用 Devart 数据提供程序 dotConnect for Oracle。
var conn = new Devart.Data.Oracle.OracleConnection();
conn.ConnectionString = Environment.GetEnvironmentVariable("ORACLE_CONNECTION_STRING");
try
{
conn.Open();
}
catch (Exception e)
{
Console.WriteLine(e);
throw;
}
但是当我尝试连接到创建的 Oracle DB 容器的数据库时,出现以下异常:
System.Net.Internals.SocketExceptionFactory+ExtendedSocketException(连接被拒绝 127.0.0.1:1521)
我还尝试在我的 docker-compose 文件中包含depends_on 和networks 选项,结果相同。
导致此异常的原因可能是什么?
我该如何解决这个问题?
从容器内,你能把这个命令的输出发送给我吗?
apt-get update && apt-get install nmap -y && nmap -p 1521 localhost
如果您不熟悉如何在容器内访问 bash,请执行以下操作:
找到您的容器 ID 或名称: docker ps
连接到 BASH: docker exec -it >containerID< /bin/bash
我有一种感觉,他的问题与 Oracle 而不是 Docker 有关,因为您的 docker-compose 文件看起来是正确的。 也许侦听器尚未启用。 我也很感激输出: lsnrctl status
if nmap
说端口没有open
。
https://docs.oracle.com/cd/E11882_01/network.112/e41945/listenercfg.htm#NETAG010
我在我的 mac 上遇到了同样的问题。 我使用> 9000的端口解决了它。
只需添加SslMode=None;
在您的连接字符串中
"ConnectionStrings": {
"DefaultConnection": "Server=db-host; Database=db-name; Uid=db-user; Pwd=db-pwd; SslMode=None;"
},
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.