1

我正在运行 MongoDB 2.2。我可以像这样添加凭据来访问我的单实例 MongoDB:

<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
  <property name="writeResultChecking" value="EXCEPTION"/>
  <property name="writeConcern" value="FSYNC_SAFE"/>
  <constructor-arg ref="myRs"/>
  <constructor-arg name="databaseName" value="mydb"/>
  <constructor-arg name="userCredentials" ref="userCredentials"/>
</bean>

<bean id="userCredentials" class="org.springframework.data.authentication.UserCredentials">
  <constructor-arg name="username" value="username" />
  <constructor-arg name="password" value="password" />
</bean>

但文档说只有密钥文件身份验证可用于副本集: http ://docs.mongodb.org/v2.2/administration/replica-sets/#replica-set-security

如何在应用程序上下文 XML 文件中优先使用 DB 凭据(甚至是密钥文件),以便在使用 Spring Data MongoDB 时对 MongoDB 副本集进行身份验证?

谢谢。

4

1 回答 1

0

--keyfile 选项启用副本集成员之间基于密钥的身份验证。它对您的应用程序和副本集之间的通信没有影响。

您需要将用户添加到数据库。确保您已连接到 Primary。

$ mongo
PRIMARY> use the_database_i_want_to_be_authenticated
switched to db the_database_i_want_to_be_authenticated
PRIMARY> db.addUser("myusername","mypassword")
{
    "user" : "myusername",
    "readOnly" : false,
    "pwd" : "a6de521abefc2fed4f5876855a3484f5",
    "_id" : ObjectId("5194932444ef978a730c22d4")
}

在数据库中创建用户后,您将能够使用以下连接它

<bean id="userCredentials" class="org.springframework.data.authentication.UserCredentials">
    <constructor-arg name="username" value="username" />
    <constructor-arg name="password" value="password" />
</bean>
于 2013-05-16T08:18:58.730 回答