通过Heat快速搭建分布式designate服务

Posted by xue on December 10, 2016

heat基础知识

本文可以在已安装openstack的环境下,快速搭建分布式designate服务。

使用到的heat 内部函数

  • get_attr

作用:获取所创建资源的属性。

get_attr:

  - <resource name>

  - <attribute name>

  - <key/index 1> (optional)

  - <key/index 2> (optional)

  - ...

Resource name:必须是模板 resouce 段中指定的资源。
Attribute name:要获取的属性,如果属性对应的值是list 或map, 则可以指定key/index来获取具体的值。
示例:

resources:

  my_instance:

    type: OS::Nova::Server

 ...



outputs:

  instance_ip:

    description: IP address of the deployed compute instance

    value: { get_attr: [my_instance, first_address] }

  instance_private_ip:

    description: Private IP address of the deployed compute instance

    value: { get_attr: [my_instance, networks, private, 0] }
  • get_param

作用:引用模板中指定的参数。 语法:

get_param:

 - <parameter name>

 - <key/index 1> (optional)

 - <key/index 2> (optional)

 - ...

示例:

parameters:

   instance_type:

    type: string

    label: Instance Type

    description: Instance type to be used.

  server_data:

    type: json



resources:

  my_instance:

    type: OS::Nova::Server

    properties:

      flavor: { get_param: instance_type}

      metadata: { get_param: [ server_data, metadata ] }

      key_name: { get_param: [ server_data, keys, 0 ] }

输入参数是:

{"instance_type": "m1.tiny",
{"server_data": {"metadata": {"foo": "bar"},
                 "keys": ["a_key","other_key"]}}}

  • get_resource 作用:获取模板中指定的资源。 语法:
get_resource: <resource ID>

示例:

resources:

  instance_port:

    type: OS::Neutron::Port

    properties: ...



  instance:

    type: OS::Nova::Server

    properties:

      ...

      networks:

        port: { get_resource: instance_port }

heat模板分析

模板中各参数(parameters)的含义

参数名称 参数含义
key_name Name of key-pair to be used for compute in
image_id 镜像id
instance_type Type of instance (flavor) to be used
secgroup_name security groups ,可以是一个列表
password root登录密码
service_passwd designate mysql rabbitmq keystone 相关服务的密码
network_id network id

模板中各资源(resources)的含义

资源名称 资源类型 资源作用
dns_secgroup OS::Neutron::SecurityGroup 为创建的两台虚拟机配置安全组规则,允许53端口的入口流量,即允许外部向它们发送dns请求
designate-slave OS::Nova::Server 此虚拟机安装bind服务
designate-master OS::Nova::Server 此虚拟机安装mysql rabbitmq keystone designate bind 服务

搭建步骤

1.创建下面的yaml文件:

designate-final.yaml

  1. 执行命令(根据具体需要修改参数):
openstack stack create -t designate-final.yaml -p "key_name=$KEY_NAME image_id=$IMAGE_ID instance_type=$INSTANCE_TYPE network_id=$NETWORK_ID" STACK_NAME

注意:由于我事先在镜像里安装了designate rabbitmq mysql bind keystone httpd 等相关包,所以此heat模板中并没有包的安装过程,如果用此模板安装,必须要使用安装了所有相关软件包的镜像(镜像必须为centos7系统)。等待两分钟左右便可。关于designate的原理和操作可以查看我的另一篇博客: puppet-designate
另外如果镜像不包含相应的软件包,也可以创建下面的heat模板,此模板自带相应软件包的安装: designate-final-full.yaml

扩展节点

如果后面觉得两个节点的不够使,再扩展slave节点的话也比较简单,再扩展的designate-slave节点的内容完全一致,直接copy一份再改一下name。designate-master也很简单,只需要在最后的params中加上$slave_new_ip_address: {get_attr: [designate-slave-new, first_address]},然后把$slave_new_ip_address加入到bind配置文件中即可。