netty

1.控制带宽

public class FlowMonitoringHandler extends GlobalChannelTrafficShapingHandler {

    public FlowMonitoringHandler(ScheduledExecutorService executor, long writeGlobalLimit, long readGlobalLimit,
            long writeChannelLimit, long readChannelLimit, long checkInterval) {
        super(executor, writeGlobalLimit, readGlobalLimit, writeChannelLimit, readChannelLimit, checkInterval);
    }

    @Override
    protected void doAccounting(TrafficCounter counter) {
        super.doAccounting(counter);

       MetricsUtils.counterN(MetricsConstants.METRICS_TRAFFIC_COUNTER_READ, counter.lastReadBytes());
       MetricsUtils.counterN(MetricsConstants.METRICS_TRAFFIC_COUNTER_WRITE, counter.lastWrittenBytes());
        // log.info("TrafficCounter, Read: {} KB, Write: {} KB", counter.lastReadBytes() / 1024, counter.lastWrittenBytes() / 1024);
    }

}

判断lastReadBytes和lastWrittenBytes大小,超过大小如何处理,自动阻塞后续的写入操作

GlobalChannelTrafficShapingHandler flowMonitoringHandler = new FlowMonitoringHandler(finalEventExecutorGroup,
                                                                                             config.getWriteGlobalLimit(),
                                                                                             config.getReadGlobalLimit(),
                                                                                             config.getWriteChannelLimit(),
                                                                                             config.getReadChannelLimit(),
                                                                                             config.getCheckInterval());

bootstrap.group(boss, worker)
                 .channel(NioServerSocketChannel.class)
                 .childOption(ChannelOption.TCP_NODELAY, config.isTcpNodelay())
                 .handler(new LoggingHandler(LogLevel.DEBUG))
                 .childHandler(new ChannelInitializer<NioSocketChannel>() {
                     @Override
                     protected void initChannel(NioSocketChannel ch) {
                         ChannelPipeline pipeline = ch.pipeline();
                         pipeline.addLast(flowMonitoringHandler);
                     }
                 });

2.控制消息大小

public class WebSocketSizeLimitHandler extends SimpleChannelInboundHandler<WebSocketFrame> {

    private static final int MAX_FRAME_SIZE = 1024 * 1024; // 设置最大消息大小为1MB

    @Override
    protected void channelRead0(ChannelHandlerContext ctx, WebSocketFrame frame) {
        if (frame instanceof TextWebSocketFrame || frame instanceof BinaryWebSocketFrame) {
            if (frame.content().readableBytes() > MAX_FRAME_SIZE) {
                // 消息过大,可以根据需要进行处理,例如关闭连接或发送错误消息
                ctx.close();
            } else {
                // 消息大小合法,继续处理
                // ...
            }
        } else {
            // 非文本或二进制帧,继续处理
            // ...
        }
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值