日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java Netty實現心跳機制過程解析

瀏覽:192日期:2022-09-05 08:30:27

netty心跳機制示例,使用Netty實現心跳機制,使用netty4,IdleStateHandler 實現。Netty心跳機制,netty心跳檢測,netty,心跳

本文假設你已經了解了Netty的使用,或者至少寫過netty的helloworld,知道了netty的基本使用。我們知道使用netty的時候,大多數的東西都與Handler有關,我們的業務邏輯基本都是在Handler中實現的。Netty中自帶了一個IdleStateHandler 可以用來實現心跳檢測。

心跳檢測的邏輯

本文中我們將要實現的心跳檢測邏輯是這樣的:服務端啟動后,等待客戶端連接,客戶端連接之后,向服務端發送消息。如果客戶端在“干活”那么服務端必定會收到數據,如果客戶端“閑下來了”那么服務端就接收不到這個客戶端的消息,既然客戶端閑下來了,不干事,那么何必浪費連接資源呢?所以服務端檢測到一定時間內客戶端不活躍的時候,將客戶端連接關閉。本文要實現的邏輯步驟為:

啟動服務端,啟動客戶端 客戶端向服務端發送'I am alive',并sleep隨機時間,用來模擬空閑。 服務端接收客戶端消息,并返回'copy that',客戶端空閑時 計數+1. 服務端客戶端繼續通信 服務端檢測客戶端空閑太多,關閉連接。客戶端發現連接關閉了,就退出了。

有了這個思路,我們先來編寫服務端。

心跳檢測服務端代碼

public class HeartBeatServer { int port ; public HeartBeatServer(int port){ this.port = port; } public void start(){ ServerBootstrap bootstrap = new ServerBootstrap(); EventLoopGroup boss = new NioEventLoopGroup(); EventLoopGroup worker = new NioEventLoopGroup(); try{ bootstrap.group(boss,worker) .handler(new LoggingHandler(LogLevel.INFO)) .channel(NioServerSocketChannel.class) .childHandler(new HeartBeatInitializer()); ChannelFuture future = bootstrap.bind(port).sync(); future.channel().closeFuture().sync(); }catch(Exception e){ e.printStackTrace(); }finally { worker.shutdownGracefully(); boss.shutdownGracefully(); } } public static void main(String[] args) throws Exception { HeartBeatServer server = new HeartBeatServer(8090); server.start(); }}

熟悉netty的同志,對于上面的模板一樣的代碼一定是在熟悉不過了。啥都不用看,只需要看childHandler(new HeartBeatInitializer()) 這一句。HeartBeatInitializer就是一個ChannelInitializer顧名思義,他就是在初始化channel的時做一些事情。我們所需要開發的業務邏輯Handler就是在這里添加的。其代碼如下:

public class HeartBeatInitializer extends ChannelInitializer<Channel> { @Override protected void initChannel(Channel channel) throws Exception { ChannelPipeline pipeline = channel.pipeline(); pipeline.addLast('decoder', new StringDecoder()); pipeline.addLast('encoder', new StringEncoder()); pipeline.addLast(new IdleStateHandler(2,2,2, TimeUnit.SECONDS)); pipeline.addLast(new HeartBeatHandler()); }}

代碼很簡單,我們先添加了StringDecoder,和StringEncoder。這兩個其實就是編解碼用的,下面的IdleStateHandler才是本次心跳的核心組件。我們可以看到IdleStateHandler的構造函數中接收了4個參數,其定義如下:

public IdleStateHandler(long readerIdleTime, long writerIdleTime, long allIdleTime, TimeUnit unit);

三個空閑時間參數,以及時間參數的格式。我們的例子中設置的是2,2,2,意思就是客戶端2秒沒有讀/寫,這個超時時間就會被觸發。超時事件觸發就需要我們來處理了,這就是上的HeartBeatInitializer中最后一行的HeartBeatHandler所做的事情。代碼如下:

