草庐IT

play-services-vision

全部标签

docker - 无法连接到 docker 容器中的数据库主机,从 api-service 到 db-service,以便在 golang 中使用 goose 进行迁移

goose是帮助我运行所有*sql文件并在数据库中运行查询的迁移工具。我想在我的api服务的docker容器中使用此工具自动执行迁移(创建表和其他内容)。问题是当docker运行命令“gooserun”时出现错误-gooserun:dialtcp:lookupdbon192.168.63.6:53:nosuchhost。docker-composeservices:db:build:./dbvolumes:-./db/pgdata:/pgdataimage:postgresports:-"5432"restart:alwaysenvironment:-POSTGRES_USER=use

amazon-web-services - 使用 AWS SQS 的最有效方式(使用 Golang)

使用AWSSQS(简单队列服务)时,您需要为向该服务发出的每个请求(推送、拉取……)付费。您可以发送到队列的每条消息最大为256kb。为了省钱,我想在将消息发送到SQS之前缓冲发送到我的Go应用程序的消息,直到我有足够的数据来有效地使用256kb的限制。由于我的Go应用程序是一个网络服务器,我目前的想法是使用字符串互斥锁并附加消息,只要我超过256kb限制,然后发出SQS推送事件。为了节省更多空间,我可以在将每条消息附加到字符串互斥量之前对其进行gzip压缩。我想知道是否有某种gzip流可以用于此目的。我的假设是,将所有连接的消息gzip在一起会导致更小的大小,然后gzip每条消息,然

amazon-web-services - 运行代码部署 Hook 时找不到 Go 命令

您好,我正在尝试为我的golang应用程序创建一个CodeDeploy部署。我有一个自动缩放组,它使用我创建的AMI,它安装了我需要的所有库。当我尝试运行CodeDeploy时,它在我的after_install中存在错误:LifecycleEvent-AfterInstallScript-scripts/after_install.sh[stderr]/opt/codedeploy-agent/deployment-root/a65d9a2e-fddd-471c-8ea1-c018792d00bd/d-4IKP3PP4Y/deployment-archive/scripts/afte

amazon-web-services - 尝试在 awsgosdk 的帮助下在 terratest 中调用 cloudwatch loggroupname 和 logstreamname

在terratest中,我想调用awscloudwatch特定的日志组名称和日志流名称下面的代码来自github但不知道如何调用特定的日志组和日志流https://github.com/awsdocs/aws-doc-sdk-examples/blob/master/go/example_code/cloudwatch/CloudWatchGetLogEvents.go 最佳答案 尝试这样的事情c:=aws.NewCloudWatchLogsClient(t,awsRegion)t.Run("logStreamExists",fun

amazon-web-services - 有没有什么方法可以为 CloudWatch Logs 的系统字段设置值?

我想在lambda执行中为字段@requestId设置值,因为在源代码中显式输出的日志不包含@requestId字段值。我读过anarticle并尝试输出如下日志,但@requestId未被填充。fmt.Print(`{"requestId":"comeon!!"}`)下面的代码都不是。fmt.Print(`{"@requestId":"comeon!!"}`)系统字段是否受到保护? 最佳答案 当触发AWSLambda函数时,context元素会传递给该函数。来自AWSLambdaFunctionHandlerinGo-AWSLam

amazon-web-services - API 网关集成请求 HTTP header 未将查询字符串映射到 header

在Api-Gateway上,我正在尝试设置从“方法请求”查询字符串到“集成请求”header到lambda的映射,但映射永远不会到达lambda函数。在“方法请求”>“URL查询字符串参数”上,我将其设置为“customerIdentification”然后如文档所述:doc转到“集成请求”>“HTTPheader”添加名称“userId”并映射到“method.request.querystring.customerIdentification”packagemainimport("context""encoding/json""fmt""github.com/aws/aws-lam

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

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

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