草庐IT

不正当竞争

全部标签

unit-testing - 表驱动测试中的竞争检测

我有一个表驱动测试和表循环外的initvar(worker)。我使用gotest-raсe运行测试并添加了t.Parallel()并且没有检测到竞争条件。我可以假设我的测试没有竞争条件吗://Thismockcouldbeinaseparatefile.typemockWorkerstruct{}//implmentourWorkeriterfacefunc(mdmockWorker)Work()error{returnnil}typemockDoerstruct{ErrorerrorWorkerworker}//implmentourDoeriterfacefunc(mdmockDo

go - 从两个不同的互斥体报告的数据竞争

今天出现了一个有趣的问题,我的代码包含多个Mutex,每个都覆盖不同映射的锁定。这是我正在使用的源代码的结构相似:typeMyStructstruct{dogMutexsync.RWMutexdogMapmap[int]Dog//keyedbyPIDcatMutexsync.RWMutexcatMapmap[int]Cat//keyedby(localAddress+localPort)}这里有一个更详细的问题示例:https://play.golang.org/p/eic8q2VrNq在使用“gobuild-race...”构建可执行文件后,生成的可执行文件报告以下竞争由于代码比上面

multithreading - 以下无锁代码是否表现出竞争条件?

在KubernetesGorepoonGithub.com内,有一个HighWaterMark数据结构的无锁实现。此代码依赖于原子操作来实现没有数据竞争的线程安全代码。//HighWaterMarkisathread-safeobjectfortrackingthemaximumvalueseen//forsomequantity.typeHighWaterMarkint64//Updatereturnstrueifandonlyif'current'isthehighestvalueeverseen.func(hwm*HighWaterMark)Update(currentint64

跨并行 goroutine 共享 channel 时的 Golang 竞争条件

我正在编写此示例代码来自学如何跨并行goroutine共享channel,但我遇到了竞争条件。该程序应该启动与系统上可用的CPU一样多的goroutine。第一个访问blchannel的goroutine立即将channel设置为包含false,这样就没有其他goroutine可以访问范围超过stchannel的循环。其他goroutine应该在第一个访问blchannel的goroutine从stchannel读取并打印每个值时结束。packagemainimport("fmt""runtime""strconv""math/rand""time""sync")funcmain(){

http - 由于来自服务器的 mime 不正确,无法使用 Go 打开 Zip

我有一个向服务器发送zip文件的应用程序。然后对zip进行操作,并在响应中发回一个新的zip。问题是发回的响应有application/octet-stream而不是application/zip消息的mime。我认为这就是为什么archive/zip无法打开生成的zip并且我得到一个zip:notavalidzipfile的原因。在检索zip文件时,我有什么办法可以更改mime吗?我获取zip的代码:funcGetZipFromServer(zipnamestring){//////////////////////////////////////////////////////Ope

go - JWT 始终有效,即使传递的参数不正确

我正在使用jwt-go库,并且我已经编写了用于在我的应用程序中实现它的测试。但是,无论我创建什么token,它都会被返回为有效。我猜我不是在检查什么。documentation已过时,因为声明不再支持索引。这是我的应用程序代码://AuthService-providesauthenticationtypeAuthServicestruct{}//CreateToken-signsandencryptsauthtokenfunc(a*AuthService)CreateToken(email,passwordstring)(string,error){token:=jwt.New(jw

go - 当只读来自 HTTP 处理程序的共享结构时如何防止竞争条件

我需要从struct更新值并返回(只读)而不是从HTTP处理程序写入,以避免出现竞争条件我正在使用sync.Mutex这是一个基本示例:http://play.golang.org/p/21IimsdKP6epackagemainimport("encoding/json""log""net/http""sync""time")typeCounterstruct{countuintflagboolmusync.Mutexquitchanstruct{}timetime.Timewgsync.WaitGroup}func(c*Counter)Start(){c.count=1c.time

go - 与列表的数据竞争。使用互斥锁列出并发访问

我正在进行数据竞赛,但我不太明白为什么。使用-race命令运行我的测试我已将其缩小到尝试访问list.List并从中读取它,但我的互斥体似乎没有这样做任何事物。我在一个数组中有许多*list.Lists:typeMyListstruct{mutexsync.Mutex*list.List}typeSomeObjstruct{datastring}varmyListOfLists[10]MyList我正在像这样从列表中读取和写入:list:=myListOfLists[someIndex]list.mutex.Lock()fore:=list.Front();e!=nil;e=e.Nex

go - 如何锁定 map 并修复数据竞争

我正在尝试解决WARNING:DATARACE这是代码:packagemodelsimport("sync""time")typeStatsstruct{sync.Mutexrequestmap[int64]int}func(s*Stats)PutRequest(){s.Lock()s.request[time.Now().Unix()]++s.Unlock()}func(s*Stats)GetRequests()map[int64]int{s.Lock()m:=s.requests.Unlock()returnm}varRequests=Stats{sync.Mutex{},make

go - 如何转储正在运行的 kubelet 的 goroutines 堆栈竞争

kubernetes比较复杂,kubelet在某些场景长时间运行会出现死锁。有没有办法转储正在运行的kubelet的goroutine堆栈跟踪?如下所示的预期输出对调试kubelet的死锁类问题非常有帮助。goroutine386[chansend,1140minutes]:k8s.io/kubernetes/pkg/kubelet/pleg.(*GenericPLEG).relist(0xc42069ea20)/workspace/anago-v1.11.5-beta.0.24+753b2dbc622f5c/src/k8s.io/kubernetes/_output/dockeriz