gpt4 book ai didi

go - 不断重新连接到 Cassandra

转载 作者:IT王子 更新时间:2023-10-29 01:43:42 24 4
gpt4 key购买 nike

我在网上了解到,使用 Cassandra 时的最佳做法是在您的服务生命周期内拥有 1 个 Cluster 和 1 个 Session

我的问题是:

  1. 如果我们的 Cassandra 服务器出现故障,我如何确保我的集群和/或 session 将继续尝试重新连接,直到我们的 Cassandra 服务器重新联机?

  2. 应该只有集群尝试重新连接,还是只有 session ,或者两者都尝试重新连接?

我们正在使用 Gogithub.com/gocql/gocql为我们的服务。

我在 gocql 文档中看到了以下代码片段,但看起来它只有有限的重试次数:

cluster.ReconnectionPolicy = &gocql.ConstantReconnectionPolicy{MaxRetries: 10, Interval: 8 * time.Second}

我还在网上找到了下面的代码片段,但它看起来不像是为处理这种情况而设计的:

var cluster *gocql.ClusterConfig
var session *gocql.Session

func getCassandraSession() *gocql.Session {
if session == nil || session.Closed() {
if cluster == nil {
cluster = gocql.NewCluster("127.0.0.1:9042")
cluster.Keyspace = "demodb"
cluster.Consistency = gocql.One
cluster.ProtoVersion = 4
}
var err error
if session, err = cluster.CreateSession(); err != nil {
panic(err)
}
}
return session
}

上述任何方法是否足以确保在我们的 Cassandra 服务器重新联机之前尝试重新连接?如果不是,这种情况下的最佳做法是什么?

最佳答案

特别感谢@Jim Wartnick为了这。我只是尝试在我的本地机器上关闭 Cassandra,然后重新打开它,gocql 立即重新连接,而无需在我的问题中使用上述任何片段。

只要您的 ClusterSession 至少连接到 Cassandra 一次,即使 Cassandra 出现故障,它们也会在 Cassandra 恢复后立即重新连接到它在线。

非常感谢所有提供帮助的人!

关于go - 不断重新连接到 Cassandra,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56002002/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com