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 logging_source: {get_attr: [MongodbPuppetBase, role_data, logging_source]}
74 logging_groups: {get_attr: [MongodbPuppetBase, role_data, logging_groups]}
75 step_config: &step_config
78 - - "['Mongodb_database', 'Mongodb_user', 'Mongodb_replset'].each |String $val| { noop_resource($val) }"
79 - {get_attr: [MongodbPuppetBase, role_data, step_config]}
80 # BEGIN DOCKER SETTINGS #
82 config_volume: mongodb
83 puppet_tags: file # set this even though file is the default
84 step_config: *step_config
85 config_image: &mongodb_config_image {get_param: DockerMongodbConfigImage}
87 /var/lib/kolla/config_files/mongodb.json:
88 command: /usr/bin/mongod --unixSocketPrefix=/var/run/mongodb --config /etc/mongod.conf run
90 - source: "/var/lib/kolla/config_files/src/*"
93 preserve_properties: true
94 - source: "/var/lib/kolla/config_files/src-tls/*"
97 preserve_properties: true
99 - path: /var/lib/mongodb
100 owner: mongodb:mongodb
102 - path: /var/log/mongodb
103 owner: mongodb:mongodb
105 - path: /etc/pki/tls/certs/mongodb.pem
106 owner: mongodb:mongodb
110 image: {get_param: DockerMongodbImage}
113 volumes: &mongodb_volumes
115 - - /var/lib/kolla/config_files/mongodb.json:/var/lib/kolla/config_files/config.json
116 - /var/lib/config-data/puppet-generated/mongodb/:/var/lib/kolla/config_files/src:ro
117 - /etc/localtime:/etc/localtime:ro
118 - /var/log/containers/mongodb:/var/log/mongodb
119 - /var/lib/mongodb:/var/lib/mongodb
121 - internal_tls_enabled
124 - - {get_param: InternalTLSCAFile}
125 - {get_param: InternalTLSCAFile}
127 - /etc/pki/tls/certs/mongodb.pem:/var/lib/kolla/config_files/src-tls/etc/pki/tls/certs/mongodb.pem:ro
130 - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
132 # MySQL database initialization occurs only on single node
134 config_volume: 'mongodb_init_tasks'
135 puppet_tags: 'mongodb_database,mongodb_user,mongodb_replset'
136 step_config: 'include ::tripleo::profile::base::database::mongodb'
137 config_image: *mongodb_config_image
140 - - /var/lib/mongodb:/var/lib/mongodb
141 - /var/log/containers/mongodb:/var/log/mongodb
143 - internal_tls_enabled
146 - - {get_param: InternalTLSCAFile}
147 - {get_param: InternalTLSCAFile}
149 - /etc/pki/tls/certs/mongodb.pem:/var/lib/kolla/config_files/src-tls/etc/pki/tls/certs/mongodb.pem:ro
152 - name: create persistent directories
157 - /var/log/containers/mongodb
160 get_attr: [MongodbPuppetBase, role_data, metadata_settings]
162 - name: Check for mongodb service
163 stat: path=/usr/lib/systemd/system/mongod.service
165 register: mongod_service
166 - name: Stop and disable mongodb service
168 service: name=mongod state=stopped enabled=no
169 when: mongod_service.stat.exists