public class HeartBeatHandler extends SimpleChannelInboundHandler<String> { int readIdleTimes = 0; @Override protected void channelRead0(ChannelHandlerContext ctx, String s) throws Exception { System.out.println(' ====== > [server] message received : ' + s); if('I am alive'.equals(s)){ ctx.channel().writeAndFlush('copy that'); }else { System.out.println(' 其他信息處理 ... '); } } @Override public void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception { IdleStateEvent event = (IdleStateEvent)evt; String eventType = null; switch (event.state()){ case READER_IDLE:eventType = '讀空閑';readIdleTimes ++; // 讀空閑的計數加1break; case WRITER_IDLE:eventType = '寫空閑';// 不處理break; case ALL_IDLE:eventType ='讀寫空閑';// 不處理break; } System.out.println(ctx.channel().remoteAddress() + '超時事件:' +eventType); if(readIdleTimes > 3){ System.out.println(' [server]讀空閑超過3次,關閉連接'); ctx.channel().writeAndFlush('you are out'); ctx.channel().close(); } } @Override public void channelActive(ChannelHandlerContext ctx) throws Exception { System.err.println('=== ' + ctx.channel().remoteAddress() + ' is active ==='); }}

至此,我們的服務端寫好了。

心跳檢測客戶端代碼

netty的api設計使得編碼的模式非常具有通用性,所以客戶端代碼和服務端的代碼幾乎一樣:啟動client端的代碼幾乎一樣,也需要一個ChannelInitializer,也需要Handler。改動的地方很少,因此本文不對客戶端代碼進行詳細解釋。下面給出client端的完整代碼:

public class HeartBeatClient { int port; Channel channel; Random random ; public HeartBeatClient(int port){ this.port = port; random = new Random(); } public static void main(String[] args) throws Exception{ HeartBeatClient client = new HeartBeatClient(8090); client.start(); } public void start() { EventLoopGroup eventLoopGroup = new NioEventLoopGroup(); try{ Bootstrap bootstrap = new Bootstrap(); bootstrap.group(eventLoopGroup).channel(NioSocketChannel.class) .handler(new HeartBeatClientInitializer()); connect(bootstrap,port); String text = 'I am alive'; while (channel.isActive()){sendMsg(text); } }catch(Exception e){ // do something }finally { eventLoopGroup.shutdownGracefully(); } } public void connect(Bootstrap bootstrap,int port) throws Exception{ channel = bootstrap.connect('localhost',8090).sync().channel(); } public void sendMsg(String text) throws Exception{ int num = random.nextInt(10); Thread.sleep(num * 1000); channel.writeAndFlush(text); } static class HeartBeatClientInitializer extends ChannelInitializer<Channel> { @Override protected void initChannel(Channel ch) throws Exception { ChannelPipeline pipeline = ch.pipeline(); pipeline.addLast('decoder', new StringDecoder()); pipeline.addLast('encoder', new StringEncoder()); pipeline.addLast(new HeartBeatClientHandler()); } } static class HeartBeatClientHandler extends SimpleChannelInboundHandler<String> { @Override protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception { System.out.println(' client received :' +msg); if(msg!= null && msg.equals('you are out')) {System.out.println(' server closed connection , so client will close too');ctx.channel().closeFuture(); } } }}

運行代碼

在上面的代碼寫好之后,我們先啟動服務端,然后在啟動客戶端。運行日志如下:

server端:

=== /127.0.0.1:57700 is active === ====== > [server] message received : I am alive ====== > [server] message received : I am alive/127.0.0.1:57700超時事件:寫空閑/127.0.0.1:57700超時事件:讀空閑/127.0.0.1:57700超時事件:讀寫空閑/127.0.0.1:57700超時事件:寫空閑/127.0.0.1:57700超時事件:讀空閑/127.0.0.1:57700超時事件:讀寫空閑/127.0.0.1:57700超時事件:寫空閑 ====== > [server] message received : I am alive/127.0.0.1:57700超時事件:寫空閑/127.0.0.1:57700超時事件:讀寫空閑/127.0.0.1:57700超時事件:讀空閑/127.0.0.1:57700超時事件:寫空閑/127.0.0.1:57700超時事件:讀寫空閑/127.0.0.1:57700超時事件:讀空閑 [server]讀空閑超過3次,關閉連接

client端:

client sent msg and sleep 2 client received :copy that client received :copy that client sent msg and sleep 6 client sent msg and sleep 6 client received :copy that client received :you are out server closed connection , so client will close tooProcess finished with exit code 0

通過上面的運行日志,我們可以看到:

1.客戶端在與服務器成功建立之后,發送了3次’I am alive’,服務端也回應了3次:’copy that’

2.由于客戶端消極怠工,超時了多次,服務端關閉了鏈接。

3.客戶端知道服務端拋棄自己之后,也關閉了連接,程序退出。

以上簡單了演示了一下,netty的心跳機制,其實主要就是使用了IdleStateHandler。源碼下載

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
中文不卡在线| 亚洲ab电影| 欧美国产美女| 热久久国产精品| 黄色欧美日韩| 久久五月天小说| 色乱码一区二区三区网站| 午夜国产精品视频| 国产一区日韩| 日韩精品国产欧美| 激情久久久久久| 亚洲综合不卡| 午夜免费一区| 在线免费观看亚洲| 国产视频一区免费看| 国产日韩电影| 国产不卡人人| 欧美日韩午夜电影网| 美女福利一区二区三区| 久久人人精品| 日韩一区二区三区在线免费观看| 欧美aa在线视频| 老司机精品在线| 日韩成人精品一区二区三区| 青青国产91久久久久久| 亚久久调教视频| 亚洲香蕉久久| 麻豆91小视频| 1000部精品久久久久久久久| 日韩国产高清在线| 日韩一级不卡| 日本一二区不卡| 在线精品视频一区| 福利在线免费视频| 日韩高清电影一区| 欧美视频二区| 欧美激情 亚洲a∨综合| 免费日本视频一区| 日韩不卡手机在线v区| 国产一区调教| 日韩综合一区二区| 丝袜诱惑制服诱惑色一区在线观看| 亚洲人成亚洲精品| 国产精品普通话对白| 狠狠色狠狠色综合日日tαg| 国产精品一区二区三区av| 色天使综合视频| 国产精品久久久一区二区| 亚洲精品一二三区区别| 久久婷婷国产| 欧美日本久久| 99riav1国产精品视频| 老司机免费视频一区二区三区| 视频一区视频二区中文| 久久精品国语| 色爱综合网欧美| 国产精品免费99久久久| 久久国产尿小便嘘嘘| 欧美在线黄色| 国产日韩欧美三区| 国产精品videossex久久发布| 国产亚洲精aa在线看| 欧美一区激情| 国产精品17p| 国产精品高颜值在线观看| 久久精品系列| 鲁鲁在线中文| 久久久久久久久久久妇女| 91久久久精品国产| 美女尤物久久精品| 日韩精品一区二区三区中文在线 | 欧美日韩1区2区3区| 99久久婷婷这里只有精品| 久久免费福利| 精品欧美日韩精品| 国产精品一区2区3区| 欧美精品自拍| 日本精品在线播放| 88久久精品| 美女视频网站久久| 麻豆国产精品| 女生影院久久| 午夜欧美精品| 在线精品视频一区| 日本不卡高清| 国产v日韩v欧美v| 午夜精品成人av| 国产不卡人人| 欧美日韩在线网站| 狠狠色综合网| 亚洲69av| 日韩中文字幕| 久久av导航| 美女一区网站| 亚洲一区中文| 午夜久久av| 在线日韩视频| 日韩精选在线| 精品三级久久久| 久久婷婷亚洲| 中文字幕免费一区二区| 国产精品a级| 久久在线视频免费观看| 国产精品免费看| 久久99伊人| 久久中文字幕一区二区| 成人在线观看免费视频| 亚洲免费激情| 国产激情欧美| 日韩中文字幕不卡| 国产在线视频欧美一区| 日韩精品一页| 一区三区视频| 麻豆免费精品视频| 亚洲免费一区二区| 国产日韩欧美一区二区三区在线观看| 桃色av一区二区| 久久狠狠久久| 久久久精品日韩| 亚洲伊人av| 日韩国产成人精品| 欧美成人a交片免费看| 日韩不卡一二三区| 午夜亚洲精品| 九九精品调教| 久久精品一区二区国产| 免费在线亚洲| 欧美日韩1区2区3区| 性一交一乱一区二区洋洋av| 亚洲精品福利电影| 国产精品黄色片| 四虎精品永久免费| 爽爽淫人综合网网站| 日韩视频久久| 日韩精品水蜜桃| 精品视频在线你懂得| 亚洲欧美日韩在线观看a三区| 日韩在线观看一区| 成人午夜亚洲| 免费在线欧美黄色| 国产精品精品国产一区二区| 久久wwww| 久久精品亚洲| 免费在线观看一区| 精品高清久久| 国产成人久久| 国产精品高颜值在线观看| 国产99久久| 欧美日韩四区| 亚洲福利精品| 91精品电影| 香蕉成人av| 亚洲午夜av| 视频一区二区不卡| 亚洲精品免费观看| 日韩中文字幕一区二区高清99| 一区二区电影| 日本v片在线高清不卡在线观看| 日韩三级视频| 精品视频在线观看网站| 樱桃视频成人在线观看| 丝袜美腿亚洲色图| 日韩在线观看中文字幕| 国产精品网址| 久久99久久久精品欧美| 精品视频网站| 久久精品网址| 国产精品av一区二区| 日本黄色精品| 视频一区二区中文字幕| 国产日韩欧美三区| 久久九九精品| 视频一区中文字幕精品| 欧美国产另类| 国产日韩高清一区二区三区在线| 亚洲黄色免费av| 丝袜美腿成人在线| 精品色999| 日本精品另类| 91久久在线| 日本不卡免费高清视频在线| 国产91精品对白在线播放| 日韩一区免费| 蜜桃成人精品| 国产乱码精品一区二区亚洲| 99综合视频| 中文字幕在线高清| 日韩亚洲精品在线观看| 久久狠狠婷婷| 卡一卡二国产精品| 中文视频一区| 91精品99| 99精品综合| 精品视频一区二区三区在线观看 | 欧美成人综合| 精品亚洲a∨| 91精品尤物| 伊人久久一区| 影音国产精品| 不卡一区综合视频|