18.3. 指定 DNS 分配给端口的名称

当您启用 Red Hat OpenStack Platform(RHOSP)Networking 服务(neutron)dns_domain 用于端口扩展时,您可以通过内部 DNS指定分配给端口的名称

您可以通过在 YAML 格式的环境文件中声明 RHOSP Orchestration(heat) NeutronPluginExtensions 参数,为端口扩展启用 dns_domain。使用对应参数 NeutronDnsDomain,您可以指定您的域名,这将覆盖默认值 openstacklocal。重新部署 overcloud 后,您可以使用 OpenStack 客户端端口命令、端口集端口创建,使用 --dns-name 来分配端口名称。

另外,当启用端口扩展的 dns_domain 时,计算服务会在引导虚拟机实例过程中使用实例的 hostname 属性填充 dns_name 属性。在引导过程结束时,dnsmasq 会根据其实例主机名识别分配的端口。

流程

  1. 以 stack 用户身份登录 undercloud,并提供 stackrc 文件,以启用 director 命令行工具。

    示例

    $ source ~/stackrc

  2. 创建自定义 YAML 环境文件(my-neutron-environment.yaml)。

    注意

    括号内的值是此流程中示例命令中使用的示例值。将这些示例值替换为适合您的站点的值。

    示例

    $ vi /home/stack/templates/my-neutron-environment.yaml

    提示

    undercloud 包括一组构成您的 overcloud 创建计划的编排服务模板。您可以使用环境文件来自定义 overcloud 的各个方面,这些文件是 YAML 格式的文件,可覆盖核心编排服务模板集合中的参数和资源。您可以根据需要纳入多个环境文件。

  3. 在环境文件中,添加 parameter_defaults 部分。在本节下,为端口扩展 dns_domain_ports 添加 dns_domain。

    示例

    parameter_defaults:
      NeutronPluginExtensions: "qos,port_security,dns_domain_ports"

    注意

    如果您设置了 dns_domain_ports,请确保部署不使用 dns_domain,则 DNS 集成扩展。这些扩展不兼容,扩展无法同时定义。

  4. 另外,在 parameter_defaults 部分中,使用 NeutronDnsDomain 参数添加您的域名(example.com)。

    示例

    parameter_defaults:
        NeutronPluginExtensions: "qos,port_security,dns_domain_ports"
        NeutronDnsDomain: "example.com"

  5. 运行 openstack overcloud deploy 命令,包括核心编配模板、环境文件和这个新环境文件。

    重要

    环境文件的顺序非常重要,因为后续环境文件中定义的参数和资源更为优先。

    示例

    $ openstack overcloud deploy --templates \
    -e [your-environment-files] \
    -e /usr/share/openstack-tripleo-heat-templates/environments/services/my-neutron-environment.yaml

验证

  1. 登录 overcloud,并在网络(公共)上创建新端口(new_port)。为端口分配 DNS 名称(my_port)。

    示例

    $ source ~/overcloudrc
    $ openstack port create --network public --dns-name my_port new_port

  2. 显示端口的详细信息(new_port)。

    示例

    $ openstack port show -c dns_assignment -c dns_domain -c dns_name -c name new_port

    输出

    +-------------------------+----------------------------------------------+
    | Field                   | Value                                        |
    +-------------------------+----------------------------------------------+
    | dns_assignment          | fqdn='my_port.example.com',                  |
    |                         | hostname='my_port',                          |
    |                         | ip_address='10.65.176.113'                   |
    | dns_domain              | example.com                                  |
    | dns_name                | my_port                                      |
    | name                    | new_port                                     |
    +-------------------------+----------------------------------------------+

    dns_assignment 下,端口的完全限定域名(fqdn)值包含 DNS 名称(my_port)的串联,以及您之前使用 NeutronDnsDomain 设置的域名(example.com)。

  3. 使用您刚才创建的端口(new_port)创建新的虚拟机实例(my_vm)。

    示例

    $ openstack server create --image rhel --flavor m1.small --port new_port my_vm

  4. 显示端口的详细信息(new_port)。

    示例

    $ openstack port show -c dns_assignment -c dns_domain -c dns_name -c name new_port

    输出

    +-------------------------+----------------------------------------------+
    | Field                   | Value                                        |
    +-------------------------+----------------------------------------------+
    | dns_assignment          | fqdn='my_vm.example.com',                    |
    |                         | hostname='my_vm',                            |
    |                         | ip_address='10.65.176.113'                   |
    | dns_domain              | example.com                                  |
    | dns_name                | my_vm                                        |
    | name                    | new_port                                     |
    +-------------------------+----------------------------------------------+

    请注意,计算服务将 dns_name 属性从其原始值(my_port)改为与端口关联的实例的名称(my_vm)。

其他资源