草庐IT

Web模式

全部标签

mysql - 如何在我的 Go 程序中运行测试之前获取数据库模式

我必须为数据库交互运行Go测试。数据库模式位于.sql文件中。我有一个包含main包的文件夹A,我在A中有3个文件夹B、C和D,它们分别包含包B、C和D。B、C、D中有测试文件,但A没有任何测试。我想要一种方法,这样我就可以做一个gotest./...从A开始,我的所有测试都在将架构采购到mysql之后运行。我尝试在A中创建一个main_test.go文件并在其中放置一个TestMain函数。但它不起作用。 最佳答案 你可以在main_test.go上使用init函数packagemainfuncinit(){//loadandex

amazon-web-services - 如何使用此架构在 Elastic Search 中复制索引?

我有一个场景,我必须从多个来源导入数据(数百万条记录)并将其保存在数据库中。当用户尝试搜索与该数据相关的任何信息时,他们应该会在2-3秒内获得结果。为此,我设计了一个架构,在该架构中,我使用golang从多个来源导入数据并在AWSSQS中推送数据。我创建了一个lambda函数,它在AWSSQS有一些数据时触发。然后,此lambda函数将数据推送到AWSElasticSearch中。我创建了一个RestAPI,我使用它向用户提供结果。我每天早上都使用CRON来完成导入工作。现在我的问题是,如果有一批新数据出现,我想删除现有数据并用新数据替换所有数据。我坚持如何实现删除和添加新数据部分。我

git - 如何在不终止连接的情况下更新 docker web 应用程序?

我有一个docker-compose.yml,它有两个服务:一个数据库和我的Go应用程序。我的CI/CD管道调用托管此docker容器的服务器并运行此bash脚本:gitfetch&>/dev/nulldiffs=$(gitdiffmasterorigin/master)if[!-z"$diffs"]thenecho"PullingcodefromGitHub..."gitcheckoutmastergitpulloriginmaster#updateserverdocker-composeup--build-d#killallunuseddockercontainersdockers

go - Web 服务器和同时监听 nats

我的代码从终端读取输入并将这些值发送到nats,同时它需要一个http端点。它单独工作,但当我将所有这些组合起来时,它不会从nats中读取。如果您能指出正确的方向,我将不胜感激。packagemainimport("bufio""fmt"nats"github.com/nats-io/nats.go""html/template""log""net/http""os")funcmain(){wd,err:=os.Getwd()iferr!=nil{log.Fatal(err)}tmpl:=template.Must(template.ParseFiles(wd+"/template/m

go - 为什么我会得到这个适配器接口(interface)模式的无限循环

我需要将现有的API接口(interface)替换为考虑传入Authtoken并为传出服务调用发出机器对机器token的API接口(interface)。总而言之,这是一个使用gorilla/mux路由框架的API,我只是将端点添加到mux.NewRouter()。没有什么特别的......还;)。我一直在尝试几种不同的模式,但似乎最吸引人的是MatRyer在https://medium.com/@matryer/writing-middleware-in-golang-and-how-go-makes-it-so-much-fun-4375c1246e81中派生的适配器接口(inte

go - 将一片结构保存到 Cloud Datastore(Datastore 模式下的 Firestore)中的正确方法是什么?

我想在GoogleCloudDatastore(Datastore模式下的Firestore)中保存一部分结构。以电话簿和联系人为例。typeContactstruct{Key*datastore.Key`json:"id"datastore:"__key__"`Emailstring`json:"email"datastore:",noindex"`Namestring`json:"name"datastore:",noindex"`}typePhonebookstruct{Contacts[]ContactTitlestring}保存和加载这个结构没有问题,因为Datastorel

amazon-web-services - DynamoDB Marshal 和 unmarshal golang time.Time 自纪元以来以毫秒为单位

SDK默认将time.Time值编码为RFC3339字符串。您如何选择以其他方式编码和解码,例如自纪元以来毫秒?SDK提到了Marshaler和Unmarshaler接口(interface),但没有解释如何使用它们。 最佳答案 (当我正要发布我的问题时,我通过研究UnixTime的工作原理找到了答案)。要使用自定义Marshaler和Unmarshaler,您可以创建自定义类型。typeMillisTimetime.Timefunc(eMillisTime)MarshalDynamoDBAttributeValue(av*dyna

amazon-web-services - golang in goland kinesis.GetRecordsInput is not found while 方法是?

为什么找不到GetRecordsInput?编译不通过的可能原因是什么?谢谢 最佳答案 Ohhhhhhhh,如果你有这样的变量kinesis:={whatever}好吧,你只是把自己搞砸了!!!但当然会增加困惑kinesis.GetRecords工作得很好。在我尝试一些古怪的东西并跳出框框思考之前,这花了我一个小时的时间来研究。咕噜咕噜。 关于amazon-web-services-golangingolandkinesis.GetRecordsInputisnotfoundwhile方

amazon-web-services - 我无法读取环境变量(Go 中的 aws-lambda)

我想使用DynamoDBLocal和SAMCLI在本地环境中测试AWSLambda。我创建了一个简单的用户数据库表(id,名称),我正在尝试获取数据。我运行“samlocalstart-api--env-varstest/env.json”。当我访问“http://localhost:3000/users/1”时,发生错误。错误信息如下。我无法理解此错误消息的含义。如何修复此错误?{"errorMessage":"InvalidParameter:1validationerror(s)found.\n-minimumfieldsizeof3,GetItemInput.TableName

amazon-web-services - 尝试调用 Go AWS Lambda 函数时权限被拒绝

我创建了一个AWSLambda函数,我正在使用Webhook调用APIGateway以下是我使用gobuild-omain.go构建的代码,因为我一直在阅读您必须指定扩展名。packagemainimport("context""fmt""github.com/aws/aws-lambda-go/lambda")funcHandleRequest(ctxcontext.Context)(string,error){returnfmt.Sprintf("Hello!"),nil}funcmain(){lambda.Start(HandleRequest)}问题是即使我有publicper