Java Socket編程心跳包創(chuàng)建實(shí)例解析
1.什么是心跳包?
心跳包就是在客戶端和服務(wù)器間定時(shí)通知對方自己狀態(tài)的一個(gè)自己定義的命令字,按照一定的時(shí)間間隔發(fā)送,類似于心跳,所以叫做心跳包。
用來判斷對方(設(shè)備,進(jìn)程或其它網(wǎng)元)是否正常運(yùn)行,采用定時(shí)發(fā)送簡單的通訊包,如果在指定時(shí)間段內(nèi)未收到對方響應(yīng),則判斷對方已經(jīng)離線。用于檢測TCP的異常斷開?;驹蚴欠?wù)器端不能有效的判斷客戶端是否在線,也就是說,服務(wù)器無法區(qū)分客戶端是長時(shí)間在空閑,還是已經(jīng)掉線的情況。所謂的心跳包就是客戶端定時(shí)發(fā)送簡單的信息給服務(wù)器端告訴它我還在而已。代碼就是每隔幾分鐘發(fā)送一個(gè)固定信息給服務(wù)端,服務(wù)端收到后回復(fù)一個(gè)固定信息如果服務(wù)端幾分鐘內(nèi)沒有收到客戶端信息則視客戶端斷開。
比如有些通信軟件長時(shí)間不使用,要想知道它的狀態(tài)是在線還是離線就需要心跳包,定時(shí)發(fā)包收包。發(fā)包方:可以是客戶也可以是服務(wù)端,看哪邊實(shí)現(xiàn)方便合理,一般是客戶端。服務(wù)器也可以定時(shí)發(fā)心跳下去。一般來說,出于效率的考慮,是由客戶端主動(dòng)向服務(wù)器端發(fā)包,而不是服務(wù)器向客戶端發(fā)。客戶端每隔一段時(shí)間發(fā)一個(gè)包,使用TCP的,用send發(fā),使用UDP的,用sendto發(fā),服務(wù)器收到后,就知道當(dāng)前客戶端還處于“活著”的狀態(tài),否則,如果隔一定時(shí)間未收到這樣的包,則服務(wù)器認(rèn)為客戶端已經(jīng)斷開,進(jìn)行相應(yīng)的客戶端斷開邏輯處理。
2.以下是實(shí)現(xiàn)Java心跳包的簡單實(shí)例
a)服務(wù)器端Server.java
package cn.yw.socket.heart; import java.io.ObjectInput; import java.io.ObjectInputStream; import java.net.ServerSocket; import java.net.Socket; public class Server extends Thread{ private ServerSocket server = null; Object obj = new Object(); @Override public void run() { try{ while(true){ server = new ServerSocket(25535); Socket client = server.accept(); synchronized(obj){ new Thread(new Client(client)).start(); } } } catch(Exception e){ e.printStackTrace(); } } /** * 客戶端線程 * @author USER * */ class Client implements Runnable{ Socket client; public Client(Socket client){ this.client = client; } @Override public void run() { try{ while(true){ ObjectInput in = new ObjectInputStream(client.getInputStream()); Entity entity = (Entity)in.readObject(); System.out.println(entity.getName()); System.out.println(entity.getSex()); } } catch(Exception e){ e.printStackTrace(); } } } /** *程序的入口main方法 * @param args */ public static void main(String[] args){ new Server().start(); } }
b)客戶端Client.java
package cn.yw.socket.heart; public class Client extends Thread{ @Override public void run() { try{ while(true){ ClientSender.getInstance().send(); synchronized(Client.class){ // this.wait(5000); Thread.sleep(2000); } } } catch(Exception e){ e.printStackTrace(); } } /** * 程序的入口main方法 * @param args */ public static void main(String[] args){ Client client = new Client(); client.start(); } }
package cn.yw.socket.heart; import java.io.ObjectOutputStream; import java.net.InetAddress; import java.net.Socket; public class ClientSender{ private ClientSender(){ } Socket sender = null; private static ClientSender instance; public static ClientSender getInstance(){ if(instance==null){ synchronized(Client.class){ instance = new ClientSender(); } } return instance; } public void send(){ try{ sender = new Socket(InetAddress.getLocalHost(),25535); while(true){ ObjectOutputStream out = new ObjectOutputStream(sender.getOutputStream()); Entity obj = new Entity(); obj.setName("syz"); obj.setSex("男"); out.writeObject(obj); out.flush(); Thread.sleep(5000); } } catch(Exception e){ } } }
3.實(shí)體類Entity.java
package cn.yw.socket.heart; import java.io.Serializable; public class Entity implements Serializable{ private String name; private String sex; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } }
總結(jié)
以上就是本文關(guān)于Java Socket編程心跳包創(chuàng)建實(shí)例解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
Java多線程編程實(shí)現(xiàn)socket通信示例代碼
Java編程利用socket多線程訪問服務(wù)器文件代碼示例
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
Spring AOP如何整合redis(注解方式)實(shí)現(xiàn)緩存統(tǒng)一管理詳解
這篇文章主要給大家介紹了關(guān)于Spring AOP如何整合redis(注解方式)實(shí)現(xiàn)緩存統(tǒng)一管理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08一文徹底弄懂零拷貝原理以及java實(shí)現(xiàn)
零拷貝(英語: Zero-copy) 技術(shù)是指計(jì)算機(jī)執(zhí)行操作時(shí),CPU不需要先將數(shù)據(jù)從某處內(nèi)存復(fù)制到另一個(gè)特定區(qū)域,下面這篇文章主要給大家介紹了關(guān)于零拷貝原理以及java實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2021-08-08基于OAuth2.0授權(quán)系統(tǒng)的驗(yàn)證碼功能的實(shí)現(xiàn)
本篇教程給大家分享基于OAuth2.0授權(quán)系統(tǒng)的驗(yàn)證碼功能的實(shí)現(xiàn),驗(yàn)證碼功能的實(shí)現(xiàn)是采用Zuul網(wǎng)關(guān)的Filter過濾器進(jìn)行校驗(yàn)驗(yàn)證碼,具體實(shí)現(xiàn)代碼跟隨小編一起看看吧2021-05-05ssm項(xiàng)目改造spring?boot項(xiàng)目完整步驟
Spring?Boot現(xiàn)在已經(jīng)成為Java開發(fā)領(lǐng)域的一顆璀璨明珠,它本身是包容萬象的,可以跟各種技術(shù)集成,下面這篇文章主要給大家介紹了關(guān)于ssm項(xiàng)目改造spring?boot項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2023-04-04解決spring?security?loginProcessingUrl無效問題
這篇文章主要介紹了解決spring?security?loginProcessingUrl無效問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08使用Springboot封裝好的發(fā)送post請求的工具類
本文介紹了在Springboot中封裝發(fā)送HTTP請求的工具類,并提供了普通的HTTP請求工具類代碼和Response類的使用示例,這些工具類可為開發(fā)者提供便利性和參考價(jià)值,幫助提高開發(fā)效率2024-09-09