Java tutorial
/* * Copyright 2009-2016 Weibo, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.weibo.api.motan.transport.netty; import java.net.InetSocketAddress; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; import com.weibo.api.motan.util.LoggerUtil; import io.netty.channel.*; /** * @author maijunsheng * @version 2013-6-7 * */ @ChannelHandler.Sharable public class NettyServerChannelManage extends ChannelDuplexHandler { private ConcurrentMap<String, Channel> channels = new ConcurrentHashMap<String, Channel>(); private int maxChannel = 0; public NettyServerChannelManage(int maxChannel) { super(); this.maxChannel = maxChannel; } @Override public void channelRegistered(ChannelHandlerContext ctx) throws Exception { Channel channel = ctx.channel(); String channelKey = getChannelKey((InetSocketAddress) channel.localAddress(), (InetSocketAddress) channel.remoteAddress()); if (channels.size() > maxChannel) { // ?close LoggerUtil.warn( "NettyServerChannelManage channelConnected channel size out of limit: limit={} current={}", maxChannel, channels.size()); channel.close(); } else { channels.put(channelKey, channel); super.channelRegistered(ctx); } } @Override public void channelUnregistered(ChannelHandlerContext ctx) throws Exception { Channel channel = ctx.channel(); String channelKey = getChannelKey((InetSocketAddress) channel.localAddress(), (InetSocketAddress) channel.remoteAddress()); channels.remove(channelKey); super.channelUnregistered(ctx); ; } public Map<String, Channel> getChannels() { return channels; } /** * close */ public void close() { for (Map.Entry<String, Channel> entry : channels.entrySet()) { try { Channel channel = entry.getValue(); if (channel != null) { channel.close(); } } catch (Exception e) { LoggerUtil.error("NettyServerChannelManage close channel Error: " + entry.getKey(), e); } } } /** * remote address + local address * * @param local * @param remote * @return */ private String getChannelKey(InetSocketAddress local, InetSocketAddress remote) { String key = ""; if (local == null || local.getAddress() == null) { key += "null-"; } else { key += local.getAddress().getHostAddress() + ":" + local.getPort() + "-"; } if (remote == null || remote.getAddress() == null) { key += "null"; } else { key += remote.getAddress().getHostAddress() + ":" + remote.getPort(); } return key; } }