Golang并发网络请求批量处理示例

使用goroutine和channel可高效并发处理批量网络请求,通过限制并发数和加入超时控制优化资源使用。

golang并发网络请求批量处理示例

在Go语言中,使用并发处理批量网络请求是一种常见且高效的实践。通过 goroutine 和 channel,可以轻松实现多个请求的并行发送,并统一收集结果或错误。下面是一个实用的示例,展示如何并发地发起多个HTTP请求,并进行批量处理。

使用 Goroutine 和 Channel 批量请求

核心思路是为每个请求启动一个 goroutine,将结果通过 channel 返回,主协程通过 select 或 range 接收结果。

示例代码:

package main

import ("fmt""net/http""sync")

type Result struct {URL stringStatus intErr error}

func fetchURL(url string, ch chan<- Result) {resp, err := http.Get(url)if err != nil {ch <- Result{URL: url, Err: err}return}defer resp.Body.Close()ch <- Result{URL: url, Status: resp.StatusCode}}

func main() {urls := []string{"https://www.php.cn/link/98a733901e53052474f2320d0a3a9473","https://www.php.cn/link/8c4b0479f20772cb9b68cf5f161d1e6f","https://www.php.cn/link/874b2add857bd9bcc60635a51eb2b697","https://www.php.cn/link/ef246753a70fce661e16668898810624",}

var wg sync.WaitGroupch := make(chan Result, len(urls)) // 缓冲channel避免阻塞for _, url := range urls {    wg.Add(1)    go func(u string) {        defer wg.Done()        fetchURL(u, ch)    }(url)}// 关闭channel当所有goroutine完成go func() {    wg.Wait()    close(ch)}()// 收集结果for result := range ch {    if result.Err != nil {        fmt.Printf("请求 %s 失败: %vn", result.URL, result.Err)    } else {        fmt.Printf("请求 %s 成功,状态码: %dn", result.URL, result.Status)    }}

}

限制并发数量(使用信号量)

如果请求量很大,同时发起全部请求可能耗尽资源。可以通过带缓冲的 channel 实现并发控制。

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

改进版本:限制最大并发数

// 在main中修改goroutine启动方式semaphore := make(chan struct{}, 3) // 最多3个并发

