草庐IT

service-model

全部标签

concurrency - Go Memory Model文档中给出的这个例子失败的原因是什么?

在Go内存模型文档中http://golang.org/ref/mem它给出了以下示例:varastringvardoneboolfuncsetup(){a="hello,world"done=true}funcmain(){gosetup()for!done{}print(a)}然后它说这个例子的以下内容。"thereisnoguaranteethatthewritetodonewilleverbeobservedbymain,sincetherearenosynchronizationeventsbetweenthetwothreads.Theloopinmainisnotguar

model-view-controller - 我可以在golang中根据字符串实例化不同的类型吗?

我想用golang实现MVC。但似乎很难实现我想要的。在Testcontroller.go中我有:func(c*TestController)Test(){//}func(c*TestController)Index(){//}只有一个Controller,我可以使用reflect.ValueOf(TestController{}).MethodByName().Call()来执行该功能。现在我想添加另一个Controller。但似乎我无法通过不同的字符串新建不同的实例:controllerName:=strings.Split(r.URL.Path,"/")controller=re

python - 应用引擎 : convert ndb model to go lang struct

我在AppEngine上有一个python模块和一个go模块。go模块相当简单,只是为由python模块填充的数据存储提供一个只读搜索接口(interface)。如何将以下ndb模型转换为go结构:classCourse(ndb.Model):name=ndb.StringProperty()neat_name=ndb.StringProperty(required=True)country=ndb.KeyProperty(kind=Country,required=True)university=ndb.KeyProperty(kind=University,required=Tru

amazon-web-services - AWS S3 Golang SDK - 上传文件 - 错误的区域

我在尝试通过官方GolangAWSSDK将文件上传到S3时遇到问题。我的目标是指定位于北加州地区(us-west-1)的存储桶。我可以在S3资源管理器中看到它;但是,当我运行put操作时,出现以下错误:BucketRegionError:incorrectregion,thebucketisnotin'NorthernCalifornia'region这就是我设置连接的方式:creds:=credentials.NewStaticCredentials(aws_access_key_id,aws_secret_access_key,token)_,err:=creds.Get()con

model-view-controller - 路由器找不到 Controller Beego

我有一个正在运行的beego应用程序,然后我的路由器停止寻找Controller,我不知道为什么。无论我输入什么url,路由器都不会指向提示nomatch的Controller2016/07/2617:24:50[router.go:829][D]|GET|/|478.352µs|notmatch|app.confappname=exampleapphttpport=8080runmode=devrouter.gopackageroutersimport("github.com/astaxie/beego""example/controllers")funcinit(){beego.R

json - 无法将字符串解码到 Go struct 字段 Article.article_type of type models.ArticleType

我无法将json字段article_type解码为golang结构Article。我遇到错误:json:无法将字符串解码到Gostruct字段Article.article_typeoftypemodels.ArticleTypestr:=[]byte(`[{"created_at":1486579331,"updated_at":1486579331,"article_type":"news"}]`)typeArticlestruct{IDuint`gorm:"primary_key"`CreatedAttimestamp.Timestamp`json:"created_at"`Up

amazon-web-services - aws s3 put 方法参数由 goamz

之前我使用的是"launchpad.net/goamz/s3"但是对于我的新项目,我正在使用"github.com/goamz/goamz/s3".并且桶的put方法发生了变化,现在它多了一个参数“选项”region:=aws.USEast2connection:=s3.New(AWSAuth,region)bucket:=connection.Bucket("XXXXX")//changethisyourbucketnamepath:="mypath"//thisisthetargetfileandlocationinS3//Saveimagetos3err=bucket.Put(p

amazon-web-services - 使用 API 代替 SDK 可以吗?

我喜欢快速的代码执行(因此我从Python切换到Go)并且我不喜欢依赖性。亚马逊建议使用SDK进行更简单的身份验证(但在Lambda中,我可以从环境变量中获取来自IAM的token),并且因为内置在SDK中会重试错误(我认为只有几行代码)。是的,使用SDK编写代码速度更快,但是使用纯HTTPAPI而不是SDK有哪些额外注意事项?我对毫秒太着迷了吗?这样的优化值得吗? 最佳答案 您使用AWS所做的任何事情都是API调用的结果,无论是通过CLI、Web控制台还是SDK执行。SDK使与这些API的交互变得更加容易。虽然您可能能够对某些调用

amazon-web-services - 在 Kinesis 流上发布消息是异步的吗?

是在Kinesis流上异步发布消息,还是有任何方法可以使用GoLangSDKAPI异步运行它? 最佳答案 documentation似乎对哪些操作是异步的非常透彻,所以我会说不:发布消息不是异步的。但这无论如何都是有意义的——如果操作尚未完成,它如何返回错误?但是你能让它异步吗?当然。在Go中,使任何东西异步都是微不足道的——只需在goroutine中运行它即可。如果您是goroutines的新手,ATourofGo是对这个概念的一个很好的介绍。 关于amazon-web-service

amazon-web-services - lambda 调用负载错误

我正在尝试使用GoSDK调用一个lambda函数(用Go编写)来自另一个应用程序,但遇到有效负载问题,但当我通过具有相同输出的控制台测试lambda函数时却没有。这里是调用lambda的函数:typeRedisPairstruct{RedisKeystring`json:"redis_key"`RedisValuestring`json:"redis_value"`}typeRedisBatchstruct{RedisPairs[]RedisPairGroupIdstring`json:"group_id"`}funclambdawrite(redisbatchRedisBatch){