docker: add logging(source & groups)
[apex-tripleo-heat-templates.git] / docker / services / congress.yaml
1 heat_template_version: pike
2
3 description: >
4   OpenStack containerized Congress API service
5
6 parameters:
7   DockerCongressApiImage:
8     description: image
9     type: string
10   DockerCongressConfigImage:
11     description: The container image to use for the congress config_volume
12     type: string
13   EndpointMap:
14     default: {}
15     description: Mapping of service endpoint -> protocol. Typically set
16                  via parameter_defaults in the resource registry.
17     type: json
18   ServiceData:
19     default: {}
20     description: Dictionary packing service data
21     type: json
22   ServiceNetMap:
23     default: {}
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.
27     type: json
28   DefaultPasswords:
29     default: {}
30     type: json
31   RoleName:
32     default: ''
33     description: Role name on which the service is applied
34     type: string
35   RoleParameters:
36     default: {}
37     description: Parameters specific to the role
38     type: json
39
40 resources:
41
42   ContainersCommon:
43     type: ./containers-common.yaml
44
45   MySQLClient:
46     type: ../../puppet/services/database/mysql-client.yaml
47
48   CongressBase:
49     type: ../../puppet/services/congress.yaml
50     properties:
51       EndpointMap: {get_param: EndpointMap}
52       ServiceData: {get_param: ServiceData}
53       ServiceNetMap: {get_param: ServiceNetMap}
54       DefaultPasswords: {get_param: DefaultPasswords}
55       RoleName: {get_param: RoleName}
56       RoleParameters: {get_param: RoleParameters}
57
58 outputs:
59   role_data:
60     description: Role data for the Congress API role.
61     value:
62       service_name: {get_attr: [CongressBase, role_data, service_name]}
63       config_settings:
64         map_merge:
65           - get_attr: [CongressBase, role_data, config_settings]
66       logging_source: {get_attr: [CongressBase, role_data, logging_source]}
67       logging_groups: {get_attr: [CongressBase, role_data, logging_groups]}
68       step_config: &step_config
69         list_join:
70           - "\n"
71           - - {get_attr: [CongressBase, role_data, step_config]}
72             - {get_attr: [MySQLClient, role_data, step_config]}
73       service_config_settings: {get_attr: [CongressBase, role_data, service_config_settings]}
74       # BEGIN DOCKER SETTINGS
75       puppet_config:
76         config_volume: congress
77         puppet_tags: congress_config
78         step_config: *step_config
79         config_image: {get_param: DockerCongressConfigImage}
80       kolla_config:
81         /var/lib/kolla/config_files/congress_api.json:
82           command: /usr/bin/congress-server --config-file=/etc/congress/congress.conf --log-file=/var/log/congress/api.log
83           config_files:
84             - source: "/var/lib/kolla/config_files/src/*"
85               dest: "/"
86               merge: true
87               preserve_properties: true
88           permissions:
89             - path: /var/log/congress
90               owner: congress:congress
91               recurse: true
92       docker_config:
93         # db sync runs before permissions set by kolla_config
94         step_2:
95           congress_init_logs:
96             image: &congress_api_image {get_param: DockerCongressApiImage}
97             privileged: false
98             user: root
99             volumes:
100               - /var/log/containers/congress:/var/log/congress
101             command: ['/bin/bash', '-c', 'chown -R congress:congress /var/log/congress']
102         step_3:
103           congress_db_sync:
104             image: *congress_api_image
105             net: host
106             privileged: false
107             detach: false
108             user: root
109             volumes:
110               list_concat:
111                 - {get_attr: [ContainersCommon, volumes]}
112                 -
113                   # FIXME(mandre) mounting /etc rw to workaround LP1696283
114                   # This should go away anyway and mount the exact files it
115                   # needs or use kolla set_configs.py
116                   - /var/lib/config-data/congress/etc/:/etc/
117                   - /var/log/containers/congress:/var/log/congress
118             command: "/usr/bin/bootstrap_host_exec congress su congress -s /bin/bash -c 'congress-db-manage --config-file /etc/congress/congress.conf upgrade head'"
119         step_4:
120           congress_api:
121             start_order: 15
122             image: *congress_api_image
123             net: host
124             privileged: false
125             restart: always
126             volumes:
127               list_concat:
128                 - {get_attr: [ContainersCommon, volumes]}
129                 -
130                   - /var/lib/kolla/config_files/congress_api.json:/var/lib/kolla/config_files/config.json:ro
131                   - /var/lib/config-data/puppet-generated/congress/:/var/lib/kolla/config_files/src:ro
132                   - /var/log/containers/congress:/var/log/congress
133             environment:
134               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
135       host_prep_tasks:
136         - name: create persistent logs directory
137           file:
138             path: /var/log/containers/congress
139             state: directory
140       upgrade_tasks:
141         - name: Stop and disable congress_api service
142           tags: step2
143           service: name=openstack-congress-server state=stopped enabled=no