for _, url := range urls {wg.Add(1)go func(u string) {defer wg.Done()semaphore <- struct{}{} // 获取令牌fetchURL(u, ch)<-semaphore // 释放令牌}(url)}

超时控制与上下文(Context)

实际应用中应加入请求超时,避免长时间等待。可使用 context 控制生命周期。

func fetchURLWithContext(url string, ch chan<- Result) {    ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)    defer cancel()
req, _ := http.NewRequestWithContext(ctx, "GET", url, nil)resp, err := http.DefaultClient.Do(req)if err != nil {    ch <- Result{URL: url, Err: err}    return}defer resp.Body.Close()ch <- Result{URL: url, Status: resp.StatusCode}

}

结果聚合与错误处理

可以根据需要对结果进一步处理,比如统计成功/失败数量,或只返回成功结果。

例如,在接收阶段统计:

successCount, failCount := 0, 0for result := range ch {    if result.Err != nil {        failCount++        // 可记录日志或重试    } else {        successCount++    }    fmt.Printf("[%s] %dn", result.URL, result.Status)}fmt.Printf("完成: 成功=%d, 失败=%dn", successCount, failCount)

基本上就这些。Golang 的并发模型让批量网络请求变得简单高效,合理使用 channel、WaitGroup 和 context 能写出稳定可靠的并发代码。注意控制并发数和设置超时,避免系统资源耗尽。

以上就是Golang并发网络请求批量处理示例的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

  • Go语言中映射(Map)的正确初始化:避免运行时错误

    本文深入探讨Go语言中映射(Map)的初始化机制。Go语言中的映射,包括作为函数命名返回值声明的映射,其默认零值为nil。在向nil映射中添加元素会导致运行时错误。教程将详细解释为何需要使用内置函数make来正确初始化映射,区分nil映射与空映射,并提供代码示例,确保开发者能避免常见的panic: …

    好文分享 2025年12月15日
    000
  • Golang实现小型HTTP文件服务器

    答案:Go可通过net/http包快速实现HTTP文件服务器。使用http.FileServer和http.Handle指定目录并监听端口即可提供文件服务,如fs := http.FileServer(http.Dir(“./static”))绑定根路径;通过http.Str…

    2025年12月15日
    000
  • Golang数组传递与指针传递区别

    Go中数组是值传递,函数内修改不影响原数组;若需修改则应传指针;切片因引用底层数组,修改会影响原数据;大数组建议用指针或切片以提升效率。 在Go语言中,数组传递和指针传递的行为有显著区别,理解这些差异对编写高效、正确的程序非常重要。 数组是值传递 Go中的数组是值类型,当把数组作为参数传递给函数时,…

    2025年12月15日
    000
  • Golang云原生环境下配置热更新示例

    答案:%ignore_a_1%通过文件监控与自动重启实现Golang应用免停机迭代,可集成Air等工具至Dockerfile并结合Kubernetes部署,配合skaffold实现文件同步;失败时依赖健康检查、回滚、监控告警与灰度发布保障稳定性,性能优化需减少重启频率、提升构建速度及利用缓存;除Ai…

    2025年12月15日
    000
  • Golang控制语句组合使用示例

    Golang控制语句可通过if、for、switch的嵌套与组合实现复杂逻辑,示例包括多层条件判断、循环嵌套及switch中结合for和if,同时支持break、continue与标签跳转控制循环,配合无条件switch、fallthrough和类型switch提升灵活性,合理使用缩进、注释、测试与…

    2025年12月15日
    000
  • Golang应用在K8s中自动伸缩示例

    答案:Golang应用在K8s中实现自动伸缩需依托HPA机制,结合容器化部署、资源请求与限制设置、Metrics Server数据支撑,并通过CPU、内存或自定义指标(如QPS、队列长度)触发伸缩;同时应用须设计为无状态、支持优雅关机、健康检查及高并发处理,确保伸缩高效稳定。 Golang应用在Ku…

    2025年12月15日
    000
  • Golangslice和数组操作性能对比分析

    数组固定长度适合小数据,切片动态扩容更灵活;遍历和访问性能相近,但传参和扩容时切片更高效;建议小规模用数组,大规模及动态场景用切片并预设容量。 在Go语言中,数组和切片是两种常用的数据结构,它们都可以用来存储相同类型的元素序列。虽然切片底层依赖数组实现,但在实际使用中,二者在性能表现上存在差异。理解…

    2025年12月15日
    000
  • GolangRESTful API设计与实现示例

    答案:Golang中RESTful API设计需选合适框架如Gin,定义资源端点,用JSON序列化数据,结合中间件处理日志、认证,通过状态码和自定义错误提升健壮性,采用JWT或OAuth2实现安全认证,并利用goroutine与连接池优化并发性能。 RESTful API设计与实现,在Golang中…

    2025年12月15日
    000
  • Golang在云原生环境中性能测试示例

    答案是:在云原生环境中,Golang性能测试需结合pprof、k6等工具,通过明确指标、模拟生产环境、持续监控与CI/CD集成,系统性地定位瓶颈并优化资源利用。 Golang在云原生环境中进行性能测试,说白了,就是为了确保你的Go应用在容器化、微服务化、弹性伸缩的云上跑得又快又稳,能扛住预期的流量冲…

    2025年12月15日
    000
  • Go GAE Datastore 结构体字段平滑重命名与数据迁移指南

    在Go语言的Google App Engine (GAE) Datastore应用中,直接重命名已存储结构体中的字段会导致数据加载错误。本文将详细介绍如何利用datastore.PropertyLoadSaver接口,通过实现其Load和Save方法,实现结构体字段的平滑重命名和数据迁移。这种方法允…

    2025年12月15日
    000
  • Golang函数变量与高阶函数实现技巧

    Go语言中函数是一等公民,可赋值给变量、作为参数传递或从函数返回,实现函数变量与高阶函数。函数变量通过func(参数) 返回值类型声明,可用于回调、策略模式、配置选项等场景;高阶函数能接收或返回函数,结合闭包可实现行为抽象、函数组合、装饰器、柯里化等灵活编程范式。闭包使返回的函数能捕获并保持外部变量…

    2025年12月15日
    000
  • Go GAE Datastore 结构体字段重命名与数据迁移策略

    本教程探讨在Go Google App Engine (GAE) Datastore中安全重命名结构体字段的方法。通过实现datastore.PropertyLoadSaver接口,可以在不进行大规模数据迁移的情况下,优雅地处理旧字段数据加载到新字段,并以新字段名保存数据,从而实现平滑的结构体演进。…

    2025年12月15日
    000
  • Go语言中切片与接口:类型转换的深层解析与实践

    在Go语言中,即使结构体实现了某个接口,其切片(如[]Person)也不能直接赋值给该接口的切片(如[]Model)。这是因为Go接口值和结构体在内存中的布局方式不同,导致[]Person和[]Model的内存结构完全不兼容。要实现这种转换,必须通过显式循环逐个元素进行类型转换,创建一个新的切片。此…

    2025年12月15日
    000
  • Golang组合模式处理菜单与目录结构

    组合模式通过统一接口处理层级结构,Go语言的隐式接口实现和多态特性使其更简洁灵活。 Go语言中的组合模式为处理菜单或文件目录这类具有层级结构的数据提供了一种异常简洁且强大的方法。它允许我们将单个对象(如一个菜单项或一个文件)和对象的组合(如一个子菜单或一个目录)视为同一种类型来操作,从而极大地简化了…

    2025年12月15日
    000
  • GolangIDE快捷键与调试功能配置技巧

    GoLand和VS Code是主流Go开发工具,掌握快捷键与调试配置可提升效率。GoLand中按Ctrl+Space触发代码补全,VS Code默认自动补全或手动调用,减少鼠标操作,提升编码流畅度。 Go语言开发中,选择合适的IDE并掌握其快捷键与调试配置,能显著提升编码效率。目前主流的Go开发工具…

    2025年12月15日
    000
  • Golang错误处理与测试覆盖率结合方法

    答案:Golang中通过自定义错误类型、错误包装与接口抽象,结合表驱动测试和模拟技术,可有效提升错误处理的测试覆盖率,从而增强代码健壮性、可维护性及故障排查效率,长远提升项目质量。 Golang的错误处理与测试覆盖率,在我看来,它们并非两个独立的技术点,而是一对紧密协作的伙伴,共同构建起软件的健壮性…

    2025年12月15日
    000
  • Golang切片基础操作与动态扩容技巧

    Golang切片是引用类型,基于底层数组的指针、长度和容量实现;创建方式包括基于数组、字面量和make函数;append操作可能触发扩容,扩容时若原容量小于1024则翻倍,否则增加1/4;扩容会分配新数组并复制数据,导致地址变化;为避免频繁扩容应预先设置足够容量;copy函数复制时以较短切片为准;n…

    2025年12月15日
    000
  • Go语言中带缓冲通道元素数量的测量与流控制实践

    本文详细阐述了在Go语言中如何使用内置函数len()获取带缓冲通道中当前排队元素的数量。通过示例代码展示其用法,并探讨了该功能在实现生产者-消费者模型中的流控制策略时的应用,同时强调了并发环境下测量结果的瞬时性特点。 len() 函数在通道中的应用 在go语言中,内置函数len()是一个多用途的函数…

    2025年12月15日
    000
  • Golang结构体指针与方法绑定实践

    Go中方法可绑定值或指针接收者,指针接收者操作原始实例,值接收者操作副本;2. 推荐使用指针接收者修改字段、避免大结构复制、保持方法集一致及接口匹配;3. 调用时Go自动处理取址,但需防范nil指针解引用导致panic。 在Go语言中,结构体与方法的结合使用非常频繁,而指针接收者在实际开发中更是常见…

    2025年12月15日
    000
  • Golang模块依赖可视化工具推荐与使用

    Go模块依赖可视化能解决项目结构不透明、循环依赖难查、模块耦合过高等痛点。通过go mod graph结合Graphviz可生成直观依赖图,快速识别核心依赖与潜在问题;使用modv等工具则支持交互式分析,提升大型项目可读性;IDE内置功能适合日常开发即时查看,助力团队高效协作与架构优化。 在Go语言…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信