0

我在 Docker 容器中运行 Cassandra 集群,使用舰队进行管理。我能够让集群启动并运行,但是如果我用舰队关闭单元然后再次备份,容器就会失败。Cassandra 日志在第二次启动时有此条目。

Cannot add table 'role_members' to non existing keyspace 'system_auth'.
Fatal configuration error; unable to start server.  See log for stacktrace.
INFO  20:59:34 InetAddress /172.17.8.102 is now DOWN
ERROR 20:59:34 Fatal configuration error
org.apache.cassandra.exceptions.ConfigurationException: Cannot add table 'role_members' to non existing keyspace 'system_auth'.
        at org.apache.cassandra.service.MigrationManager.announceNewColumnFamily(MigrationManager.java:284) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.MigrationManager.announceNewColumnFamily(MigrationManager.java:275) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.StorageService.maybeAddTable(StorageService.java:1046) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.StorageService.doAuthSetup(StorageService.java:1034) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.StorageService.joinTokenRing(StorageService.java:967) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.StorageService.initServer(StorageService.java:698) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.StorageService.initServer(StorageService.java:581) ~[apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.CassandraDaemon.setup(CassandraDaemon.java:291) [apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.CassandraDaemon.activate(CassandraDaemon.java:481) [apache-cassandra-2.2.0.jar:2.2.0]
        at org.apache.cassandra.service.CassandraDaemon.main(CassandraDaemon.java:588) [apache-cassandra-2.2.0.jar:2.2.0]

我找不到有关此特定错误的任何信息,而且我真的不知道为什么会发生这种情况。我能找到的最接近的信息是,system_auth如果您不使用默认表,则需要专门配置该表AllowAllAuthenticator,但我正在使用它。我没有在 cassandra.yaml 文件中更改它。

有谁知道为什么会发生这种情况?

4

3 回答 3

0

结果证明这是我遇到的一个相当独特的配置问题。我/var/lib/cassandra在主机/var/lib/cassandra上映射到我的 docker 容器内。但我也无意中映射/var/lib/cassandra/data到主机上自动生成的 Docker 目录。因此,当我停止并重新启动容器时,数据目录会消失,并且 Cassandra 会失败,因为它试图从 commitlog 目录重新创建数据。

于 2015-09-14T20:00:49.360 回答
0

我只是按照 Datastax “初始化多节点集群(单数据中心)”教程遇到了问题。

我解决了同样的问题,删除了整个内容,/var/lib/cassandra而不仅仅是/var/lib/cassandra/system/

为什么?我认为 Kris 得到了真正的问题来源:重新启动时,C* 服务发现 commitLog 已满,并通过尝试重建在那里找到的提交来恢复,由于不同的配置和不同的表结构而失败......

于 2015-09-23T15:02:56.430 回答
0

有没有可能你正在使用CassandraAuthorizer而不使用PasswordAuthenticator?我认为这可能不起作用并导致此特定错误。

system_auth不适用于AllowAllAuthenticator,需要PasswordAuthenticator改用。如果按照以下方式配置 cassandra.yaml:

authenticator: PasswordAuthenticator
authorizer: CassandraAuthorizer

然后重新启动 cassandra,它应该会为您创建 system_auth 密钥空间。如果您不想设置授权,您可以随时使用AllowAllAuthorizer。更多信息可以在这里找到。

于 2015-09-10T21:33:19.037 回答