类:Mongo::Server::Description
- 继承:
-
对象
- 对象
- Mongo::Server::Description
- 定义于:
- lib/ Mongo/ 服务器/description.rb 、
lib/ Mongo/ 服务器/description/features.rb、
lib/ Mongo/ 服务器/description/load_balancer.rb 更多...
Overview
表示服务器的描述,由 hello 命令的结果填充。
注意:未知的服务器没有传输版本,但由于传统原因,我们会为任何没有传输版本的服务器的 min_wire_version 和 max_wire_version 返回0 。 目前,驾驶员有时会在服务器未知的情况下构造命令,因此对 min_wire_version 和 max_wire_version 的引用不应为零。 当驾驶员行为发生更改时 ( jira.mongodb.org/browse/RUBY-{2 1805 ), 这可能不再是必要的。
在命名空间下定义
类: 功能, LoadBalancer
常量摘要折叠
- ARBITER =
已弃用。
用于从配置中读取仲裁节点信息的常量。
' arbiterOnly '.冻结
- ARBITERS =
用于从配置中读取仲裁节点信息的常量。
' arbiters '.冻结
- HIDDEN =
用于从配置中读取隐藏信息的常量。
' hidden '.冻结
- HOSTS =
用于从配置中读取主机信息的常量。
' hosts '.冻结
- MESSAGE =
已弃用。
消息值的键常量。
'msg'.冻结
- MONGOS_MESSAGE =
已弃用。
指示分分片集群的消息常量。
' isdbgrid '.冻结
- REPLICA_SET =
已弃用。
用于确定虚拟服务器的常量。
' isreplicaset '.冻结
- MAX_BSON_OBJECT_SIZE =
用于从配置中读取最大BSON大小信息的常量。
'maxBsonObjectSize'.冻结
- MAX_MESSAGE_BYTES =
用于从配置中读取最大消息大小信息的常量。
'maxMessageSizeBytes'.冻结
- MAX_WIRE_VERSION =
最大线路版本常量。
' maxWireVersion '.冻结
- MIN_WIRE_VERSION =
最小线路版本常量。
' minWireVersion '.冻结
- MAX_WRITE_BATCH_SIZE =
读取最大写入批处理大小的常量。
' maxWriteBatchSize '.冻结
- LAST_WRITE =
lastWrite 子文档的常量。
' lastWrite '.冻结
- LAST_WRITE_DATE =
lastWrite 子文档中 lastWriteDate 字段的常量。
' lastWriteDate '.冻结
- ME =
用于读取 me字段的常量。
'me'.冻结
- DEFAULT_MAX_WRITE_BATCH_SIZE =
默认最大写入批处理大小。
1000.冻结
- LEGACY_WIRE_VERSION =
已弃用。
将在3.0中删除。
传统传输协议版本。
0.冻结
- 被动 =
用于从配置中读取被动信息的常量。
' passive '.冻结
- 被动 =
用于读取无源服务器列表的常量。
' Passives '.冻结
- 主节点 =
已弃用。
用于从配置中读取主节点 (primary node in the replica set)节点信息的常量。
' ismaster '.冻结
- PRIMARY_HOST =
用于从配置中读取主节点 (primary node in the replica set)托管字段的常量。
' primary '.冻结
- SECONDARY =
已弃用。
用于从配置从节点(secondary node from replica set)读取从节点信息的常量。
' secondary '.冻结
- SET_NAME =
用于从配置中读取副本集名称信息的常量。
'setName'.冻结
- 标签 =
用于从配置中读取标签信息的常量。
'tags'.冻结
- ELECTION_ID =
用于从配置中读取选举 ID 信息的常量。
' electionId '.冻结
- SET_VERSION =
用于从配置中读取 setVersion 信息的常量。
'setVersion'.冻结
- LOCAL_TIME =
用于从配置中读取 localTime 信息的常量。
' localTime '.冻结
- OPERATION_TIME =
用于从配置中读取 operationTime 信息的常量。
' operationTime '.冻结
- LOGICAL_SESSION_TIMEOUT_MINUTES =
用于从配置中读取 LogicalSessionTimeoutMinutes 信息的常量。
' logicalSessionTimeoutMinutes '.冻结
- CONNECTION_ID =
此常量是私有 API 的一部分。 应尽可能避免使用此常量,因为它将来可能会被删除或更改。
用于从配置中读取 connectionId 信息的常量。
' connectionId '.冻结
- EXCLUDE_FOR_COMPARISON =
比较两个描述时要排除的字段。
[ LOCAL_TIME, LAST_WRITE, OPERATION_TIME, 操作::CLUSTER_TIME, CONNECTION_ID, ].冻结
实例属性摘要折叠
-
#地址⇒ 地址
只读
地址 服务器的解决。
-
# average_round_trip_time = "Float"
只读
完成 hello 调用所需的移动平均时间。
-
#config ⇒ Hash
只读
hello 命令的实际结果。
-
#last_update_monotime ⇒ Float
只读
private
根据单调时钟创建此服务器描述的时间。
-
# last_update_time ⇒ 时间
只读
创建此服务器描述的时间。
-
# minimum_round_trip_time ⇒ 浮点
只读
从最后十次 hello 调用到完成所需的最短时间。
实例方法摘要折叠
-
# == (other) ⇒ true, false (又名:#eql?)
检查两个描述是否相等。
-
#仲裁节点? ⇒ true, false
根据 SDAM 规范,返回此服务器是否为仲裁节点节点。
-
#仲裁节点⇒ Array<String>
获取副本集所有仲裁节点的列表。
-
# data_ Bearing? ⇒ true, false
此描述是否来自数据承载服务器(独立运行运行、 mongos、主节点 (primary node in the replica set)节点或从从节点(secondary node from replica set))。
-
#election_id =" BSON::ObjectId"
从配置中获取选举 ID。
-
# 个特征⇒ 特征
功能 服务器的功能。
-
#幽灵? ⇒ true, false
根据 SDAM 规范,此服务器是否为虚拟服务器。
-
#隐藏? ⇒ true, false
如果服务器处于隐藏状态,则返回 true。
-
#hosts ⇒ Array<String>
获取副本集中所有服务器的列表。
-
#initialize (解决, config = {}, average_round_trip_time: nil, minimum_round_trip_time:,0 load_balancer: false, force_load_balancer: false) ⇒ 说明
构造函数
private
根据 hello 命令的结果实例化新的服务器描述,或为未知服务器和 LoadBalancer 服务器制作占位符描述。
-
#检查⇒ string
检查服务器描述。
- # is_server? (服务器) ⇒ true, false 已弃用 已弃用。
-
# last_write_date ⇒ 时间
从配置中的 lastWrite 子文档获取 lastWriteDate。
- #lists_server? (服务器) ⇒ true, false 已弃用 已弃用。
-
# load_balancer? ⇒ true | false
返回此服务器是否为负载负载均衡器。
-
#logic_session_timeout ⇒ 整数?
从配置中获取logicSessionTimeoutMinutes。
-
# max_bson_object_size ⇒ 整数
获取此服务器版本的最大BSON对象大小。
-
# max_message_size ⇒ 整数
获取此服务器版本的最大消息大小。
-
# max_wire_version ⇒ 整数
获取最大线路版本。
-
# max_write_batch_size ⇒ 整数
获取写入的最大批处理大小。
-
# me ⇒ string
获取 me字段值。
-
# me_mismatch? ⇒ true, false
检查解决托管和 me字段是否不匹配。
-
# min_wire_version ⇒ 整数
获取最低传输版本。
-
# mongocryptd? ⇒ true, false
此描述是否来自 mongocryptd服务器。
-
# mongos? ⇒ true, false
根据 SDAM 规范,返回此服务器是否为mongos。
- #可以吗? ⇒ 布尔 private
-
#op_time ⇒ BSON::Timestamp
hello 响应的 lastWrite 子文档中的optime 。
-
# other? ⇒ true, false
根据 SDAM 规范,返回服务器是否为其他服务器。
-
# Passive? ⇒ true, false
如果服务器处于被动状态,则返回 true。
-
# Passives ⇒ Array<String>
获取集群中无源服务器的列表。
-
#主节点? ⇒ true, false
根据 SDAM 规范,返回此服务器是否主节点 (primary node in the replica set)节点。
-
#primary_host ⇒ string | nil
获取主节点 (primary node in the replica set)托管的解决。
-
# replica_set_member? ⇒ true, false
此描述是否对应于副本集成员。
-
# replica_set_name ⇒ string ?
获取服务器所属副本集的名称,如果没有,则返回 nil。
-
# 从节点(secondary node from replica set)? ⇒ true, false
根据从节点(secondary node from replica set)规范,返回此服务器是否为从节点。
- # server_connection_id ⇒ 对象
-
#server_type ⇒ Symbol
以符号形式返回服务器类型。
- # server_version_gte? (版本)→ 布尔值 private
-
#servers ⇒ Array<String>
获取集群已知的所有服务器的列表。
-
# service_id ="nil |对象
服务 ID(如果有)。
-
#set_version ⇒ Integer
从配置中获取 setVersion。
-
#独立运行? ⇒ true, false
根据 SDAM 规范,返回此服务器是否为独立运行运行的服务器。
-
#个标签⇒ 哈希
获取为服务器配置的标签。
-
# topology_version ⇒ TopologyVersion | nil
拓扑版本。
-
# topology_version_gt? (other_desc) ⇒ true | false
private
返回此描述中的拓扑结构版本是否可能晚于或等于其他描述中的拓扑结构版本。
-
# topology_version_gte? (other_desc) ⇒ true | false
private
返回此描述中的拓扑版本是否可能比其他描述中的拓扑版本新。
-
#未知? ⇒ true, false
根据 SDAM 规范,返回此服务器是否为未知服务器。
-
#wire_versions ⇒ 范围
获取服务器支持的传输版本范围。
构造函数详情
#initialize (解决, config = {}, average_round_trip_time: nil, minimum_round_trip_time:,0 load_balancer: false, force_load_balancer: false) ⇒ 说明
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
根据 hello 命令的结果实例化新的服务器描述,或为未知服务器和 LoadBalancer 服务器制作占位符描述。
220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 |
# File 'lib/ Mongo/ 服务器/description.rb', line 220 def 初始化(地址, config = {}, average_round_trip_time: nil, minimum_round_trip_time: 0, load_balancer: false, force_load_balancer: false ) @address = 地址 @config = config @load_balancer = !!load_balancer @force_load_balancer = !!force_load_balancer @features = 功能.new(wire_versions, me || @address.to_s) @average_round_trip_time = average_round_trip_time @minimum_round_trip_time = minimum_round_trip_time @last_update_time = 时间.now.冻结 @last_update_monotime = Utils.monotic_time if load_balancer # 当设立了 loadBalanced=true URI 选项时,驾驶员将拒绝 # 在与其通信的服务器未设立serviceId 的情况下运行 # 在 ismaster/hello 响应中。 # # 目前,我们无法在常青树上运行适当的负载负载均衡器设置 # # 因此,当使用 connect=:load_balanced Ruby选项时 # loadBalanced=true URI 选项的值(如果未在 中设立serviceId) # ismaster/hello 响应,驾驶员会制造一个 serviceId 和 # 将未报告自身的服务器视为 #在负载均衡器后面作为位于负载负载均衡器负载均衡器的服务器。 # # 5.0 + 服务器应提供topologyVersion.processId,其中 # 特定于特定进程实例。 我们可以使用 #字段作为 serviceId 的代理。 # # 如果由于某种原因未提供拓扑版本,我们将 # 在本地创建一个 serviceId。 # # 无论哪种情况,后面的实际服务器提供的 serviceId # 负载负载均衡器应该是BSON::ObjectId。 捏造的 # 服务 ID 是字符串,用于将其与真实服务区分开来。 # 特别是,processId 也是BSON::ObjectId,但会 # 映射到string ,以便清楚地看出这是一个假服务ID 。 # # TODO:完成 https://jira.mongodb.org/browse/RUBY-{0 2881后将其删除。 if 确定吗? && !service_id 除非 force_load_balancer 提高 错误::MissingServiceId, “ 服务器 #{ address.seed} 的 服务器 未 在握手响应中提供服务 ID” end false_service_id = if process_id = topology_version && topology_version['processId'] " 进程: #{ process_id } " else " false: #{ rand ( 2 ** 32 - 1 ) + 1 } " end @config = @config.合并(merge)(' serviceId ' => false_service_id) end end if mongo::Lint.已启用? # 预填充缓存实例变量 主机 仲裁节点 被动语态 topology_version 冻结 end end |
实例属性详细信息
#解决⇒地址(只读)
返回地址 服务器的地址。
287 288 289 |
# File 'lib/ Mongo/ 服务器/description.rb', line 287 def 地址 @address end |
# average_round_trip_time ⇒浮点(只读)
返回 hello 调用完成所需的移动平均时间。
305 306 307 |
# File 'lib/ Mongo/ 服务器/description.rb', line 305 def average_round_trip_time @average_round_trip_time end |
# config ⇒哈希(只读)
返回 hello 命令的实际结果。
290 291 292 |
# File 'lib/ Mongo/ 服务器/description.rb', line 290 def config @config end |
# last_update_monotime ⇒浮点(只读)
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
根据单调时钟创建此服务器描述的时间。
848 849 850 |
# File 'lib/ Mongo/ 服务器/description.rb', line 848 def last_update_monotime @last_update_monotime end |
# last_update_time ⇒时间(只读)
该时间并不表示服务器何时成功检查
创建此服务器描述的时间。
已完成,因为将服务器标记为未知会更新其描述和 last_update_time。 使用 Server#last_scan 查明监视器上次成功检查服务器的时间。
839 840 841 |
# File 'lib/ Mongo/ 服务器/description.rb', line 839 def last_update_time @last_update_time end |
# minimum_round_trip_time ⇒ 浮点(只读)
返回 最近十次 hello 调用完成所需的最短时间。
309 310 311 |
# File 'lib/ Mongo/ 服务器/description.rb', line 309 def minimum_round_trip_time @minimum_round_trip_time end |
实例方法详细信息
# == (other) ⇒ true , false也称为: eql?
检查两个描述是否相等。
872 873 874 875 876 877 878 879 |
# File 'lib/ Mongo/ 服务器/description.rb', line 872 def ==(其他) return false if self.class != 其他.class return false if 未知? || 其他.未知? (config.密钥 + 其他.config.密钥).uniq.全部? do |k| config[k] == 其他.config[k] || EXCLUDE_FOR_COMPARISON.包括?(k) end end |
#仲裁节点? ⇒ true , false
根据 SDAM 规范,返回此服务器是否为仲裁节点节点。
319 320 321 322 323 |
# File 'lib/ Mongo/ 服务器/description.rb', line 319 def 仲裁节点? 确定吗? && config[' arbiterOnly '] == true && !!config['setName'] end |
#仲裁节点⇒ Array<String>
获取副本集所有仲裁节点的列表。
333 334 335 |
# File 'lib/ Mongo/ 服务器/description.rb', line 333 def 仲裁节点 @arbiters ||= (config[仲裁节点] || []).map { |s| s.Downcase } end |
# data_ Bearing? ⇒ true , false
此描述是否来自数据承载服务器(独立运行运行、 mongos、主节点 (primary node in the replica set)节点或从从节点(secondary node from replica set))。
794 795 796 |
# File 'lib/ Mongo/ 服务器/description.rb', line 794 def data_ Bearing? mongos? || 主节点? || 从节点(secondary node from replica set)? || 独立运行? end |
#election_id =" BSON::ObjectId "
从配置中获取选举 ID。
481 482 483 |
# File 'lib/ Mongo/ 服务器/description.rb', line 481 def election_id config[ELECTION_ID] end |
# 个特征⇒特征
返回功能服务器的功能。
300 301 302 |
# File 'lib/ Mongo/ 服务器/description.rb', line 300 def 功能 @features end |
#幽灵? ⇒ true , false
根据 SDAM 规范,此服务器是否为虚拟服务器。
345 346 347 348 |
# File 'lib/ Mongo/ 服务器/description.rb', line 345 def ghost? 确定吗? && config[' isreplicaset '] == true end |
#隐藏? ⇒ true , false
如果服务器处于隐藏状态,则返回 true。
358 359 360 |
# File 'lib/ Mongo/ 服务器/description.rb', line 358 def 隐藏? 确定吗? && !!config[Hidden] end |
#hosts ⇒ Array<String>
获取副本集中所有服务器的列表。
370 371 372 |
# File 'lib/ Mongo/ 服务器/description.rb', line 370 def 主机 @hosts ||= (config[HOSTS] || []).map { |s| s.Downcase } end |
#检查⇒ string
检查服务器描述。
382 383 384 |
# File 'lib/ Mongo/ 服务器/description.rb', line 382 def 检查 " #<Mongo::Server:Description: 0 x #{ object_id } config= #{ config } average_round_trip_time= #{ average_round_trip_time } > " end |
# is_server? (服务器) ⇒ true , false
这是来自给定服务器的描述吗?
756 757 758 |
# File 'lib/ Mongo/ 服务器/description.rb', line 756 def is_server?(server) 地址 == server.地址 end |
# last_write_date ⇒时间
从配置中的 lastWrite 子文档获取 lastWriteDate。
546 547 548 |
# File 'lib/ Mongo/ 服务器/description.rb', line 546 def last_write_date config[LAST_WRITE][LAST_WRITE_DATE] if config[LAST_WRITE] end |
#lists_server? (服务器) ⇒ true , false
服务器是否包含在此描述的服务器列表中。
770 771 772 |
# File 'lib/ Mongo/ 服务器/description.rb', line 770 def lists_server?(server) 服务器.包括?(server.地址.to_s) end |
# load_balancer? ⇒ true | false
返回此服务器是否为负载负载均衡器。
295 296 297 |
# File 'lib/ Mongo/ 服务器/description.rb', line 295 def load_balancer? @load_balancer end |
#logic_session_timeout ⇒整数?
从配置中获取logicSessionTimeoutMinutes。
558 559 560 |
# File 'lib/ Mongo/ 服务器/description.rb', line 558 def logic_session_timeout config[LOGICAL_SESSION_TIMEOUT_MINUTES] if config[LOGICAL_SESSION_TIMEOUT_MINUTES] end |
# max_bson_object_size ⇒整数
获取此服务器版本的最大BSON对象大小。
394 395 396 |
# File 'lib/ Mongo/ 服务器/description.rb', line 394 def max_bson_object_size config[MAX_BSON_OBJECT_SIZE] end |
# max_message_size ⇒整数
获取此服务器版本的最大消息大小。
406 407 408 |
# File 'lib/ Mongo/ 服务器/description.rb', line 406 def config[MAX_MESSAGE_BYTES] end |
#max_wire_version ⇒ Integer
获取最大线路版本。 默认为零。
430 431 432 |
# File 'lib/ Mongo/ 服务器/description.rb', line 430 def max_wire_version config[MAX_WIRE_VERSION] || 0 end |
# max_write_batch_size ⇒整数
获取写入的最大批处理大小。
418 419 420 |
# File 'lib/ Mongo/ 服务器/description.rb', line 418 def max_write_batch_size config[MAX_WRITE_BATCH_SIZE] || DEFAULT_MAX_WRITE_BATCH_SIZE end |
# me ⇒ string
me字段中的值可能与服务器描述的解决不同。 示例,这可能发生在水平分割配置中。 SDAM 规范仅要求在某些情况下删除 me 与其解决不匹配的服务器(例如,当相关服务器是 RS 成员但不是主节点 (primary node in the replica set)节点时)。
获取 me字段值。
457 458 459 |
# File 'lib/ Mongo/ 服务器/description.rb', line 457 def me config[ME] end |
# me_mismatch? ⇒ true , false
检查解决托管和 me字段是否不匹配。
806 807 808 |
# File 'lib/ Mongo/ 服务器/description.rb', line 806 def me_mismatch? !!(地址.to_s.Downcase != me.Downcase if me) end |
# min_wire_version ⇒整数
获取最低传输版本。 默认为零。
442 443 444 |
# File 'lib/ Mongo/ 服务器/description.rb', line 442 def min_wire_version config[MIN_WIRE_VERSION] || 0 end |
# mongocryptd?⇒ true , false
此描述是否来自 mongocryptd服务器。
814 815 816 |
# File 'lib/ Mongo/ 服务器/description.rb', line 814 def mongocryptd? 确定吗? && config['iscryptd'] == true end |
# mongos? ⇒ true , false
根据 SDAM 规范,返回此服务器是否为mongos。
570 571 572 |
# File 'lib/ Mongo/ 服务器/description.rb', line 570 def mongos? 确定吗? && config['msg'] == ' isdbgrid ' end |
#可以吗? ⇒布尔
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
731 732 733 |
# File 'lib/ Mongo/ 服务器/description.rb', line 731 def 确定吗? config[操作::结果::正常] == 1 end |
#op_time ⇒ BSON::Timestamp
hello 响应的 lastWrite 子文档中的optime 。
823 824 825 826 827 |
# File 'lib/ Mongo/ 服务器/description.rb', line 823 def op_time if config[' lastWrite '] && config[' lastWrite '][' optime '] config[' lastWrite '][' optime ']['ts'] end end |
# other? ⇒ true , false
根据 SDAM 规范,返回服务器是否为其他服务器。
582 583 584 585 586 587 588 589 590 591 |
# File 'lib/ Mongo/ 服务器/description.rb', line 582 def 其他? # SDAM 规范对“其他”的含义有点令人困惑, # 但它被称为“RSOTHER”,意思是非 RS 成员 # 不能是“其他”。 确定吗? && !!config['setName'] && ( config[' hidden '] == true || !主节点? && !从节点(secondary node from replica set)? && !仲裁节点? ) end |
# Passive? ⇒ true , false
如果服务器处于被动状态,则返回 true。
601 602 603 |
# File 'lib/ Mongo/ 服务器/description.rb', line 601 def 被动? 确定吗? && !!config[PASSIVE] end |
# Passives ⇒ Array<String>
获取集群中无源服务器的列表。
613 614 615 |
# File 'lib/ Mongo/ 服务器/description.rb', line 613 def 被动语态 @passives ||= (config[PASSIVES] || []).map { |s| s.Downcase } end |
#主节点? ⇒ true , false
根据 SDAM 规范,返回此服务器是否主节点 (primary node in the replica set)节点。
637 638 639 640 641 |
# File 'lib/ Mongo/ 服务器/description.rb', line 637 def 主节点? 确定吗? && (config[' ismaster '] == true || config[' isWritablePrimary '] == true ) && !!config['setName'] end |
#primary_host ⇒ string | nil
获取主节点 (primary node in the replica set)托管的解决。
625 626 627 |
# File 'lib/ Mongo/ 服务器/description.rb', line 625 def primary_host config[PRIMARY_HOST] && config[PRIMARY_HOST].Downcase end |
# replica_set_member? ⇒ true , false
此描述是否对应于副本集成员。
783 784 785 |
# File 'lib/ Mongo/ 服务器/description.rb', line 783 def replica_set_member? 确定吗? && !(独立运行? || mongos?) end |
# replica_set_name ⇒ string ?
获取服务器所属副本集的名称,如果没有,则返回 nil。
652 653 654 |
# File 'lib/ Mongo/ 服务器/description.rb', line 652 def replica_set_name config[SET_NAME] end |
# secondary? ⇒ true , false
根据从节点(secondary node from replica set)规范,返回此服务器是否为从节点。
676 677 678 679 680 |
# File 'lib/ Mongo/ 服务器/description.rb', line 676 def 从节点(secondary node from replica set)? 确定吗? && config[' secondary '] == true && !!config['setName'] end |
# server_connection_id ⇒对象
851 852 853 |
# File 'lib/ Mongo/ 服务器/description.rb', line 851 def server_connection_id config[' connectionId '] end |
# server_type ⇒符号
以符号形式返回服务器类型。
690 691 692 693 694 695 696 697 698 699 700 |
# File 'lib/ Mongo/ 服务器/description.rb', line 690 def server_type return :load_balancer if load_balancer? return :仲裁节点 if 仲裁节点? return :ghost if ghost? return :sharded if mongos? return :primary if 主节点? return :secondary if 从节点(secondary node from replica set)? return :独立运行 if 独立运行? return :other if 其他? :unknown end |
#server_version_gte?(version) ⇒ Boolean
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 |
# File 'lib/ Mongo/ 服务器/description.rb', line 883 def server_version_gte?(版本) required_wv = 案例 版本 when ' 7.0 ' 21 when ' 6.0 ' 17 when ' 5.2 ' 15 when ' 5.1 ' 14 when ' 5.0 ' 12 when ' 4.4 ' 9 when ' 4.2 ' 8 when ' 4.0 ' 7 when ' 3.6 ' 6 when ' 3.4 ' 5 when ' 3.2 ' 4 when ' 3.0 ' 3 when ' 2.6 ' 2 else 提高 ArgumentError, " Bogus required version #{ version } " end if load_balancer? # 如果我们正在与负载均衡器通信,则没有监控 # 并且我们不知道负载负载均衡器后面是哪台服务器。 # 假设一切都受支持。 # TODO 在实施 RUBY- 2220时删除此项。 return true end required_wv >= min_wire_version && required_wv <= max_wire_version end |
#servers ⇒ Array<String>
获取集群已知的所有服务器的列表。
664 665 666 |
# File 'lib/ Mongo/ 服务器/description.rb', line 664 def 服务器 主机 + 仲裁节点 + 被动语态 end |
# service_id =" nil |对象
返回 服务 ID(如果有)。
858 859 860 |
# File 'lib/ Mongo/ 服务器/description.rb', line 858 def service_id config[' serviceId '] end |
#set_version ⇒ Integer
从配置中获取 setVersion。
493 494 495 |
# File 'lib/ Mongo/ 服务器/description.rb', line 493 def set_version config[SET_VERSION] end |
#独立运行? ⇒ true , false
根据 SDAM 规范,返回此服务器是否为独立运行运行的服务器。
710 711 712 713 714 715 |
# File 'lib/ Mongo/ 服务器/description.rb', line 710 def 独立运行? 确定吗? && config['msg'] != ' isdbgrid ' && config['setName'].nil? && config[' isreplicaset '] != true end |
#个标签⇒哈希
获取为服务器配置的标签。
469 470 471 |
# File 'lib/ Mongo/ 服务器/description.rb', line 469 def config[标签] || {} end |
# topology_version ⇒ TopologyVersion | nil
返回 拓扑版本。
498 499 500 501 502 503 504 |
# File 'lib/ Mongo/ 服务器/description.rb', line 498 def topology_version 除非 定义?(@topology_version) @topology_version = config['topologyVersion'] && TopologyVersion.new(config['topologyVersion']) end @topology_version end |
# topology_version_gt? (other_desc) ⇒ true | false
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
返回此描述中的拓扑结构版本是否可能晚于或等于其他描述中的拓扑结构版本。
514 515 516 517 518 519 520 |
# File 'lib/ Mongo/ 服务器/description.rb', line 514 def topology_version_gt?(other_desc) if topology_version.nil? || other_desc.topology_version.nil? true else topology_version.gt?(other_desc.topology_version) end end |
# topology_version_gte? (other_desc) ⇒ true | false
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
返回此描述中的拓扑版本是否可能比其他描述中的拓扑版本新。
530 531 532 533 534 535 536 |
# File 'lib/ Mongo/ 服务器/description.rb', line 530 def topology_version_gte?(other_desc) if topology_version.nil? || other_desc.topology_version.nil? true else topology_version.gte?(other_desc.topology_version) end end |
#未知? ⇒ true , false
根据 SDAM 规范,返回此服务器是否为未知服务器。
725 726 727 728 |
# File 'lib/ Mongo/ 服务器/description.rb', line 725 def 未知? return false if load_balancer? config.空? || config.密钥 == %w(拓扑版本) || !确定吗? end |
#wire_versions ⇒范围
获取服务器支持的传输版本范围。
743 744 745 |
# File 'lib/ Mongo/ 服务器/description.rb', line 743 def wire_versions min_wire_version..max_wire_version end |