Merge "Add sample usage of StorageMgmt network for compute nodes"
[apex-tripleo-heat-templates.git] / docker / services / ironic-pxe.yaml
1 heat_template_version: pike
2
3 description: >
4   OpenStack containerized Ironic PXE service
5
6 parameters:
7   DockerNamespace:
8     description: namespace
9     default: 'tripleoupstream'
10     type: string
11   DockerIronicPxeImage:
12     description: image
13     default: 'centos-binary-ironic-pxe:latest'
14     type: string
15   DockerIronicConfigImage:
16     description: The container image to use for the ironic config_volume
17     default: 'centos-binary-ironic-pxe:latest'
18     type: string
19   EndpointMap:
20     default: {}
21     description: Mapping of service endpoint -> protocol. Typically set
22                  via parameter_defaults in the resource registry.
23     type: json
24   ServiceNetMap:
25     default: {}
26     description: Mapping of service_name -> network name. Typically set
27                  via parameter_defaults in the resource registry.  This
28                  mapping overrides those in ServiceNetMapDefaults.
29     type: json
30   DefaultPasswords:
31     default: {}
32     type: json
33   RoleName:
34     default: ''
35     description: Role name on which the service is applied
36     type: string
37   RoleParameters:
38     default: {}
39     description: Parameters specific to the role
40     type: json
41
42 resources:
43
44   ContainersCommon:
45     type: ./containers-common.yaml
46
47 outputs:
48   role_data:
49     description: Role data for the Ironic PXE role.
50     value:
51       service_name: ironic_pxe
52       config_settings: {}
53       step_config: &step_config ''
54       service_config_settings: {}
55       # BEGIN DOCKER SETTINGS
56       puppet_config:
57         config_volume: ironic
58         puppet_tags: ironic_config
59         step_config: *step_config
60         config_image:
61           list_join:
62             - '/'
63             - [ {get_param: DockerNamespace}, {get_param: DockerIronicConfigImage} ]
64       kolla_config:
65         /var/lib/kolla/config_files/ironic_pxe_http.json:
66           command: /usr/sbin/httpd -DFOREGROUND
67         /var/lib/kolla/config_files/ironic_pxe_tftp.json:
68           command: /usr/sbin/in.tftpd --foreground --user root --address 0.0.0.0:69 --map-file /var/lib/ironic/tftpboot/map-file /var/lib/ironic/tftpboot
69           permissions:
70             - path: /var/log/ironic
71               owner: ironic:ironic
72               recurse: true
73       docker_config:
74         step_4:
75           ironic_pxe_tftp:
76             start_order: 90
77             image: &ironic_pxe_image
78               list_join:
79                 - '/'
80                 - [ {get_param: DockerNamespace}, {get_param: DockerIronicPxeImage} ]
81             net: host
82             privileged: false
83             restart: always
84             volumes:
85               list_concat:
86                 - {get_attr: [ContainersCommon, volumes]}
87                 -
88                   - /var/lib/kolla/config_files/ironic_pxe_tftp.json:/var/lib/kolla/config_files/config.json:ro
89                   - /var/lib/config-data/ironic/etc/ironic/:/etc/ironic/:ro
90                   # TODO(mandre) check how docker like mounting in a bind-mounted tree
91                   # This directory may contain migrated data from BM
92                   - /var/lib/ironic:/var/lib/ironic/
93                   # These files were generated by puppet inside the config container
94                   # TODO(mandre) check the mount permission (ro/rw)
95                   - /var/lib/config-data/ironic/var/lib/ironic/tftpboot/chain.c32:/var/lib/ironic/tftpboot/chain.c32
96                   - /var/lib/config-data/ironic/var/lib/ironic/tftpboot/pxelinux.0:/var/lib/ironic/tftpboot/pxelinux.0
97                   - /var/lib/config-data/ironic/var/lib/ironic/tftpboot/ipxe.efi:/var/lib/ironic/tftpboot/ipxe.efi
98                   - /var/lib/config-data/ironic/var/lib/ironic/tftpboot/undionly.kpxe:/var/lib/ironic/tftpboot/undionly.kpxe
99                   - /var/lib/config-data/ironic/var/lib/ironic/tftpboot/map-file:/var/lib/ironic/tftpboot/map-file
100                   - /dev/log:/dev/log
101                   - /var/log/containers/ironic:/var/log/ironic
102             environment:
103               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
104           ironic_pxe_http:
105             start_order: 91
106             image: *ironic_pxe_image
107             net: host
108             privileged: false
109             restart: always
110             volumes:
111               list_concat:
112                 - {get_attr: [ContainersCommon, volumes]}
113                 -
114                   - /var/lib/kolla/config_files/ironic_pxe_http.json:/var/lib/kolla/config_files/config.json:ro
115                   - /var/lib/config-data/ironic/etc/ironic/:/etc/ironic/:ro
116                   - /var/lib/config-data/ironic/etc/httpd/conf/:/etc/httpd/conf/:ro
117                   - /var/lib/config-data/ironic/etc/httpd/conf.d/:/etc/httpd/conf.d/:ro
118                   - /var/lib/config-data/ironic/etc/httpd/conf.modules.d/:/etc/httpd/conf.modules.d/:ro
119                   - /var/lib/config-data/ironic/var/www/:/var/www/:ro
120                   - /var/lib/ironic:/var/lib/ironic/
121                   - /var/log/containers/ironic:/var/log/ironic
122             environment:
123               - KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
124       host_prep_tasks:
125         - name: create persistent directories
126           file:
127             path: "{{ item }}"
128             state: directory
129           with_items:
130             - /var/lib/ironic
131             - /var/log/containers/ironic