公司弄了个货柜需要TCP连接,然后我就搭建了netty框架用于tcp连接,突然某一天又来了好几个货柜,不同的货柜不同的IP,启动程序全部都进行连接了,但是发送指令就是错乱的,同一个指令一会儿开开这个柜子,一会儿开开那个柜子,然后对接得人说我应该要指定某个连接,后来看看自己的代码有了灵感
netty有个客户端连接就会请求的方法,我在方法里把所有的连接存储到全局变量里
/**
* 当客户端主动链接服务端的链接后,这个通道就是活跃的了。也就是客户端与服务端建立了通信通道并且可以传输数据
*/
@Override
public void channelActive(ChannelHandlerContext ctx) {
try {
SocketChannel channel = (SocketChannel) ctx.channel();
InetSocketAddress inetSocketAddress = channel.remoteAddress();
String clientIP = inetSocketAddress.getAddress().getHostAddress();
logger.info("客户端连接上服务端: IP地址是:" + clientIP);
// 存储不同的ip的SocketChannel
// 根据标识不同存储不同的key,用来区分不同的连接
Map<String, ChannelHandlerContext> map = new HashMap();
if (IpCabinetBind.IP_34.getIp().equals(clientIP)) {
map.put(IpCabinetBind.IP_34.getOrderNo(), ctx);
}
if (IpCabinetBind.IP_3

最低0.47元/天 解锁文章
1648

被折叠的 条评论
为什么被折叠?



