go语言实现心跳机制样例

目录

1、服务端代码:

2、客户端代码:

3、最终实现效果:


1、服务端代码:

复制代码
package main

import (
	"fmt"
	"net"
)

func handleClient(conn net.Conn) {
	defer conn.Close()

	fmt.Println("Client connected:", conn.RemoteAddr())

	// 读取客户端的数据
	buffer := make([]byte, 1024)
	for {
		n, err := conn.Read(buffer)
		if err != nil {
			fmt.Println("Error reading:", err)
			return
		}

		// 处理接收到的数据
		data := string(buffer[:n])
		fmt.Printf("Received from %s: %s\n", conn.RemoteAddr(), data)

		// 回复心跳响应
		response := "Heartbeat response"
		conn.Write([]byte(response))
	}
}

func main() {
	listener, err := net.Listen("tcp", ":8080")
	if err != nil {
		fmt.Println("Error:", err)
		return
	}
	defer listener.Close()

	fmt.Println("Heartbeat server listening on :8080")

	for {
		conn, err := listener.Accept()
		if err != nil {
			fmt.Println("Error accepting connection:", err)
			continue
		}

		// 启动一个goroutine处理客户端连接
		go handleClient(conn)
	}
}

2、客户端代码:

复制代码
package main

import (
	"fmt"
	"net"
	"time"
)

func sendHeartbeat(conn net.Conn) {
	for {
		// 发送心跳数据
		heartbeat := "Heartbeat message"
		conn.Write([]byte(heartbeat))

		// 等待一段时间再发送下一次心跳
		time.Sleep(time.Second * 5)
	}
}

func main() {
	conn, err := net.Dial("tcp", "localhost:8080")
	if err != nil {
		fmt.Println("Error connecting to server:", err)
		return
	}
	defer conn.Close()

	fmt.Println("Connected to server:", conn.RemoteAddr())

	// 启动goroutine发送心跳
	go sendHeartbeat(conn)

	// 主goroutine保持运行,等待心跳
	select {}
}

3、最终实现效果:

相关推荐
来自旧金山的勇士14 分钟前
WSL->Ubunut安装Redis
后端
大葱白菜16 分钟前
Java Set 集合详解:从基础语法到实战应用,彻底掌握去重与唯一性集合
java·后端
大葱白菜17 分钟前
Java Map 集合详解:从基础语法到实战应用,彻底掌握键值对数据结构
java·后端
apihz22 分钟前
域名WHOIS信息查询免费API使用指南
android·开发语言·数据库·网络协议·tcp/ip
小猪乔治爱打球23 分钟前
[Golang修仙之路] 算法专题:回溯(递归)
后端·面试
昵称为空C31 分钟前
SpringBoot数据存储时区选择,符合国际化和特定时区方案
spring boot·后端
coding随想36 分钟前
掌控网页的魔法之书:JavaScript DOM的奇幻之旅
开发语言·javascript·ecmascript
爱吃烤鸡翅的酸菜鱼1 小时前
IDEA高效开发:Database Navigator插件安装与核心使用指南
java·开发语言·数据库·编辑器·intellij-idea·database
心情好的小球藻2 小时前
Python应用进阶DAY9--类型注解Type Hinting
开发语言·python
ldj20202 小时前
SpringBoot为什么使用new RuntimeException() 来获取调用栈?
java·spring boot·后端