GolangTCPUDP网络通信入门教程
时间:2025-10-11 16:57:31 380浏览 收藏
本教程深入讲解Golang中如何利用`net`包进行TCP和UDP网络通信,助力开发者构建高性能网络应用。**TCP通信**作为可靠连接的基础,通过`net.Listen`监听端口,`Accept`接收连接,并为每个连接启动goroutine处理并发。**UDP通信**则以其无连接的特性,适用于对实时性要求高的场景,使用`net.ListenUDP`监听,实现快速数据传输。本文将通过实际示例,详细展示TCP和UDP服务器与客户端的搭建过程,并重点强调错误处理、TCP粘包、UDP大小限制以及资源释放等关键细节,助您掌握Golang网络编程的核心技术。
Go语言中net包支持TCP与UDP编程。1. TCP通过net.Listen监听,Accept接收连接,每连接启goroutine处理;2. UDP用net.ListenUDP监听,ReadFromUDP收包,WriteToUDP回包;3. 注意错误处理、TCP粘包、UDP大小限制及资源释放。

Go语言标准库中的net包为TCP和UDP网络编程提供了简洁而强大的支持。无论是构建高性能服务器还是轻量级客户端,Golang都能以极少的代码实现稳定通信。下面通过实际示例展示TCP与UDP的基本用法和关键细节。
TCP通信:可靠连接的基础
TCP是面向连接的协议,适合需要确保数据完整性和顺序的应用场景,比如HTTP服务、文件传输等。
1. TCP服务器
使用net.Listen监听端口,接受客户端连接并处理数据:
func startTCPServer() {
listener, err := net.Listen("tcp", ":8080")
if err != nil {
log.Fatal(err)
}
defer listener.Close()
log.Println("TCP服务器启动,监听 :8080")
for {
conn, err := listener.Accept()
if err != nil {
log.Println("接受连接失败:", err)
continue
}
go handleTCPConn(conn)
}
}
func handleTCPConn(conn net.Conn) {
defer conn.Close()
buffer := make([]byte, 1024)
for {
n, err := conn.Read(buffer)
if err != nil {
log.Println("读取结束或出错:", err)
return
}
log.Printf("收到: %s", string(buffer[:n]))
// 回显数据
conn.Write([]byte("echo: " + string(buffer[:n])))
}
}
2. TCP客户端
连接服务器并发送消息:
func tcpClient() {
conn, err := net.Dial("tcp", "localhost:8080")
if err != nil {
log.Fatal(err)
}
defer conn.Close()
conn.Write([]byte("Hello TCP Server"))
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
log.Printf("回显: %s", string(buf[:n]))
}
TCP的关键在于连接管理。服务器通常为每个连接启动一个goroutine,利用Go的轻量级并发模型高效处理多个客户端。
UDP通信:无连接的高效传输
UDP不建立连接,适合对实时性要求高、可容忍少量丢包的场景,如音视频流、心跳包等。
1. UDP服务器
使用net.ListenUDP绑定地址,接收任意来源的数据包:
func startUDPServer() {
addr, _ := net.ResolveUDPAddr("udp", ":9090")
conn, err := net.ListenUDP("udp", addr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
log.Println("UDP服务器启动,监听 :9090")
buffer := make([]byte, 1024)
for {
n, clientAddr, err := conn.ReadFromUDP(buffer)
if err != nil {
log.Println("读取失败:", err)
continue
}
log.Printf("来自 %s: %s", clientAddr, string(buffer[:n]))
// 回复客户端
conn.WriteToUDP([]byte("UDP echo"), clientAddr)
}
}
2. UDP客户端
直接向目标地址发送数据包:
func udpClient() {
serverAddr, _ := net.ResolveUDPAddr("udp", "localhost:9090")
conn, err := net.DialUDP("udp", nil, serverAddr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
conn.Write([]byte("Hello UDP Server"))
response := make([]byte, 1024)
n, _, _ := conn.ReadFromUDP(response)
log.Printf("收到回复: %s", string(response[:n]))
}
UDP通信中,服务器通过ReadFromUDP获取客户端地址,再用WriteToUDP回复。客户端则可通过DialUDP建立虚拟连接简化收发流程。
实践建议与注意事项
在真实项目中,以下几点值得特别关注:
- 错误处理不能忽略,尤其是网络中断、超时等常见问题
- TCP粘包问题需自行处理,常见方案有固定长度、分隔符或头部带长度字段
- UDP有最大报文限制(通常64KB),过大数据需应用层拆分
- 高并发下注意资源释放,避免文件描述符泄漏
- 可结合
context控制超时和取消
Go的net包接口设计直观,配合goroutine能轻松实现并发网络服务。理解TCP与UDP的本质差异,才能根据业务需求选择合适协议。
基本上就这些,不复杂但容易忽略细节。动手写一遍,比看十篇理论都管用。
到这里,我们也就讲完了《GolangTCPUDP网络通信入门教程》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
505 收藏
-
503 收藏
-
502 收藏
-
502 收藏
-
502 收藏
-
125 收藏
-
161 收藏
-
412 收藏
-
347 收藏
-
200 收藏
-
391 收藏
-
307 收藏
-
379 收藏
-
119 收藏
-
140 收藏
-
147 收藏
-
378 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习