Golang使用net进行基础网络编程实践

Go语言net包支持TCP/UDP/HTTP网络编程,通过Listen/Accept处理并发连接,Dial实现客户端通信,UDP适用于低延迟场景,手动解析HTTP请求可定制协议,需设置超时与错误处理保障稳定性。

golang使用net进行基础网络编程实践

Go语言的

net

包为网络编程提供了强大且简洁的支持,适合快速构建TCP、UDP和HTTP等网络服务。通过标准库即可完成常见网络通信任务,无需引入第三方依赖。下面介绍使用

net

包进行基础网络编程的核心实践。

TCP服务器与客户端通信

使用

net.Listen

创建TCP服务器,监听指定地址和端口。每当有客户端连接时,通过

Accept

方法获取连接对象,并在独立goroutine中处理数据读写。

示例:简单回声服务器

服务器代码:

package main

import ("bufio""fmt""net""strings")

func handleConn(conn net.Conn) {defer conn.Close()scanner := bufio.NewScanner(conn)for scanner.Scan() {line := strings.TrimSpace(scanner.Text())fmt.Fprintf(conn, "echo: %sn", line)}}

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

fmt.Println("Server running on :8080")for {    conn, err := listener.Accept()    if err != nil {        continue    }    go handleConn(conn)}

}

客户端代码:

立即学习“go语言免费学习笔记(深入)”;

package main

import ("bufio""fmt""net""os")

func main() {conn, err := net.Dial("tcp", "localhost:8080")if err != nil {panic(err)}defer conn.Close()

go func() {    scanner := bufio.NewScanner(conn)    for scanner.Scan() {        fmt.Println(scanner.Text())    }}()input := bufio.NewScanner(os.Stdin)for input.Scan() {    fmt.Fprintln(conn, input.Text())}

}

运行服务器后,启动客户端,输入任意文本,服务端会返回带"echo:"前缀的内容。这种模式适用于聊天系统或协议调试工具

UDP数据报通信

UDP是无连接协议,适合低延迟场景如音视频传输或心跳检测。使用

net.ListenPacket

监听UDP端口,通过

ReadFrom

接收数据并获取发送方地址,再用

WriteTo

回应。

示例:UDP回声服务

服务器:

package main

import ("fmt""net")

func main() {addr, := net.ResolveUDPAddr("udp", ":9000")conn, := net.ListenUDP("udp", addr)defer conn.Close()

buf := make([]byte, 1024)for {    n, clientAddr, _ := conn.ReadFrom(buf)    go func() {        response := append([]byte("echo: "), buf[:n]...)        conn.WriteTo(response, clientAddr)    }()}

}

客户端:

package main

import ("fmt""net")

func main() {conn, _ := net.Dial("udp", "localhost:9000")defer conn.Close()

fmt.Fprint(conn, "hello udp")buf := make([]byte, 1024)n, _ := conn.Read(buf)fmt.Printf("received: %sn", buf[:n])

}

UDP通信不需要维持连接状态,资源开销小,但不保证送达,需根据业务权衡使用。

基础HTTP服务实现

虽然

net/http

更常用,但

net

可手动解析HTTP请求。适用于学习协议原理或定制轻量协议处理。

简易HTTP响应示例:

package main

import ("io""net""strings")

func handleHTTP(conn net.Conn) {defer conn.Close()req := make([]byte, 1024)io.ReadFull(conn, req)

if strings.HasPrefix(string(req), "GET / ") {    response := "HTTP/1.1 200 OKrnContent-Length: 13rnrnHello World!"    conn.Write([]byte(response))} else {    conn.Write([]byte("HTTP/1.1 404 Not Foundrnrn"))}

}

func main() {listener, := net.Listen("tcp", ":8000")for {conn, := listener.Accept()go handleHTTP(conn)}}

访问

http://localhost:8000

将收到"Hello World!"。实际项目推荐使用

net/http

,此处仅展示底层交互过程。

连接超时与错误处理

生产环境需设置读写超时防止资源耗尽。使用

SetDeadline

设定绝对时间限制。

添加超时控制:

