我尝试使用他们的 Golang 启动一个 Consul 代理 package . 服务器本身启动了,但我无法与其交互,因为它没有开始监听传入的 HTTP 请求。
我启动代理的代码:
//create the logwriter
writer := bytes.NewBuffer(server.log)
agentConfig := agent.DefaultConfig()
agentConfig.BindAddr = "127.0.0.1"
agentConfig.DevMode = true
agentConfig.Bootstrap = true
agentConfig.Server = true
agentConfig.DataDir = "/tmp"
agentConfig.Ports.HTTP = 8500
agentConfig.Ports.HTTPS = -1
//agentConfig.AdvertiseAddr = "127.0.0.1"
//agentConfig.EnableUi = true
agentConfig.Addresses.HTTP = "127.0.0.1"
glog.Infof("Agent config: %+v", agentConfig)
agent, err := agent.Create(agentConfig, writer)
if err != nil {
t.Fatalf("Error starting consul agent: %v", err)
}
启动时生成的配置如下所示:
Agent config: &{DevMode:true Bootstrap:true BootstrapExpect:0
Server:true Datacenter:dc1 DataDir:/tmp DNSRecursor: DNSRecursors:[] DNSConfig:{NodeTTL:0 NodeTTLRaw: ServiceTTL:map[] ServiceTTLRaw:map[]
AllowStale:false EnableTruncate:false UDPAnswerLimit:3 MaxStale:5s
MaxStaleRaw: OnlyPassing:false} Domain:consul. EncryptKey:
LogLevel:INFO NodeName: ClientAddr:127.0.0.1 BindAddr:127.0.0.1
AdvertiseAddr: AdvertiseAddrs:{SerfLan:<nil> SerfLanRaw: SerfWan:<nil>
SerfWanRaw: RPC:<nil> RPCRaw:} AdvertiseAddrWan:
TranslateWanAddrs:false Ports:{DNS:8600 HTTP:8500 HTTPS:-1 RPC:8400
SerfLan:8301 SerfWan:8302 Server:8300} Addresses:{DNS: HTTP:127.0.0.1
HTTPS: RPC:} TaggedAddresses:map[] LeaveOnTerm:false SkipLeaveOnInt:
<nil> Telemetry:{StatsiteAddr: StatsdAddr: StatsitePrefix:consul
DisableHostname:false DogStatsdAddr: DogStatsdTags:[]} Protocol:2
EnableDebug:false VerifyIncoming:false VerifyOutgoing:false VerifyServerHostname:false CAFile: CertFile: KeyFile: ServerName:
StartJoin:[] StartJoinWan:[] RetryJoin:[] RetryMaxAttempts:0
RetryInterval:30s RetryIntervalRaw: RetryJoinWan:[]
RetryMaxAttemptsWan:0 RetryIntervalWan:30s RetryIntervalWanRaw:
ReconnectTimeoutLan:0 ReconnectTimeoutLanRaw: ReconnectTimeoutWan:0
ReconnectTimeoutWanRaw: EnableUi:false UiDir: PidFile:
EnableSyslog:false SyslogFacility:LOCAL0 RejoinAfterLeave:false
CheckUpdateInterval:5m0s CheckUpdateIntervalRaw: ACLToken:
ACLMasterToken: ACLDatacenter: ACLTTL:30s ACLTTLRaw:
ACLDefaultPolicy:allow ACLDownPolicy:extend-cache Watches:[]
DisableRemoteExec:false DisableUpdateCheck:false
DisableAnonymousSignature:false HTTPAPIResponseHeaders:map[]
AtlasInfrastructure: AtlasToken: AtlasACLToken: AtlasJoin:false
AtlasEndpoint: AEInterval:1m0s DisableCoordinates:false
SyncCoordinateRateTarget:64 SyncCoordinateIntervalMin:15s Checks:[]
Services:[] ConsulConfig:<nil> Revision: Version: VersionPrerelease:
WatchPlans:[] UnixSockets:{UnixSocketPermissions:{Usr: Grp: Perms:}}
SessionTTLMin:0 SessionTTLMinRaw: Reap:<nil>}
检查我打开的端口,我可以看到代理已启动但未监听 HTTP
storage.t 16820 felix 5u IPv4 469866 0t0 TCP localhost:8300 (LISTEN)
storage.t 16820 felix 6u IPv4 469867 0t0 TCP localhost:8301 (LISTEN)
storage.t 16820 felix 7u IPv4 469868 0t0 UDP localhost:8301
storage.t 16820 felix 8u IPv4 469869 0t0 TCP localhost:8302 (LISTEN)
storage.t 16820 felix 9u IPv4 469870 0t0 UDP localhost:8302
每一个让运行的提示都值得赞赏:)
最佳答案
确保所有必需的端口也已打开:
来自领事文档: https://www.consul.io/docs/agent/options.html#ports-used
关于go - 以编程方式启动的 Consul 代理不打开 HTTP 端口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38971036/
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
question的一些答案关于redirect_to让我想到了其他一些问题。基本上,我正在使用Rails2.1编写博客应用程序。我一直在尝试自己完成大部分工作(因为我对Rails有所了解),但在需要时会引用Internet上的教程和引用资料。我设法让一个简单的博客正常运行,然后我尝试添加评论。靠我自己,我设法让它进入了可以从script/console添加评论的阶段,但我无法让表单正常工作。我遵循的其中一个教程建议在帖子Controller中创建一个“评论”操作,以添加评论。我的问题是:这是“标准”方式吗?我的另一个问题的答案之一似乎暗示应该有一个CommentsController参
几个月前,我读了一篇关于rubygem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:
我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
一、引擎主循环UE版本:4.27一、引擎主循环的位置:Launch.cpp:GuardedMain函数二、、GuardedMain函数执行逻辑:1、EnginePreInit:加载大多数模块int32ErrorLevel=EnginePreInit(CmdLine);PreInit模块加载顺序:模块加载过程:(1)注册模块中定义的UObject,同时为每个类构造一个类默认对象(CDO,记录类的默认状态,作为模板用于子类实例创建)(2)调用模块的StartUpModule方法2、FEngineLoop::Init()1、检查Engine的配置文件找出使用了哪一个GameEngine类(UGame
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里