第一个请求不在 goroutine 函数的开头发送
来源:stackoverflow
时间:2024-03-29 13:23:06 136浏览 收藏
哈喽!今天心血来潮给大家带来了《第一个请求不在 goroutine 函数的开头发送》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!
问题内容
我正在我的代码中运行 goroutine。比如说,如果我将线程设置为 50,它将不会运行前 49 个请求,但会运行第 50 个请求并继续处理其余请求。我不太确定如何描述我遇到的问题,并且它没有给出任何错误。这只发生在使用 fasthttp 时,并且在 net/http 上工作得很好。这可能是 fasthttp 的问题吗? (这不是我的全部代码,只是我认为发生问题的区域)
threads := 50 var lock sync.mutex semaphore := make(chan bool, threads) for len(userarray) != 0 { semaphore <- true go func() { lock.lock() var values []byte defer func() { <-semaphore }() fmt.println(len(userarray)) if len(userarray) == 0 { return } values, _ = json.marshal(userarray[0]) currentarray := userarray[0] userarray = userarray[1:] client := &fasthttp.client{ dial: fasthttpproxy.fasthttphttpdialertimeout(proxy, time.second * 5), } time.sleep(1 * time.nanosecond) lock.unlock()
这是我得到的输出(数字是剩余的请求数量)
200 199 198 197 196 195 194 193 192 191 190 189 188 187 186 185 184 183 182 181 180 179 178 177 176 175 174 173 172 171 170 169 168 167 166 165 164 163 162 161 160 159 158 157 156 155 154 153 152 151 (10 lines of output from req 151) 150 (10 lines of output from req 150) cont.
抱歉,如果我的解释令人困惑,我真的不知道如何解释这个错误
正确答案
我认为问题在于变量的范围。为了表示排队,我有一个并行工作线程池,它们全部从同一通道拉出,然后使用等待组等待它们。 确切的代码可能需要调整,因为我手头没有 go 编译器,但想法是这样的:
threads := 50 queueSize := 100 // trying to add more into the queue will blocke semaphore := make(chan bool, threads) jobQueue := make(chan MyItemType, queueSize) var wg sync.WaitGroup func processQueue(jobQueue <- chan MyItemType) { defer wg.Done() for item := range jobQueue { values, _ = json.Marshal(item) // doesn't seem to be used? client := &fasthttp.Client{ Dial: fasthttpproxy.FasthttpHTTPDialerTimeout(proxy, time.Second * 5), } } } for i := 0; i < threads; i++ { wg.Add(1) go processQueue(jobQueue) } close(jobQueue) wg.Wait()
现在您可以将项目放入 jobqueue
中,它们将由这些线程之一处理。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《第一个请求不在 goroutine 函数的开头发送》文章吧,也可关注golang学习网公众号了解相关技术文章。
声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习