将副本集更新为密钥文件身份验证

概述

replica set实施访问控制需要配置:

对于本教程,副本集的每个成员都使用相同的内部身份验证机制和设置。

强制执行内部身份验证还会强制执行用户访问控制。 要连接到副本集,客户喜欢mongosh 需要使用user account。 请参阅Users and Authentication Mechanisms

云管理器和操作管理器

如果您当前正在使用或计划使用 Cloud Manager 或 Ops Manager,请参阅 Cloud Manager manual Ops Manager manual以实施访问控制。

注意事项

[IMPORTANT]重要 为避免因 IP 地址更改而导致配置更新,请使用 DNS 主机名而不是 IP 地址。 在配置副本集成员或分片集群成员时,使用 DNS 主机名而不是 IP 地址尤为重要。

使用主机名而不是 IP 地址来配置跨分割网络水平的集群。 从 MongoDB 5.0 开始,仅配置了 IP 地址的节点将无法通过启动验证而不会启动。

IP绑定

在 3.6 版中更改。

从 MongoDB 3.6 开始,mongodmongos 默认绑定到 localhost。 如果部署的成员在不同的主机上运行,或者如果您希望远程客户端连接到您的部署,则必须指定 --bind_ipnet.bindIp。 有关详细信息,请参阅Localhost Binding Compatibility Changes

操作系统

本教程主要涉及 mongod 进程。 Windows 用户应该改用 exe 程序。

密钥文件安全

密钥文件是最低限度的安全形式,最适合测试或开发环境。 对于生产环境,我们建议使用x.509 certificates

用户

本教程仅涵盖在 admin 数据库上创建最少数量的管理用户。 对于用户认证,本教程使用默认的 SCRAM 认证机制。 质询-响应安全机制最适合测试或开发环境。 对于生产环境,我们建议使用 x.509 certificatesLDAP Proxy Authentication (仅适用于 MongoDB Enterprise)或 Kerberos Authentication(仅适用于 MongoDB Enterprise)。

有关为特定认证机制创建用户的详细信息,请参阅特定认证机制页面。

有关用户创建和管理的最佳实践,请参阅➤ Configure Role-Based Access Control

停机时间

以下执行访问控制的过程需要停机。 对于不需要停机的过程,请参阅Update Replica Set to Keyfile Authentication (No Downtime)

