Docker容器内WS端口映射异常的实现
作者:新标签页
本文介绍了在Docker容器内部署WebSocket服务时遇到的问题及解决方法,通过更改代码获取容器内部真实IP,解决了端口映射失败导致的连接不通问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
在Docker容器内部署Websocket服务时出现了端口映射失败,链接WS时始终访问不通的情况。
代码如下
var server = new WebSocketServer("ws://127.0.0.1:8888");
server.Start(socket =>
{
socket.OnOpen = () => //当建立Socket链接时执行此方法
{
};
socket.OnClose = () =>// 当关闭Socket链接十执行此方法
{
};
socket.OnMessage = message =>// 接收客户端发送过来的信息
{
};
});
}将程序打包进入Docker容器后,配置DockerCompose
version: '3.4'
services:
tdssserver:
image: test
restart: always
container_name: test
ports:
- 8988:8888
environment:
TZ: Asia/Shanghai
volumes:
- ./appsettings.json:/app/appsettings.json正常情况下应该可以通过WS正常连接到服务上,但是当服务在Docker内正常运行的时候,使用测试工具进行测试连接发现一直连不通。

一开始分析以为是WS协议与Http协议不是同族协议,认为需要单独开启Docker的Ws协议支持。但是后来查阅资料发现实际上WS和HTTP都是基于TCP的,所以立马改变排查方向。
最后分析认为可能是使用的127.0.0.1这类的LocalHost地址,导致在配置Docker映射的时候没法正确映射。
分析之后改变原来代码
string localIP;
using (Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, 0))
{
socket.Connect("8.8.8.8", 65530);
IPEndPoint endPoint = socket.LocalEndPoint as IPEndPoint;
localIP = endPoint.Address.ToString();
}
FleckLog.Level = Fleck.LogLevel.Debug;
var ws = "ws://" + localIP + ":" + planws;
var server = new WebSocketServer(ws);
server.Start(socket =>
{
socket.OnOpen = () => //当建立Socket链接时执行此方法
{
};
socket.OnClose = () =>// 当关闭Socket链接十执行此方法
{
};
socket.OnMessage = message =>// 接收客户端发送过来的信息
{
};
});思路是通过
string localIP;
using (Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, 0))
{
socket.Connect("8.8.8.8", 65530);
IPEndPoint endPoint = socket.LocalEndPoint as IPEndPoint;
localIP = endPoint.Address.ToString();
}
FleckLog.Level = Fleck.LogLevel.Debug;
var ws = "ws://" + localIP + ":" + planws;
var server = new WebSocketServer(ws);拿到Localip,最后用容器内部的LocalIp创建对应的WS连接。
改变代码后生成新的Docker镜像。启动容器,测试连接正常。

到此这篇关于Docker容器内WS端口映射异常的文章就介绍到这了,更多相关Docker WS端口映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
