我正在尝试设置一个 google TCP 内部负载平衡器。这个 lb 后面的实例组由监听端口 6379 的 redis-server 进程组成。在这些 redis 实例中,只有一个是 master。
问题:添加一个 TCP 健康检查来检测 redis master 并使 lb 将所有流量仅转移到 redis master。
方法:
为端口 6379 添加了 TCP 健康检查。
为了将命令 role 发送到 redis-server 进程并解析响应,我使用了运行状况检查中提供的可选参数。请查看截图here .
结果:所有健康检查均失败。如果我删除可选的请求/响应参数,健康检查将开始通过。
调试:
role,它发送以 *3(对于 master)和 *5 开头的响应(对于奴隶)如预期的那样。nc -l -p 6379 开始监听端口 6379,以检查在健康检查中实例端究竟收到了什么。它确实接收 role\r\n。MONITOR 命令,以查看此进程收到的命令日志。这里没有role的日志。
这意味着,实例正在通过 tcp 接收数据(role\r\n),但进程 redis-cli(根据 MONITOR 命令)或其他方式未接收到数据正在发生。请帮忙。最佳答案
不幸的是,GCP 的 TCP 健康检查在响应中可以检查的内容上非常有限。来自 https://cloud.google.com/sdk/gcloud/reference/compute/health-checks/create/tcp :
--response=RESPONSE
An optional string of up to 1024 characters that the health checker expects to receive from the instance. If the response is not received exactly, the health check probe fails. If --response is configured, but not --request, the health checker will wait for a response anyway. Unless your system automatically sends out a message in response to a successful handshake, only configure --response to match an explicit --request.
请注意帮助消息中的“完全正确”一词。响应必须完全匹配提供的字符串。不能指定要在响应中搜索的部分字符串。
正如您在 https://redis.io/commands/role 上看到的那样,redis的ROLE命令返回一堆文本。尽 pipe 字符串“master”出现在响应中,但它还有一堆其他文本,这些文本会因设置而异(基于从站的数量、地址等)。
您绝对应该向 GCP 提出功能请求,以便在响应中进行正则表达式匹配。一个可能的解决方法是在每台主机上安装一个小的网络应用程序,在本地执行“redis-cli role | grep master”命令并返回响应。然后可以配置运行状况检查来监控此 Web 应用。
关于networking - 从 google tcp 负载均衡器检测 redis master 的健康检查,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43228878/
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
如何检查Ruby文件是否是通过“require”或“load”导入的,而不是简单地从命令行执行的?例如:foo.rb的内容:puts"Hello"bar.rb的内容require'foo'输出:$./foo.rbHello$./bar.rbHello基本上,我想调用bar.rb以不执行puts调用。 最佳答案 将foo.rb改为:if__FILE__==$0puts"Hello"end检查__FILE__-当前ruby文件的名称-与$0-正在运行的脚本的名称。 关于ruby-检查是否
我有一个div,它根据表单是否正确提交而改变。我想知道是否可以检查类的特定元素?开始元素看起来像这样。如果输入不正确,添加错误类。 最佳答案 试试这个:browser.div(:id=>"myerrortest").class_name更多信息:http://watir.github.com/watir-webdriver/doc/Watir/HTMLElement.html#class_name-instance_method另一种选择是只查看具有您期望的类的div是否存在browser.div((:id=>"myerrortes
我的模型有defself.empty_building//stuffend我怎样才能对这个现有的进行rspec?,已经尝试过:describe"empty_building"dosubject{Building.new}it{shouldrespond_to:empty_building}endbutgetting:Failure/Error:it{shouldrespond_to:empty_building}expected#torespondto:empty_building 最佳答案 你有一个类方法self.empty_bu