1

我正在尝试使用 websudos幻象

有谁知道如何指定 Cassandra 的连接参数,例如用户名和密码?

谢谢

4

1 回答 1

6

Phantom 尚不支持phantom-connectors框架中的 Kerberos 身份验证,但它已在未来几周的路线图上。

但是,在使用连接器时,可以覆盖该createCluster方法并以您想要的任何方式连接到集群。

object CustomCassandraManger extends DefaultCasandraManager {

  override protected[this] def createCluster: Cluster = {
    val inets = hosts.toSeq.map(_.getAddress)

    Cluster.builder()
     .addContactPoints(inets: _*)
     ...
     .withUsernameAndPassword(..)
  }
}

我可能没有使用正确的方法,但这就是您控制集群创建方式的方式。然后,您只需将此管理器注入连接器:

trait MyConnector extends SimpleCassandraConnector {
  override val manager = CustomCassandraMananger
}

然后你将这个连接器混入你的所有表格中,就像你通常在使用幻像时所做的那样。

最新版本的幻影

在 phantom 的最新版本中,API 基于ContactPoints,您可以ClusterBuilder使用以下 DSL 指定所需的任何选项。

import com.datastax.driver.core.PlainTextAuthProvider

lazy val local = ContactPoint.local.withClusterBuilder(
  _.withAuthProvider(new PlainTextAuthProvider("user", "pass"))
).keySpace("phantom")
于 2015-05-09T11:42:06.837 回答