Phantom Scala Cassandra 连接器:如何指定节点的端口、用户名、密码
Phantom Scala Cassandra connector: how to specify port, username, password of nodes
我正在尝试使用 websudos phantom
有谁知道如何为 Cassandra 指定连接参数,例如用户名和密码?
谢谢
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 时一样。
幻影的最新版本
在最新版本的 phantom 中,API 基于 ContactPoints
,您可以使用以下 DSL 在其中指定您想要的任何 ClusterBuilder
选项。
import com.datastax.driver.core.PlainTextAuthProvider
lazy val local = ContactPoint.local.withClusterBuilder(
_.withAuthProvider(new PlainTextAuthProvider("user", "pass"))
).keySpace("phantom")
我正在尝试使用 websudos phantom
有谁知道如何为 Cassandra 指定连接参数,例如用户名和密码?
谢谢
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 时一样。
幻影的最新版本
在最新版本的 phantom 中,API 基于 ContactPoints
,您可以使用以下 DSL 在其中指定您想要的任何 ClusterBuilder
选项。
import com.datastax.driver.core.PlainTextAuthProvider
lazy val local = ContactPoint.local.withClusterBuilder(
_.withAuthProvider(new PlainTextAuthProvider("user", "pass"))
).keySpace("phantom")