Golang的net包提供TCP、UDP、Unix套接字和域名解析等网络通信功能。1. TCP通过net.Listen监听,Accept接收连接,实现可靠传输;2. UDP使用net.ListenPacket,无需连接,适合实时应用;3. 支持域名解析与IP验证,如LookupHost和ParseIP;4. Unix域套接字用于高效本地进程通信。结合goroutine可构建高并发服务。

在Golang中,net 包是实现网络通信的核心标准库,支持TCP、UDP、Unix域套接字以及域名解析等多种功能。它提供了统一的接口来处理底层网络操作,使开发者能够轻松构建高性能的网络服务。
1. 使用TCP实现客户端与服务器通信
TCP是一种面向连接的协议,适用于需要可靠传输的场景。通过 net.Listen 启动一个TCP服务器,监听指定地址和端口。
示例:启动一个简单的TCP服务器
listener, err := net.Listen("tcp", ":8080")
if err != nil {
log.Fatal(err)
}
defer listener.Close()
for {
conn, err := listener.Accept()
if err != nil {
log.Print(err)
continue
}
go handleConnection(conn)
}
func handleConnection(conn net.Conn) {
defer conn.Close()
buf := make([]byte, 1024)
n, err := conn.Read(buf)
if err != nil {
log.Print(err)
return
}
response := "收到: " + string(buf[:n])
conn.Write([]byte(response))
}
客户端使用 net.Dial 连接到服务器并发送数据:
立即学习“go语言免费学习笔记(深入)”;
conn, err := net.Dial("tcp", "localhost:8080")
if err != nil {
log.Fatal(err)
}
defer conn.Close()
conn.Write([]byte("Hello Server"))
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
fmt.Println(string(buf[:n]))
2. 使用UDP进行无连接通信
UDP不建立连接,适合对实时性要求高、可容忍少量丢包的应用,如音视频传输或心跳检测。
UDP服务器使用 net.ListenPacket 监听数据报:
conn, err := net.ListenPacket("udp", ":8080")
if err != nil {
log.Fatal(err)
}
defer conn.Close()
buf := make([]byte, 1024)
for {
n, addr, err := conn.ReadFrom(buf)
if err != nil {
log.Print(err)
break
}
fmt.Printf("收到来自 %s 的消息: %s\n", addr, string(buf[:n]))
conn.WriteTo([]byte("已接收"), addr)
}
UDP客户端直接向目标地址发送数据:
conn, err := net.Dial("udp", "localhost:8080")
if err != nil {
log.Fatal(err)
}
defer conn.Close()
conn.Write([]byte("UDP消息"))
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
fmt.Println("响应:", string(buf[:n]))
3. 域名解析与地址验证
net 包提供了一系列工具函数用于处理IP地址和域名解析。
- net.LookupHost("example.com"):解析域名对应的IP列表
- net.ParseIP("192.168.1.1"):验证字符串是否为合法IP
- net.ResolveTCPAddr / ResolveUDPAddr:解析TCP/UDP地址结构
例如判断一个IP是否为私有网段:
ip := net.ParseIP("192.168.1.1")
if ip.IsPrivate() {
fmt.Println("这是一个私有IP")
}
4. Unix域套接字通信(本地进程间通信)
Unix域套接字用于同一主机上的进程通信,比TCP更高效且安全。
服务器监听Unix套接字:
os.Remove("/tmp/socket") // 清理旧文件
l, err := net.Listen("unix", "/tmp/socket")
if err != nil {
log.Fatal(err)
}
defer l.Close()
conn, err := l.Accept()
if err != nil {
log.Print(err)
}
// 处理 conn...
客户端连接:
conn, err := net.Dial("unix", "/tmp/socket")
if err != nil {
log.Fatal(err)
}
defer conn.Close()
基本上就这些。net包的设计简洁而强大,覆盖了大多数网络编程需求,配合goroutine能轻松实现高并发服务。掌握其基本用法后,可以进一步结合 bufio、json 或 protobuf 实现更复杂的应用层协议。










