- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
假设一个 Cassandra 集群需要由客户端应用程序访问。在 Java api 中,我们创建一个集群实例并通过 Session 发送读取或写入请求。如果我们使用读/写一致性 ONE,api 如何选择实际节点(协调器节点)以转发请求。是随机选择吗?请帮忙解决这个问题。
最佳答案
Cassandra 驱动程序使用“八卦”协议(protocol)(以及称为节点发现的过程)来获取有关集群的信息。如果一个节点变得不可用,客户端驱动程序会自动尝试其他节点并安排与死节点的重新连接时间。根据to the DataStax docs :
Gossip is a peer-to-peer communication protocol in which nodes periodically exchange state information about themselves and about other nodes they know about. The gossip process runs every second and exchanges state messages with up to three other nodes in the cluster. The nodes exchange information about themselves and about the other nodes that they have gossiped about, so all nodes quickly learn about all other nodes in the cluster.
本质上,您提供给客户端连接的节点列表是获取整个集群信息的初始联系点。这就是为什么您的客户端可以与集群中的所有节点通信(如果需要),即使您可能只在连接字符串中提供一小部分节点。
一旦你的驱动程序有了关于集群的八卦信息,它就可以做出关于在哪个节点上运行查询的智能决策。节点选择不是投票或随机选择的过程。根据返回的八卦信息,客户端驱动程序应用其 Load Balancing Policy .虽然它确实考虑了几个因素,但基本上它会尝试选择与客户端的网络“距离”最短的节点。
编辑20200322
让我稍微扩展一下负载平衡策略。我鼓励高性能应用程序的开发人员使用 TokenAwarePolicy。此策略将分区键值散列为“ token ”,并使用此散列来确定哪个节点负责生成的 token 范围。这具有跳过选择“协调器”节点的中间步骤的效果,并将查询直接发送到包含所请求数据的节点。
但是,如果您使用的是非 token 感知型负载平衡策略,或者运行的查询未对分区键进行过滤,则上述原始过程适用。
关于java - Cassandra如何选择发送请求的节点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27077701/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!