Java Socket編程心跳包創(chuàng)建實例解析
1.什么是心跳包?
心跳包就是在客戶端和服務器間定時通知對方自己狀態(tài)的一個自己定義的命令字,按照一定的時間間隔發(fā)送,類似于心跳,所以叫做心跳包。
用來判斷對方(設備,進程或其它網元)是否正常運行,采用定時發(fā)送簡單的通訊包,如果在指定時間段內未收到對方響應,則判斷對方已經離線。用于檢測TCP的異常斷開。基本原因是服務器端不能有效的判斷客戶端是否在線,也就是說,服務器無法區(qū)分客戶端是長時間在空閑,還是已經掉線的情況。所謂的心跳包就是客戶端定時發(fā)送簡單的信息給服務器端告訴它我還在而已。代碼就是每隔幾分鐘發(fā)送一個固定信息給服務端,服務端收到后回復一個固定信息如果服務端幾分鐘內沒有收到客戶端信息則視客戶端斷開。
比如有些通信軟件長時間不使用,要想知道它的狀態(tài)是在線還是離線就需要心跳包,定時發(fā)包收包。發(fā)包方:可以是客戶也可以是服務端,看哪邊實現方便合理,一般是客戶端。服務器也可以定時發(fā)心跳下去。一般來說,出于效率的考慮,是由客戶端主動向服務器端發(fā)包,而不是服務器向客戶端發(fā)。客戶端每隔一段時間發(fā)一個包,使用TCP的,用send發(fā),使用UDP的,用sendto發(fā),服務器收到后,就知道當前客戶端還處于“活著”的狀態(tài),否則,如果隔一定時間未收到這樣的包,則服務器認為客戶端已經斷開,進行相應的客戶端斷開邏輯處理。
2.以下是實現Java心跳包的簡單實例
a)服務器端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.實體類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;
}
}
總結
以上就是本文關于Java Socket編程心跳包創(chuàng)建實例解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關文章
Spring AOP如何整合redis(注解方式)實現緩存統(tǒng)一管理詳解
這篇文章主要給大家介紹了關于Spring AOP如何整合redis(注解方式)實現緩存統(tǒng)一管理的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2018-08-08
解決spring?security?loginProcessingUrl無效問題
這篇文章主要介紹了解決spring?security?loginProcessingUrl無效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
使用Springboot封裝好的發(fā)送post請求的工具類
本文介紹了在Springboot中封裝發(fā)送HTTP請求的工具類,并提供了普通的HTTP請求工具類代碼和Response類的使用示例,這些工具類可為開發(fā)者提供便利性和參考價值,幫助提高開發(fā)效率2024-09-09

