草庐IT

安全通信存储

全部标签

go - 避免goroutines之间双向通信的死锁

我正在第一次体验Go,到目前为止我真的很喜欢goroutine和channels结构。我想知道是否有一种惯用的方法可以避免多个goroutine之间的双向通信出现死锁。考虑以下示例。共有三个goroutine:producer、worker和controller。生产者生产整数。实际上这可能是数据来了例如来自网络连接。worker从生产者那里接收数据,并对其进行一些操作它。然后,worker将修改后的数据发送给controller。在某些情况下,Controller会向worker发送命令。在里面例如,如果接收到的整数大于180,就会发生这种情况。当Controller试图向工作人员发

go - 如何在 golang 中模拟 GCP 的存储?

我真的不熟悉在go中模拟第三方库,我现在正在模拟cloud.google.com/go/storage我正在使用mockery.这是我当前的界面://ClientstorageclienttypeClientinterface{Bucket(namestring)BucketHandleBuckets(ctxcontext.Context,projectIDstring)BucketIterator}//BucketHandlestorage'sBucketHandletypeBucketHandleinterface{Attrs(context.Context)(*storage.B

go - 如何在 DataStore 中存储 *time.Time 类型的结构字段的当前时间?

这个问题在这里已经有了答案:Assignvaluereturnedfromfunctiontopointer(1个回答)关闭3年前。根据我的要求,我创建了一个结构为-typeMyRulestruct{CreatedAttime.Time`json:"createdAt"datastore:"createdAt,noindex"`UpdatedAt*time.Time`json:"updatedAt"datastore:"updatedAt,noindex"`}对于createdAt字段,我可以将当​​前时间存储为-MyRule.CreatedAt=time.Now()但是,将当前时间存

go - 使用 golang 在 google-cloud 数据存储中仅检索具有 key 的特定属性

MyKind有3个实体:FirstName、FamilyName和Email。我只想检索与该实体关联的Key和FirstName。在SQL中像这样:SELECTId,FirstNamefromusers;在go-lang中,我尝试像这样获取Kind中的所有数据q:=datastore.NewQuery(dataKind)然后为了拿到key,我这样做了:键,错误:=q.GetAll(ctx,&users)我不想获取所有属性,而只想获取键和名字。我想知道是否有办法在单个数据存储区查询中执行此操作?正如我之前的问题中提到的,我是go-lang和数据存储的新手。请帮忙

go - 无法使用默认服务帐户和谷歌云库从谷歌 Kubernetes 引擎访问谷歌云存储

我编写了一个应用程序,它具有使用golang通过GoogleKubernetesEngine上传图像的功能。其他一切正常,但当我尝试将图像写入GoogleCloudStorage时,我一直遇到问题。这是我在golang中实际使用googlestorageapi的代码:funcputImage(imageURLstring,imagemultipart.File)bool{fmt.Println("Puttingintoimagelocation:"+imageURL)contextBackground:=context.Background()storageClient,err:=st

go - 将多个文件传递给存储桶中的 exec.Command 调用

我正在尝试构建一个用Go编写的云函数,它将使用Google的CloudFunctions基础架构中可用的ImageMagick库来将多个图像合成并处理成最终的输出图像。问题的根源是我想使用的ImageMagick函数可用,但它需要多个不同的输入才能工作。我的输入是存储桶中的对象。os/execCmd结构允许您通过使用“ExtraFiles”数组来执行此操作,而且我知道如何将这些额外文件提供给我的ImageMagick命令。但是,“ExtraFiles”数组只想存储os.File的实例,而GCPStorageClient在您打开文件时会为您提供一个“Reader”实例。backgroun

go - 如何使一个 pod 与另一个 pod 的本地主机通信

我已经在Go中实现了一个gRPC客户端服务器。我现在已经在Kubernetes中将它们设置为客户端和服务器pod,客户端在其中连接到服务器。我在我的电脑上使用vagrant(centos/7)设置了这个集群。我的问题是客户端想要访问端口8090(服务器在此端口上服务)并向服务器发送消息,但是由于它们位于不同的pod中,客户端无法访问本地主机8090,因此pod失败。我该如何解决这个问题?funcmain(){conn,err:=grpc.Dial(":8090",grpc.WithInsecure())iferr!=nil{log.Fatalf("didnotconnect:%v",e

go - 简单的服务器客户端通信不起作用

这个看似简单的例子并没有像预期的那样工作,我不好意思问这个问题,但是这里是:有一个客户端重试连接到服务器,发送消息,然后等待响应:funcclient(){varconnnet.Connvarerrerror//retryserveruntilitisupfor{conn,err=net.Dial("tcp",":8081")iferr==nil{break}log.Println(err)time.Sleep(time.Second)}//writetoserver_,err=conn.Write([]byte("request"))iferr!=nil{log.Println(er

go - 如何从数据存储中读取自定义类型

我有一个数据存储表,就像那样Name/ID|UserEmail|UserRole|UserPermissions------------------------------------------------------json中的UserRole属性是一个string。但是,在Go代码中,它是一个类型typeUserDetailsstruct{NameIDstringUserEmailstringUserRoleUserTypeUserPermissionsstring//json??}typeUserTypestringconst(UnknownUserRoleUserType="

google-app-engine - 使用 Go 更新实体 Appengine 数据存储

我试图找到一个有效的示例,说明如何使用Go对应用引擎数据存储执行更新。我在网上找到的所有示例都非常模糊,主要是解释概念而不是“现实生活”。go的应用引擎文档说:...“更新现有实体是使用相同key执行另一个Put()的问题。”我的问题是如何检索key。所以我有下面的代码来存储和检索数据:funcsubscribe(whttp.ResponseWriter,r*http.Request){user:=User{Name:r.FormValue("username"),Email:r.FormValue("useremail"),Flag:0,}c:=appengine.NewContex