草庐IT

ejb-timer-service-app

全部标签

amazon-web-services - 您如何在无服务器架构中平衡 nosql 存储和缓存?

我正在为无服务器环境(aws)编写一个基于go的应用程序。我对编写应用级代码还很陌生,而且我有基础架构背景。我知道缓存不是持久性的,但我真的需要关心真正无服务器环境中的持久性吗?从需求的角度来看,简单的dynamodb表可以满足我的存储需求,但缓存会给我更好的性能,对吧?我需要性能,这是我为应用程序使用go的一个重要原因。 最佳答案 您可以选择AWSElastiCache(redis或memcache),但这并不是真正的无服务器,因此可能不是一个选择。AWSLambda允许您在/tmp目录中写入,您可以在内存中缓存一些内容。不过,我

google-app-engine - 云数据存储 client.GetAll 类型不匹配但 client.Get 有效

我正在appengine中编写一个go应用程序,它连接并返回来自datastore实体的一些信息。我遇到了一个问题,其中client.Get正在使用预定义结构,但client.GetAll抛出类型不匹配(反之亦然)。我对两者都使用以下结构:typemyStructstruct{IDint64Field1stringField2stringRelease_Datetime.Time}这在Release_Date被定义为time.Time时起作用(如果int则失败):k:=db.datastoreKey(id)myStruct:=&myStruct{}iferr:=db.client.Ge

go - time.Timer 的行为

我是Go的新手,时间包让我有点困惑。所以我正在制作一个聊天框,想法是当你发送消息时,计时器重置为20秒,如果你在20秒内没有回复,你就会被踢出局。我的代码只有在该人输入内容时才有效,但如果他们从未输入任何内容,他们就不会被踢出局。我尝试在for循环之前应用Stop(),但它不起作用。我应该在循环前后而不是在for循环内执行所有计时器吗?func...{timer:=time.NewTimer(20*time.Second)forinput.Scan(){gofunc(){ 最佳答案 你可以使用time.AfterFunc;例如;pa

google-app-engine - Appengine 应用程序部署 - 错误 : At least one handler must be provided

应用引擎入门。我的应用没有前端。它是一个tcp/udp套接字服务器。当我尝试部署时,标题中出现错误。处理程序是为了什么?它不是网络应用程序。appengine是服务器应用的错误谷歌服务吗? 最佳答案 您始终可以添加骨架Web处理程序(它可能只返回404)以使部署实用程序满意。但请注意,GAE标准环境沙箱对基于套接字的应用程序非常严格,请参阅Limitationsandrestrictions:AlthoughAppEnginesupportssockets,therearecertainlimitationsandbehaviors

amazon-web-services - AWS 单 session 还是多 session ?

我正在AWS云上托管的Golang中创建一个应用程序,它使用多种AWS服务,即S3、DynamoDB、ParameterStore。目前,处理每个AWS服务的各个模块都有自己的AWSsession。awsSession,err:=session.NewSession(&aws.Config{Region:aws.String(os.Getenv("AWS_REGION"))})从性能的角度来看,这是正确的方法,还是在主程序中创建单个session并将引用传递给单个模块会是更好的方法? 最佳答案 建议尽可能重用session。来自AW

amazon-web-services - 在 Golang 中使用 UploadPartCopy 到 MultiPartUpload 时遇到 AccessDenied

我正在尝试使用S3MultipartUpload来连接S3存储桶中的文件。如果您有多个大于5MB的文件(最后一个文件可以更小),您可以在S3中将它们连接成一个更大的文件。它基本上等同于使用cat将文件合并在一起。当我尝试在Go中执行此操作时,我得到:调用UploadPartCopy操作时发生错误(AccessDenied):拒绝访问代码看起来像这样:mpuOut,err:=s3CreateMultipartUpload(&S3.CreateMultipartUploadInput{Bucket:aws.String(bucket),Key:aws.String(concatenated

google-app-engine - Google App Engine goapp "deploy"工作但 "serve"失败,这是怎么回事?

我今天开始使用GoogleAppEngine,所以希望答案对有经验的人来说是显而易见的。在简单地关注thismethod之后为了让AppEngine与CloudSQL接口(interface),我遇到了一个令人沮丧的问题:goappdeploy成功但goappserve失败(使用云外壳)。这是错误:XXXX@cloudshell:~/src/XXXX/app-engine(XXXX)$goappserveapp.yamlINFO2018-06-2107:29:08,115devappserver2.py:764]SkippingSDKupdatecheck.INFO2018-06-21

google-app-engine - 如何在本地谷歌应用引擎环境中创建拉/推队列

我需要在本地启动我的谷歌应用引擎项目。它在谷歌服务器上正常工作,但调试变得很痛苦,因为在每个修复上部署都需要很多时间。我几乎已经设法在本地启动它,但我不明白如何创建队列,这是必要的。我的步骤:运行dev_appserver.pyapp.yaml,遵循usinglocaldevelopmentserver指导。除队列外一切正常:_,err:=taskqueue.Add(u.Ctx(),task,queueName)exceptions.ThrowIfErr(true,"err_msg",err)throwPanic!UserMessage:,Error:APIerror1(taskque

google-app-engine - Google App Engine Algolia 索引错误

我将GoogleAppEngine用于带有algolia的golangapi,并且我一直在本地主机中工作(索引记录),没有任何问题,今天我部署了它以对其进行实时测试,并且我的所有索引操作都遇到了这个错误无法执行请求[POST]/1/indexes/INDEXNAME/batch(APPID.algolianet.com):发布https://APPID.algolianet.com/1/indexes/INDEXNAME/batch:dialtcp:lookupAPPID.algolianet.comon[::1]:53:dialudp[::1]:53:socket:operation

amazon-web-services - 如何将 S3 数据加载到本地内存,而不是保存到文件

这个问题在这里已经有了答案:Howtokeepfilesinmemory-transferringfilesbetweenserverswithoutstoringthemlocally(1个回答)关闭4年前。这是我当前的代码:import("time""reflect""io/ioutil""fmt""os""github.com/golang/protobuf/proto""github.com/aws/aws-sdk-go/service/s3""github.com/aws/aws-sdk-go/service/s3/s3manager""github.com/aws/aws-