草庐IT

Nginx的高可用集群

全部标签

nginx - Beanstalk 中的负载均衡 go 服务器

我正在尝试在使用GRPC/Protobuf进行数据序列化的AWSbeanstalk中对go服务器进行负载平衡。Beanstalk提供nginx作为客户端-服务器通信的反向代理,它使用http1.1协议(protocol)。这导致在代理和服务器之间交换虚假消息,但客户端消息似乎永远不会按预期到达服务器。任何干净的想法都会在这里有所帮助。 最佳答案 Nginx还不支持后端的http/2。我们中的一些人正在努力解决这个问题,但还需要四分之一的时间才能到达上游。您可以等待或使用Envoy(https://github.com/lyft/en

go - 在编译时检查 go 表达式的可用性

我正在为Go编写一个(业余)编译器。现在为了优化我想知道:有没有办法检查ast.Expr中的数据是否可以在编译时访问?我知道我可以解析为ast.*Lit。 最佳答案 目标代码是编译过程的结果。Inageneralsenseobjectcodeisasequenceofstatementsorinstructionsinacomputerlanguage,usuallyamachinecodelanguage(i.e.,binary).在编译完成之前,什么都不能访问。 关于go-在编译时检

go - Go中如何获取Riak KV集群和节点状态数据

我正在尝试通过Go程序监控Riak-KV。Riak有一个名为“riak-go-client”的go客户端,但它没有任何api来获取Riak性能/状态数据。有什么办法可以得到吗? 最佳答案 获得Riak性能/状态/指标的最佳方式可能是通过其statsHTTPAPI.它适用于任何语言,甚至可以使用curl。只要您知道如何通过HTTP连接和解析JSON,就应该能够使用它。使用API就像运行一样简单:curl-vhttp://127.0.0.1:8098/stats-H"Accept:application/json"它为您提供了很多有用的

docker - nginx反向代理到Golang服务器的Docker问题

我将nginx反向代理到golang服务器,每个代理都在其自己的docker容器中并正常运行。尝试连接到Go容器时,在我的本地Mac计算机和生产服务器LinuxDebian上,我都一直在Nginx中收到此错误。一周前,它在我的本地Mac机器上运行,突然之间不再可用nginx_1|2017/09/2801:29:54[error]5#5:*12upstreamtimedout(110:Connectiontimedout)whileconnectingtoupstream,client:172.23.0.1,server:,request:"GET/api/aboutHTTP/1.1",

go - 如何在 k8s 集群中使用 heapster 获取文件系统/使用情况

如何在k8s集群中使用heapster获取“文件系统/使用情况”?我使用heapstermonitork8s,但是我无法获取节点磁盘使用情况。有人帮忙吗? 最佳答案 curl-L10.233.8.12:/api/v1/model/nodes/node1/metrics/filesystem/usage?labels="resource_id:/"ws.Route(ws.GET("/nodes/{node-name}/metrics/{metric-name:*}").至(指标.InstrumentRouteFunc(“nodeMet

mongodb - 使用 golang 从已经运行的集群的主实例重播另一个 mongodb 实例中的 oplog

我正在以json格式存储来自正在运行的主要mongodb实例的操作日志[{"Timestamp":6477723955623886852,"HistoryID":166676398345289971,"MongoVersion":2,"Operation":"i","NameSpace":"test.tests","Object":{"__v":0,"_id":"59e57f9e8489535b1848d32d","num":9795},"QueryObject":null},{"Timestamp":6477723955623886853,"HistoryID":3344156456

go - 如何使 func main() 中设置的数据库实例对其他包可用?

我正在编写我的第一个goweb应用程序,我有以下结构:.├──main.go├──model│├──model.go│└──book.go├──route│└──route.go└──view└──view.go/main.go是我的ma​​in()所在的位置。在该文件中,我还定义了一个变量Env,我将在其中保存我的数据库实例(至少这是计划)。在/main.go我做import"project/view"typeEnvstruct{dbmodels.Collection}//restofthecodefuncmain(){db,err:=models.NewDB()//etcMyEnv

amazon-web-services - AWS ECS SDK.使用 SDK 为 ECS 集群注册新的容器实例 (EC2)

我在使用AWSSDK时遇到过这个问题。目前我正在使用golang的SDK,但也欢迎其他语言的解决方案!我通过SDK创建了ECS集群现在我需要为这个集群添加EC2容器。我的问题是我无法使用AmazonECS代理通过配置指定集群名称:#!/bin/bashechoECS_CLUSTER=your_cluster_name>>/etc/ecs/ecs.config或类似的东西。我只能使用SDK。我找到了名为RegisterContainerInstance的方法.但是它有注释:ThisactionisonlyusedbytheAmazonECSagent,anditisnotintended

http - 如何在 http.ListenAndServe 中使用下一个可用端口

我写了一个简单的网络服务器来监听端口8080。但我不想使用硬编码的端口号。我想要的是我的服务器监听任何可用端口。我想知道我的Web服务器正在监听的端口号。我的代码如下:packagemainimport("net/http")funcmain(){http.HandleFunc("/",handler)http.ListenAndServe(":8080",nil)} 最佳答案 您可以使用端口0来表示您没有指定确切的端口,但您希望系统选择一个空闲的可用端口:http.ListenAndServe(":0",nil)问题在于您将无法找

搭建hadoop集群初次格式化namenode时不小心格式化了多次,主节点namenode或者从节点datanode进程不能启动,怎么办?

我们在搭建完hadoop集群时,初次启动HDFS集群,需要对主节点进行格式化操作,其本质是清理和做一些准备工作,因为此时的HDFS在物理上还是存在的。而且主节点格式化操作只能进行一次。那我们在格式化时,不小心格式化多次,就会导致主从节点之间互相不识别。然后导致启动hadoop集群时,主节点的namenode进程可能不会启动或者从节点的datanode可能不会启动。这里给出一种解决方法:我们在配置hadoop的配置文件core-site.xml时,其中有一组参数hadoop.tmp.dir,它的值指定的是配置hadoop的临时目录我们把tmp目录删除,再重新格式化即可。先进入/export/se