草庐IT

perform_in

全部标签

mongodb - 构建包含字符串和正则表达式模式的 $in 数组

我有一个Mongo集合,集合中的每个文档都有一个sources数组属性。对此属性的搜索可以是精确匹配和正则表达式的组合。例如,当使用Mongoshell时,下面的查询搜索source='gasvalves'OR'hose'包含在源项中的文档。这和我预期的一样有效db.notice.find({sources:{$in:[/\bhose/i,'gasvalves']}})mgo中的事情变得有点棘手。因为$in数组中的某些项目可以是正则表达式,而其他项目是字符串-我想进行查询的唯一方法是使用$or:varregEx[]bson.RegExvarmatches[]string//dostuf

amazon-web-services - 缺失区域 : could not find region configuration in golang and aws sns

我是Golang和AWS的新手。我正在尝试使用AWSSNS发送短信。我已经设置了环境变量,然后尝试发送短信。exportAWS_ACCESS_KEY_ID=AKIAIOSFODN..exportAWS_SECRET_ACCESS_KEY=wJalrXUtnFEM..exportAWS_DEFAULT_REGION=us-west-2我试图调试我出错的地方但总是报错MissingRegion:找不到区域配置packagemainimport("fmt""github.com/aws/aws-sdk-go/aws""github.com/aws/aws-sdk-go/aws/session

go - 为什么 "gofmt -d"给出 "computing diff: exec: "diff": executable file not found in %PATH%"error on windows?

我想看看我在golang文件中犯了哪些错误。为了弄清楚,我发出这样的命令:gofmt-dmyfile.go根据gofmt--help手册,它应该列出文件的当前版本和所需版本的差异。取而代之的是,它会生成此错误消息:computingdiff:exec:"diff":executablefilenotfoundin%PATH%如何解决这个问题? 最佳答案 gofmt工具假设系统已经安装了可用的diff。遗憾的是,此工具不是标准Windows安装的一部分,因此您需要手动添加它。对于我们大多数人来说,最简单的方法是添加我们计算机上已有的d

performance - 大量内存使用会减慢不相关的代码

我正在维护一个读取和写入大量数据的Go项目的代码,并且已经成功完成了一段时间。最近,我做了一个改变:一个大约有200万条记录的CSV文件在程序开始时加载到一个带有struct值的map中。该映射仅用于B部分,但首先执行A部分。这第一部分的运行速度明显比以前慢(处理时间翻了两番)。这很奇怪,因为那部分逻辑没有改变。我花了一个星期试图解释这是如何发生的。以下是我采取的步骤(当我提到性能时,我总是指A部分,它不包括将数据加载到内存中的时间,实际上与它无关):该程序在Docker容器内的服务器上运行。但是我已经能够在没有容器的情况下在我的笔记本电脑上重现它:与在内存中没有加载文件数据的情况下运

go - Confluent Kafka Golang 客户端生产者 "Broker: Not enough in-sync replicas"

我正在尝试测试生产者使用Golang客户端向kafka集群上的主题写入消息。这可以很好地写入本地集群上的主题,我只是复制并粘贴了他们的示例代码githubrepo.packagemainimport("fmt""gopkg.in/confluentinc/confluent-kafka-go.v1/kafka")funcmain(){p,err:=kafka.NewProducer(&kafka.ConfigMap{"bootstrap.servers":"localhost"})iferr!=nil{panic(err)}deferp.Close()//Deliveryreporth

mysql - 将 “SELECT *” 列(多于一个)读入 [][]string in go

我想在Go中将MySQL数据库列插入到[][]string中,这是一个类似的代码,它只对一列执行此操作并将其插入到[]string中,但我需要更多列到[][]string中制作数据框。mysql>select*fromusers;+----+-----------+----------+----------+-------------------------------+--------------+|id|fname|lname|uname|email|contact|+----+-----------+----------+----------+------------------

go - 使用 Go 模块时生成 in-repo protos 的最佳实践

tl;dr以前配置为使用GOPATH的repo现在配置为模块。一切都很好,越来越好。但是,protoc正确地(!)为在github.com/path/to/repo/protos结构中的repo中定义的protobufs生成Golang代码,而我现在更喜欢在我的源代码中生成这些代码,在GOPATH之外。我正在移动他们来解决这个问题。有更好的解决方案吗?我有一个GitHub存储库。为了方便讨论,我们称它为github.com/acme/toolbox。在子目录中,我有protobuf文件,其中包括:packageacme.toolbox.v1;optiongo_package="gith

go - 将值传递给结构时为 "missing type in composite literal"

我在下面这样定义了我的结构:typeS_LoginSuccessedstruct{Codeint`json:"code"`Datastruct{Userstruct{Sexstring`json:"sex"`IsVipbool`json:"is_vip"`Namestring`json:"name"`}`json:"user"`}`json:"data"`Timestampint64`json:"timestamp"`Messagestring`json:"message"`}我用这个来调用它:success_message:=S_LoginSuccessed{123,{{"male"

performance - Go - 在用于负载测试的高性能 http 客户端中,如何阻止/忽略所有 cookie?

我正在为我的公司创建工具来对我们的系统进行负载测试。我目前有用Python编写的工具,但我正在探索使用Go的选项,希望提高效率和性能,因为我们需要同时生成数百万用户(每个盒子有数千个,有很多盒子)并且每一点都很重要。我的用户主要对我们的系统进行http调用,我需要一个非常轻量级和高效的http客户端。对于我们的Python工具,以前的员工有一些功能手动处理和重用套接字并完全忽略cookie。虽然我是Go的新手,但到目前为止我已经比较了多个Go网络实现,我对CPU和网络使用情况很满意,所以我认为我还不需要手动管理套接字,但是RAM使用率比我们的Python解决方案高出数倍。我怀疑这是由于

performance - 为什么我在使用范围时看到某些尺寸的 map 速度变慢?

在我的计算机上,当我访问特定大小的map时,我看到每秒读取量下降,但它不会以线性方式降低。事实上,性能会立即下降,然后随着大小的增加缓慢恢复:$gorunmap.go4259841425985273578wps::18488800rps227909wps::1790311rps$gorunmap.go40000010000500000271355wps::18060069rps254804wps::18404288rps267067wps::18673778rps216442wps::1984859rps246724wps::2461281rps282316wps::3634125rp