对现有副本集实施密钥文件访问控制

  1. 创建密钥文件

    使用 keyfile身份验证,副本集中的每个mongod 实例都使用密钥文件的内容作为共享密码来对部署中的其他成员进行身份验证。 只有具有正确密钥文件的 mongod 实例才能加入副本集。

    [NOTE]注意

    从 MongoDB 4.2 开始,keyfiles for internal membership authentication使用 YAML 格式以允许密钥文件中有多个密钥。 YAML 格式接受以下内容:

    • 单个键字符串(与早期版本相同),

    • 多个键字符串(每个字符串必须用引号引起来),或

    • 键字符串的序列。

    YAML 格式与使用文本文件格式的现有单密钥密钥文件兼容。

    密钥的长度必须介于 6 到 1024 个字符之间,并且只能包含 base64 集中的字符。 副本集的所有成员必须共享至少一个公共密钥。

    [NOTE]注意

    在 UNIX 系统上,密钥文件不得具有组或世界权限。 在 Windows 系统上,不检查密钥文件权限。

    您可以使用您选择的任何方法生成密钥文件。 例如以下操作使用openssl生成一个复杂的伪随机1024字符串作为共享密码。 然后它使用 chmod 更改文件权限以仅向文件所有者提供读取权限:

    openssl rand -base64 756 > <path-to-keyfile>
    chmod 400 <path-to-keyfile>
    
  2. 将密钥文件复制到每个副本集成员

    将密钥文件复制到托管副本集成员的每个服务器。 确保运行 mongod 实例的用户是文件的所有者并且可以访问密钥文件。

    避免将密钥文件存储在可以轻松与托管 mongod 实例的硬件断开连接的存储介质上,例如 USB 驱动器或网络附加存储设备。

  3. 关闭副本集的所有成员

    关闭副本集中的每个 mongod,从secondaries开始。 继续直到副本集的所有成员都离线,包括任何arbiters。 主要成员必须是最后一个关闭的成员,以避免潜在的回滚。

    要关闭 mongod,请使用 mongosh 连接每个 mongod 并在admin 数据库上发出 db.shutdownServer()

    use admin
    db.shutdownServer()
    

    在这一步结束时,副本集的所有成员都应该离线。

  4. 在强制执行访问控制的情况下重新启动副本集的每个成员

    对于副本集中的每个成员,使用 security.keyFile 配置文件设置或 --keyFile 命令行选项启动 mongod。 使用 --keyFile 命令行选项或 security.keyFile 配置文件设置运行 mongod 会强制执行Internal/Membership AuthenticationRole-Based Access Control

    配置文件

    如果使用配置文件,设置

    根据您的配置需要包括其他选项。 例如,如果您希望远程客户端连接到您的部署或您的部署成员在不同的主机上运行,请指定 net.bindIp 设置。 有关详细信息,请参阅Localhost Binding Compatibility Changes.

    security:
      keyFile: <path-to-keyfile>
    replication:
      replSetName: <replicaSetName>
    net:
       bindIp: localhost,<hostname(s)|ip address(es)>
    

    使用配置文件启动mongod

    mongod --config <path-to-config-file>
    

    有关配置文件的更多信息,请参阅configuration options

    命令行 如果使用命令行选项,请使用以下选项启动 mongod

    • --keyFile 设置为密钥文件的路径,并且

    • --replSet 设置为副本集名称。

    根据您的配置需要包括其他选项。 例如,如果您希望远程客户端连接到您的部署或您的部署成员在不同的主机上运行,请指定 --bind_ip。 有关详细信息,请参阅Localhost Binding Compatibility Changes

    mongod --keyFile <path-to-keyfile> --replSet <replicaSetName> --bind_ip localhost,<hostname(s)|ip address(es)>
    

    [IMPORTANT]重要 为避免因 IP 地址更改而导致配置更新,请使用 DNS 主机名而不是 IP 地址。 在配置副本集成员或分片集群成员时,使用 DNS 主机名而不是 IP 地址尤为重要。

    使用主机名而不是 IP 地址来配置跨分割网络水平的集群。 从 MongoDB 5.0 开始,仅配置了 IP 地址的节点将无法通过启动验证而不会启动。

    有关命令行选项的更多信息,请参阅 mongod 参考页。

  5. 通过本地主机接口连接到副本集的成员

    通过localhost interfacemongosh 连接到其中一个 mongod实例。 您必须在与 mongod 实例相同的物理机器上运行 mongosh

    使用 rs.status() 来识别主副本集成员。 如果您已连接到主服务器,请继续执行下一步。 如果没有,请通过 localhost interfacemongosh 连接到主服务器。

    [IMPORTANT]重要

    在继续之前,您必须连接到主服务器。

  6. 创建用户管理员

    [IMPORTANT]重要

    创建第一个用户后, localhost exception将不再可用。

    第一个用户必须具有创建其他用户的权限,例如具有 userAdminAnyDatabase 的用户。 这确保您可以在 Localhost Exception 关闭后创建其他用户。

    如果至少有一个用户没有创建用户的权限,一旦 localhost 异常关闭,您可能无法创建或修改具有新权限的用户,因此无法访问必要的操作。

    使用 db.createUser() 方法添加用户。 用户至少应具有 admin 数据库的 userAdminAnyDatabase 角色。

    您必须连接到主服务器才能创建用户。

    以下示例在 admin 数据库上创建具有 userAdminAnyDatabase 角色的用户 fred。

    [IMPORTANT]重要

    密码应随机、较长且复杂,以确保系统安全并防止或延迟恶意访问。

    [TIP]提示

    mongo shell 版本 4.2 开始,您可以使用 passwordPrompt() 方法结合各种用户身份验证/管理方法/命令来提示输入密码,而不是直接在方法/命令调用中指定密码。 但是,您仍然可以像使用早期版本的 mongo shell 一样直接指定密码。

    admin = db.getSiblingDB("admin")
    admin.createUser(
      {
        user: "fred",
        pwd: passwordPrompt(), // or cleartext password
        roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
      }
    )
    

    出现提示时输入密码。有关内置角色和与数据库管理操作相关的完整列表,请参阅Database User Roles

  7. 以用户管理员身份进行身份验证

    向管理数据库进行身份验证。

    mongosh 中,使用 db.auth() 进行身份验证。 例如,以下身份验证为用户管理员 fred

    [TIP]提示

    mongo shell 版本 4.2 开始,您可以使用 passwordPrompt() 方法结合各种用户身份验证/管理方法/命令来提示输入密码,而不是直接在方法/命令调用中指定密码。 但是,您仍然可以像使用早期版本的 mongo shell 一样直接指定密码。

    db.getSiblingDB("admin").auth("fred", passwordPrompt()) // or cleartext password
    

    或者,使用 -u <username>-p <password>--authenticationDatabase 参数将新的 mongosh 实例连接到主副本集成员。

    mongosh -u "fred" -p  --authenticationDatabase "admin"
    

    如果您没有为 -p 命令行选项指定密码,mongosh 会提示输入密码。

  8. 创建集群管理员(可选)

    clusterAdmin 角色授予对复制操作的访问权限,例如配置副本集。

    创建集群管理员用户并在 admin 数据库中分配 clusterAdmin 角色:

    [TIP]提示

    mongo shell 版本 4.2 开始,您可以使用 passwordPrompt() 方法结合各种用户身份验证/管理方法/命令来提示输入密码,而不是直接在方法/命令调用中指定密码。 但是,您仍然可以像使用早期版本的 mongo shell 一样直接指定密码。

    db.getSiblingDB("admin").createUser(
      {
        "user" : "ravi",
        "pwd" : passwordPrompt(),     // or cleartext password
        roles: [ { "role" : "clusterAdmin", "db" : "admin" } ]
      }
    )
    

    出现提示时输入密码。

    有关与副本集和分片集群操作相关的内置角色的完整列表,请参阅Cluster Administration Roles

  9. 创建其他用户(可选)

    创建用户以允许客户端连接副本集并与之交互。 有关用于创建只读和读写用户的基本内置角色,请参阅Database User Roles

    您可能还需要其他管理用户。 有关用户的更多信息,请参阅Users

x.509 内部认证

有关使用 x.509 进行内部身份验证的详细信息,请参阅Use x.509 Certificate for Membership Authentication

要从密钥文件内部身份验证升级到 x.509 内部身份验证,请参阅Upgrade from Keyfile Authentication to x.509 Authentication

参见

原文 - Update Replica Set to Keyfile Authentication

译者:景圣

Copyright © 上海锦木信息技术有限公司 all right reserved,powered by Gitbook文件修订时间: 2023-09-01 17:10:26

results matching ""

    No results matching ""