1 heat_template_version: pike
4 MongoDB service deployment using puppet and docker
10 DockerMongodbConfigImage:
11 description: The container image to use for the mongodb config_volume
15 description: Mapping of service endpoint -> protocol. Typically set
16 via parameter_defaults in the resource registry.
20 description: Dictionary packing service data
24 description: Mapping of service_name -> network name. Typically set
25 via parameter_defaults in the resource registry. This
26 mapping overrides those in ServiceNetMapDefaults.
33 description: Role name on which the service is applied
37 description: Parameters specific to the role
43 default: '/etc/ipa/ca.crt'
45 description: Specifies the default CA cert to use if TLS is used for
46 services in the internal network.
50 internal_tls_enabled: {equals: [{get_param: EnableInternalTLS}, true]}
55 type: ../../../puppet/services/database/mongodb.yaml
57 EndpointMap: {get_param: EndpointMap}
58 ServiceData: {get_param: ServiceData}
59 ServiceNetMap: {get_param: ServiceNetMap}
60 DefaultPasswords: {get_param: DefaultPasswords}
61 RoleName: {get_param: RoleName}
62 RoleParameters: {get_param: RoleParameters}
66 description: Containerized service Mongodb using composable services.
68 service_name: {get_attr: [MongodbPuppetBase, role_data, service_name]}
71 - get_attr: [MongodbPuppetBase, role_data, config_settings]
72 - mongodb::server::fork: false
73 step_config: &step_config
76 - - "['Mongodb_database', 'Mongodb_user', 'Mongodb_replset'].each |String $val| { noop_resource($val) }"
77 - {get_attr: [MongodbPuppetBase, role_data, step_config]}
78 # BEGIN DOCKER SETTINGS #
80 config_volume: mongodb
81 puppet_tags: file # set this even though file is the default
82 step_config: *step_config
83 config_image: &mongodb_config_image {get_param: DockerMongodbConfigImage}
85 /var/lib/kolla/config_files/mongodb.json:
86 command: /usr/bin/mongod --unixSocketPrefix=/var/run/mongodb --config /etc/mongod.conf run
88 - source: "/var/lib/kolla/config_files/src/*"
91 preserve_properties: true
92 - source: "/var/lib/kolla/config_files/src-tls/*"
95 preserve_properties: true
97 - path: /var/lib/mongodb
98 owner: mongodb:mongodb
100 - path: /var/log/mongodb
101 owner: mongodb:mongodb
103 - path: /etc/pki/tls/certs/mongodb.pem
104 owner: mongodb:mongodb
108 image: {get_param: DockerMongodbImage}
111 volumes: &mongodb_volumes
113 - - /var/lib/kolla/config_files/mongodb.json:/var/lib/kolla/config_files/config.json
114 - /var/lib/config-data/puppet-generated/mongodb/:/var/lib/kolla/config_files/src:ro
115 - /etc/localtime:/etc/localtime:ro
116 - /var/log/containers/mongodb:/var/log/mongodb
117 - /var/lib/mongodb:/var/lib/mongodb
119 - internal_tls_enabled
122 - - {get_param: InternalTLSCAFile}
123 - {get_param: InternalTLSCAFile}
125 - /etc/pki/tls/certs/mongodb.pem:/var/lib/kolla/config_files/src-tls/etc/pki/tls/certs/mongodb.pem:ro
128 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
130 # MySQL database initialization occurs only on single node
132 config_volume: 'mongodb_init_tasks'
133 puppet_tags: 'mongodb_database,mongodb_user,mongodb_replset'
134 step_config: 'include ::tripleo::profile::base::database::mongodb'
135 config_image: *mongodb_config_image
138 - - /var/lib/mongodb:/var/lib/mongodb
139 - /var/log/containers/mongodb:/var/log/mongodb
141 - internal_tls_enabled
144 - - {get_param: InternalTLSCAFile}
145 - {get_param: InternalTLSCAFile}
147 - /etc/pki/tls/certs/mongodb.pem:/var/lib/kolla/config_files/src-tls/etc/pki/tls/certs/mongodb.pem:ro
150 - name: create persistent directories
155 - /var/log/containers/mongodb
158 get_attr: [MongodbPuppetBase, role_data, metadata_settings]
160 - name: Stop and disable mongodb service
162 service: name=mongod state=stopped enabled=no