func handleConn(conn net.Conn) {    defer conn.Close()    // 设置10秒内必须完成读写    conn.SetDeadline(time.Now().Add(10 * time.Second))
scanner := bufio.NewScanner(conn)for scanner.Scan() {    if strings.ToLower(scanner.Text()) == "quit" {        break    }    fmt.Fprintf(conn, "recv: %sn", scanner.Text())    conn.SetDeadline(time.Now().Add(10 * time.Second)) // 重置超时}

}

同时应检查网络错误类型,区分临时错误与永久断开,合理重试或关闭连接。

基本上就这些。掌握

net

包的基础用法后,可以构建可靠的网络服务。关键是理解连接生命周期、并发处理和异常恢复机制。后续可结合

context

包实现优雅关闭,或封装通用通信框架。

以上就是Golang使用net进行基础网络编程实践的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1407470.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 23:11:40
下一篇 2025年12月15日 23:11:53

相关推荐

  • Go语言Web应用中嵌入本地图片:使用标签的正确姿势

    在Go语言Web开发中,经常需要在HTML页面中嵌入本地图片。直接使用文件路径可能会导致安全问题,并且不够灵活。本文将介绍一种推荐的方法,利用http.FileServer和http.StripPrefix来安全地提供静态文件服务,并在HTML中使用标签引用这些文件。 以下是详细步骤和代码示例: 首…

    2025年12月15日
    000
  • GolangRPC流控与并发限制实现方法

    答案:通过拦截器、流控机制和第三方组件实现gRPC流控与并发限制。使用semaphore控制并发数,设置HTTP/2窗口大小调节数据流速,结合rate.Limiter或Redis实现精细化限流,并通过监控动态调整策略,提升服务稳定性。 在使用 Go 语言实现 gRPC 服务时,流控(流量控制)和并发…

    2025年12月15日
    000
  • Go语言中 select 语句的“饥饿”现象及解决方法

    本文将围绕Go语言中 select 语句的一种特殊行为展开讨论,即在某些情况下,select 语句中的某些 case 分支可能由于调度问题而长时间无法被执行,导致所谓的“饥饿”现象。我们将通过一个定时器示例来具体分析这个问题,并提供相应的解决方案。 问题分析:Busy Loop 与 Goroutin…

    2025年12月15日
    000
  • 使用 Go 语言的 标签显示本地图片

    本教程旨在指导开发者如何使用 Go 语言在网页中嵌入本地图片。通过配置静态文件服务器,我们可以利用 标签轻松地将本地图片嵌入到 HTML 页面中。本文将提供详细的代码示例和步骤,帮助你理解并实现这一功能,并提供一些注意事项。 在 go 语言中,直接使用 标签显示本地图片需要配置一个静态文件服务器,将…

    2025年12月15日
    000
  • Golang访问者模式分离数据操作逻辑

    访问者模式通过将操作与数据结构解耦,提升Go代码的可维护性与扩展性。1. 它遵循开闭原则,新增操作无需修改现有元素类型,只需添加新访问者;2. 适用于稳定对象结构(如AST、图形组件)需执行多种独立操作的场景;3. 避免了类型断言和switch语句的散落,使逻辑集中且清晰;4. 但当元素类型频繁变更…

    2025年12月15日
    000
  • Golang的标签(label)和goto语句应该在何种情况下使用

    使用标签和goto可从多层嵌套循环中直接跳出,如在二维数组查找满足条件的元素后通过标签search配合break或goto跳出外层,简化控制流。 Go语言中的标签(label)和 goto 语句虽然存在,但使用场景非常有限。它们不是日常编程的推荐方式,但在特定情况下可以简化控制流或提升代码清晰度。 …

    2025年12月15日
    000
  • Golang微服务API网关设计与实现示例

    API网关通过统一入口实现路由转发、认证鉴权、限流熔断与日志监控,基于Golang的net/http与ReverseProxy构建核心代理,结合中间件扩展JWT认证、日志、限流功能,集成Consul服务发现与Viper配置热加载,支持HTTPS与Prometheus监控,形成高可用微服务入口层。 设…

    2025年12月15日
    000
  • Golang微服务注册与服务发现实践

    使用Consul结合Golang实现服务注册与发现,通过健康检查保障实例状态一致性,利用gRPC或Go Micro框架实现动态寻址与负载均衡,确保微服务间稳定通信。 在微服务架构中,服务注册与发现是核心组件之一。Golang凭借高并发、低延迟和简洁语法的优势,成为构建微服务的热门语言。结合主流工具与…

    2025年12月15日
    000
  • 在 Go 中使用 标签显示本地图片

    在 Go Web 应用中显示本地图片,通常需要将图片文件作为静态资源提供给浏览器。以下是如何使用 标签显示本地图片的详细步骤和示例代码。 package mainimport ( “fmt” “net/http” “os” “path”)func handler(w http.ResponseWri…

    2025年12月15日
    000
  • Golangmap访问性能优化与哈希算法应用

    Go map基于哈希表实现,合理优化可提升性能。1. 使用int或int64作key以减少冲突;2. 预分配map容量避免频繁扩容;3. 高并发写选用sync.Map或分片map降低竞争;4. 结合快速哈希算法预处理key提升访问速度。 在 Go 语言中,map 是最常用的数据结构之一,底层基于哈希…

    2025年12月15日
    000
  • 使用 Golang 执行外部命令 dexdump 并处理退出状态

    本文介绍了如何使用 Golang 的 os/exec 包执行 Android SDK 中的 dexdump 命令,并详细讲解了如何处理执行过程中可能出现的错误,包括命令未找到、参数缺失以及非零退出状态等情况。通过本文,你将学会如何在 Golang 程序中安全可靠地调用外部命令。 在 Golang 中…

    2025年12月15日
    000
  • Golang内存泄漏排查与性能调优

    Go语言虽然自带垃圾回收机制,但并不意味着完全免疫内存泄漏。在高并发、长时间运行的服务中,不当的编码习惯或资源管理疏忽仍可能导致内存持续增长,最终影响服务稳定性与性能。排查内存泄漏并进行性能调优,是保障Go服务长期稳定的关键环节。 常见内存泄漏场景与识别 内存泄漏通常表现为程序运行时间越长,占用内存…

    2025年12月15日
    000
  • Golang环境中代码格式化工具安装方法

    gofmt是Go内置的格式化工具,直接使用gofmt -w可格式化文件或目录;2. goimports增强版可自动管理import,需通过go install安装并用goimports -w格式化;3. 在VS Code中安装Go扩展并设置”format on save”及&…

    2025年12月15日
    000
  • Go语言中 select 语句的“饥饿”现象与解决方案

    这段摘要概括了本文的核心内容:Go 语言 select 语句在使用时可能因为 busy loop 导致某些 case 分支长时间无法被执行,称为“饥饿”现象。通过一个 time.Ticker 的例子解释了原因,并提供了 runtime.Gosched() 的解决方案。同时提醒开发者在涉及 I/O 或…

    2025年12月15日
    000
  • Go语言中Select语句与Goroutine调度:避免阻塞和饥饿

    第一段引用上面的摘要: 本文旨在深入解析Go语言中select语句与Goroutine调度之间的交互,特别是当select语句的default分支可能导致其他Goroutine无法执行时的情况。我们将通过示例代码和详细解释,帮助开发者理解Go的并发机制,避免因不当使用select语句而导致的程序行为…

    2025年12月15日
    000
  • Golang测试中常用断言方法解析

    Golang测试中,断言方法用于验证实际结果与预期是否一致,主要通过标准库testing包或第三方库实现。使用testing包可直接调用t.Errorf、t.Fatalf等方法进行基础断言,适合简单场景和原生风格追求;而引入testify/assert等第三方库则能显著提升复杂测试的可读性与维护性,…

    2025年12月15日
    000
  • Golang并发请求限流实现与优化实践

    首先使用令牌桶算法通过 rate.Limiter 实现单机限流,再结合 Redis + Lua 实现分布式全局限流,接着基于请求优先级配置动态策略,最后通过连接池、本地缓存和降级机制优化性能与容错,确保系统稳定性。 在高并发系统中,Golang 因其轻量级的 goroutine 和高效的调度机制,常…

    2025年12月15日
    000
  • go语言能做什么开发 go语言能做哪些开发

    Go语言在构建高性能微服务架构中优势显著:1. 轻量级Goroutines和Channels实现高效并发处理,降低系统开销;2. 编译生成静态单文件,部署便捷,契合云原生环境;3. 强制错误处理机制提升系统可靠性;4. 语法简洁,学习曲线平缓,利于团队协作与维护。 Go语言,在我看来,是一门为现代分…

    2025年12月15日
    000
  • Go语言中 select 语句的奇怪行为:协程调度与时间片问题

    本文旨在解释 Go 语言中 select 语句在并发场景下可能出现的“奇怪”行为,特别是当与 time.Ticker 结合使用时。通过分析一个简单的示例,我们将深入探讨 Go 语言的协程调度机制,以及如何避免因 CPU 密集型循环而导致的协程饥饿问题。本文将提供详细的解释和解决方案,帮助开发者更好地…

    2025年12月15日
    000
  • Golang值类型在函数调用中的复制行为

    值类型在Go中传递时会复制数据,包括基本类型、数组和结构体,导致函数内修改不影响原值;为避免大对象复制开销并修改原数据,应使用指针传递。 在Go语言中,值类型在函数调用时会进行复制,这意味着传递给函数的是原始数据的副本,而不是原始数据本身。这个行为直接影响函数内外对数据的操作范围和性能表现。 什么是…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信