草庐IT

Docker-Compose部署RabbitMQ

全部标签

go - 当我更新节点或使用 client-go 部署时,我偶尔会遇到这样的错误 "the object has been modified"

当我更新节点或使用client-go部署时,我偶尔会收到这样的错误“对象已被修改;请将您的更改应用到最新版本并重试”。我的目标是添加一个污点/容忍度和一个一个节点/部署的标签。有人说应该用err=retry.RetryOnConflict(retry.DefaultBackoff,func()error{}),但是好像不行。funcAddFaultToleration(deploy*appsv1.Deployment,nsstring,clientkubernetes.Interface)(*appsv1.Deployment,error){updateDeploy,err:=clie

docker - 当 PIPE docker 中的输出时从 os.Stdin 读取时被阻止

我正在尝试将程序的输出(日志)通过管道传输到Go程序,该程序聚合/压缩输出并上传到S3。运行该程序的命令是“/program1|/logShipper”。logShipper是用Go编写的,它只是从os.Stdin读取并写入本地文件。本地文件将由另一个goroutine处理并定期上传到S3。有一些现有的docker日志驱动程序,但我们在完全托管的提供程序上运行容器并且日志处理费用非常昂贵,因此我们想绕过现有解决方案并直接上传到S3。logShipper的主要逻辑只是从os.Stdin读取并写入某个文件。它在本地机器上运行时工作正常,但在docker中运行时,goroutine在read

go - RabbitMQ 消费者性能 - 预取与并发

我有一个Go应用程序处理来自单个RabbitMQ队列的事件。我用github.com/streadway/amqpRabbitMQ客户端库。Go应用程序在大约2-3秒内处理每条消息。如果我从内存中输入消息,则可以并行处理~1000条甚至更多消息。但是,不幸的是,RabbitMQ的性能更差。所以,我想更快地使用队列中的消息。因此,问题是:如何使用github.com/streadway/amqp以最有效的方式使用消息?据我了解,有两种方法:设置高预取https://godoc.org/github.com/streadway/amqp#Channel.Qos.使用单个消费者协程示例代码:

由于 : "go directory outside available modules",Docker 构建失败

我在构建我的go服务的Docker镜像时遇到问题(请参阅最后的错误消息)。我的服务代码结构如下:cmd-duc-adobepkg-adobe-common.gitignoreDockerfilego.modgo.sum这是我的Dockerfile:#buildimageFROMgolang:1.12-alpineasbuilderRUNapkupdate&&apkadd--no-cachegitca-certificates&&update-ca-certificatesWORKDIR/app#firstdownloaddependenciessothatwecanutilizethe

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

json - 如何正确反序列化包含来自 JSON 的顶级数组的 RabbitMQ 消息

我尝试这样做:casemessage:=它工作了一些迭代,而不是因错误解码:JSON输入意外结束和message.Body==nil而失败。但是一切正常,如果JSON不是对象列表([{...},{...},...]而只是单个对象{...}我试过了RmqMessagesstruct{Messages[]RmqMessage}rmqMessages:=RmqMessages{}err:=json.Unmarshal(message.Body,&rmqMessages.Messages)同样的结果我做错了什么? 最佳答案 错误是在ack循

go - Travis CI 找不到 GitHub 部署的发布文件

尽管在SO上尝试了其他答案,但我无法让TravisCI找到我的发布文件夹进行部署。我有一个像这样运行发布的Makefile:release:mkdir-preleaseenvGOOS=linuxGOARCH=amd64$(GOBUILD)-orelease/$(CLI)-$(VERSION)-linux-amd64$(BINARY_NAME_CLI)envGOOS=darwinGOARCH=amd64$(GOBUILD)-orelease/$(CLI)-$(VERSION)-darwin-amd64$(BINARY_NAME_CLI)envGOOS=windowsGOARCH=amd6

docker - 在 Dockerfile 和 docker-compose 中编写什么来传递本地包

我为服务器端api引入了带有gomodules的本地包。通过命令gorunmain.go,它在本地环境中运行良好,没有错误。但是在命令docker-composeup时不起作用。我想知道如何修复Dockerfile和docker-compose.yml。我在article目录下命令gomodinit。因此,它在go.mod中设置modulegithub.com/jpskgc/article。article├db├client├api│├main.go│├controller││└controller.go│└Dockerfile├nginx├docker-compose.yml├go.

shell - 无法使用exec在Go中为docker运行netstat

尝试使用exec在Go中运行终端命令以获取docker网络使用但无法。以下链接显示了如何使用终端获取docker容器的网络使用情况,它在终端中工作正常但不使用Go。https://docs.docker.com/config/containers/runmetrics/我得到退出代码1、2、125等,具有不同的组合。stdin,err:=cmd.StdinPipe()iferr!=nil{log.Fatal(err)}deferstdin.Close()io.WriteString(stdin,"CID="+CID)//containerIDio.WriteString(stdin,"

google-app-engine - 将简单的 golang 应用程序部署到 appengine 已停止工作

我在golang中创建了一个小型测试应用程序,并尝试将其部署到GoogleAppEngine,尽管“gcloudappdeploy”命令似乎有效并且没有报告任何错误,但当我访问端点时->https://XXX.appspot.com/cards它只是坐在那里,最终给我一个500响应,并显示错误(在浏览器中)Error:ServerErrorTheserverencounteredanerrorandcouldnotcompleteyourrequest.Pleasetryagainin30seconds.我对gogolang和AppEngine相当陌生,但我最近制作了几个可用的应用程序