heat_stack.yaml.j2 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861
  1. heat_template_version: 2016-10-14
  2. description: OpenShift cluster
  3. parameters:
  4. outputs:
  5. etcd_names:
  6. description: Name of the etcds
  7. value: { get_attr: [ etcd, name ] }
  8. etcd_ips:
  9. description: IPs of the etcds
  10. value: { get_attr: [ etcd, private_ip ] }
  11. etcd_floating_ips:
  12. description: Floating IPs of the etcds
  13. value: { get_attr: [ etcd, floating_ip ] }
  14. master_names:
  15. description: Name of the masters
  16. value: { get_attr: [ masters, name ] }
  17. master_ips:
  18. description: IPs of the masters
  19. value: { get_attr: [ masters, private_ip ] }
  20. master_floating_ips:
  21. description: Floating IPs of the masters
  22. value: { get_attr: [ masters, floating_ip ] }
  23. node_names:
  24. description: Name of the nodes
  25. value: { get_attr: [ compute_nodes, name ] }
  26. node_ips:
  27. description: IPs of the nodes
  28. value: { get_attr: [ compute_nodes, private_ip ] }
  29. node_floating_ips:
  30. description: Floating IPs of the nodes
  31. value: { get_attr: [ compute_nodes, floating_ip ] }
  32. infra_names:
  33. description: Name of the nodes
  34. value: { get_attr: [ infra_nodes, name ] }
  35. infra_ips:
  36. description: IPs of the nodes
  37. value: { get_attr: [ infra_nodes, private_ip ] }
  38. infra_floating_ips:
  39. description: Floating IPs of the nodes
  40. value: { get_attr: [ infra_nodes, floating_ip ] }
  41. conditions:
  42. no_floating: {% if openshift_openstack_provider_network_name %}true{% else %}false{% endif %}
  43. resources:
  44. {% if not openshift_openstack_provider_network_name %}
  45. net:
  46. type: OS::Neutron::Net
  47. properties:
  48. name:
  49. str_replace:
  50. template: openshift-ansible-cluster_id-net
  51. params:
  52. cluster_id: {{ openshift_openstack_stack_name }}
  53. subnet:
  54. type: OS::Neutron::Subnet
  55. properties:
  56. name:
  57. str_replace:
  58. template: openshift-ansible-cluster_id-subnet
  59. params:
  60. cluster_id: {{ openshift_openstack_stack_name }}
  61. network: { get_resource: net }
  62. cidr:
  63. str_replace:
  64. template: subnet_24_prefix.0/24
  65. params:
  66. subnet_24_prefix: {{ openshift_openstack_subnet_prefix }}
  67. allocation_pools:
  68. - start:
  69. str_replace:
  70. template: subnet_24_prefix.3
  71. params:
  72. subnet_24_prefix: {{ openshift_openstack_subnet_prefix }}
  73. end:
  74. str_replace:
  75. template: subnet_24_prefix.254
  76. params:
  77. subnet_24_prefix: {{ openshift_openstack_subnet_prefix }}
  78. dns_nameservers:
  79. {% for nameserver in openshift_openstack_dns_nameservers %}
  80. - {{ nameserver }}
  81. {% endfor %}
  82. {% if openshift_use_flannel|default(False)|bool %}
  83. data_net:
  84. type: OS::Neutron::Net
  85. properties:
  86. name: openshift-ansible-{{ openshift_openstack_stack_name }}-data-net
  87. port_security_enabled: false
  88. data_subnet:
  89. type: OS::Neutron::Subnet
  90. properties:
  91. name: openshift-ansible-{{ openshift_openstack_stack_name }}-data-subnet
  92. network: { get_resource: data_net }
  93. cidr: {{ osm_cluster_network_cidr|default('10.128.0.0/14') }}
  94. gateway_ip: null
  95. {% endif %}
  96. router:
  97. type: OS::Neutron::Router
  98. properties:
  99. name:
  100. str_replace:
  101. template: openshift-ansible-cluster_id-router
  102. params:
  103. cluster_id: {{ openshift_openstack_stack_name }}
  104. external_gateway_info:
  105. network: {{ openshift_openstack_external_network_name }}
  106. interface:
  107. type: OS::Neutron::RouterInterface
  108. properties:
  109. router_id: { get_resource: router }
  110. subnet_id: { get_resource: subnet }
  111. {% endif %}
  112. # keypair:
  113. # type: OS::Nova::KeyPair
  114. # properties:
  115. # name:
  116. # str_replace:
  117. # template: openshift-ansible-cluster_id-keypair
  118. # params:
  119. # cluster_id: {{ openshift_openstack_stack_name }}
  120. # public_key: {{ openshift_openstack_keypair_name }}
  121. common-secgrp:
  122. type: OS::Neutron::SecurityGroup
  123. properties:
  124. name:
  125. str_replace:
  126. template: openshift-ansible-cluster_id-common-secgrp
  127. params:
  128. cluster_id: {{ openshift_openstack_stack_name }}
  129. description:
  130. str_replace:
  131. template: Basic ssh/icmp security group for cluster_id OpenShift cluster
  132. params:
  133. cluster_id: {{ openshift_openstack_stack_name }}
  134. rules:
  135. - direction: ingress
  136. protocol: tcp
  137. port_range_min: 22
  138. port_range_max: 22
  139. remote_ip_prefix: {{ openshift_openstack_ssh_ingress_cidr }}
  140. - direction: ingress
  141. protocol: icmp
  142. remote_ip_prefix: {{ openshift_openstack_ssh_ingress_cidr }}
  143. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  144. flat-secgrp:
  145. type: OS::Neutron::SecurityGroup
  146. properties:
  147. name:
  148. str_replace:
  149. template: openshift-ansible-cluster_id-flat-secgrp
  150. params:
  151. cluster_id: {{ openshift_openstack_stack_name }}
  152. description:
  153. str_replace:
  154. template: Security group for cluster_id OpenShift cluster
  155. params:
  156. cluster_id: {{ openshift_openstack_stack_name }}
  157. rules:
  158. - direction: ingress
  159. protocol: tcp
  160. port_range_min: 4001
  161. port_range_max: 4001
  162. - direction: ingress
  163. protocol: tcp
  164. port_range_min: {{ openshift_master_api_port|default(8443) }}
  165. port_range_max: {{ openshift_master_api_port|default(8443) }}
  166. - direction: ingress
  167. protocol: tcp
  168. port_range_min: {{ openshift_master_console_port|default(8443) }}
  169. port_range_max: {{ openshift_master_console_port|default(8443) }}
  170. - direction: ingress
  171. protocol: tcp
  172. port_range_min: 8053
  173. port_range_max: 8053
  174. - direction: ingress
  175. protocol: udp
  176. port_range_min: 8053
  177. port_range_max: 8053
  178. - direction: ingress
  179. protocol: tcp
  180. port_range_min: 24224
  181. port_range_max: 24224
  182. - direction: ingress
  183. protocol: udp
  184. port_range_min: 24224
  185. port_range_max: 24224
  186. - direction: ingress
  187. protocol: tcp
  188. port_range_min: 2224
  189. port_range_max: 2224
  190. - direction: ingress
  191. protocol: udp
  192. port_range_min: 5404
  193. port_range_max: 5405
  194. - direction: ingress
  195. protocol: tcp
  196. port_range_min: 9090
  197. port_range_max: 9090
  198. - direction: ingress
  199. protocol: tcp
  200. port_range_min: 2379
  201. port_range_max: 2380
  202. remote_mode: remote_group_id
  203. - direction: ingress
  204. protocol: tcp
  205. port_range_min: 10250
  206. port_range_max: 10250
  207. remote_mode: remote_group_id
  208. - direction: ingress
  209. protocol: udp
  210. port_range_min: 10250
  211. port_range_max: 10250
  212. remote_mode: remote_group_id
  213. - direction: ingress
  214. protocol: tcp
  215. port_range_min: 10255
  216. port_range_max: 10255
  217. remote_mode: remote_group_id
  218. - direction: ingress
  219. protocol: udp
  220. port_range_min: 10255
  221. port_range_max: 10255
  222. remote_mode: remote_group_id
  223. - direction: ingress
  224. protocol: udp
  225. port_range_min: 4789
  226. port_range_max: 4789
  227. remote_mode: remote_group_id
  228. - direction: ingress
  229. protocol: tcp
  230. port_range_min: 30000
  231. port_range_max: 32767
  232. remote_ip_prefix: {{ openshift_openstack_node_ingress_cidr }}
  233. - direction: ingress
  234. protocol: tcp
  235. port_range_min: 30000
  236. port_range_max: 32767
  237. remote_ip_prefix: "{{ openshift_openstack_subnet_prefix }}.0/24"
  238. {% else %}
  239. master-secgrp:
  240. type: OS::Neutron::SecurityGroup
  241. properties:
  242. name:
  243. str_replace:
  244. template: openshift-ansible-cluster_id-master-secgrp
  245. params:
  246. cluster_id: {{ openshift_openstack_stack_name }}
  247. description:
  248. str_replace:
  249. template: Security group for cluster_id OpenShift cluster master
  250. params:
  251. cluster_id: {{ openshift_openstack_stack_name }}
  252. rules:
  253. - direction: ingress
  254. protocol: tcp
  255. port_range_min: 4001
  256. port_range_max: 4001
  257. - direction: ingress
  258. protocol: tcp
  259. port_range_min: {{ openshift_master_api_port|default(8443) }}
  260. port_range_max: {{ openshift_master_api_port|default(8443) }}
  261. - direction: ingress
  262. protocol: tcp
  263. port_range_min: {{ openshift_master_console_port|default(8443) }}
  264. port_range_max: {{ openshift_master_console_port|default(8443) }}
  265. - direction: ingress
  266. protocol: tcp
  267. port_range_min: 8053
  268. port_range_max: 8053
  269. - direction: ingress
  270. protocol: udp
  271. port_range_min: 8053
  272. port_range_max: 8053
  273. - direction: ingress
  274. protocol: tcp
  275. port_range_min: 24224
  276. port_range_max: 24224
  277. - direction: ingress
  278. protocol: udp
  279. port_range_min: 24224
  280. port_range_max: 24224
  281. - direction: ingress
  282. protocol: tcp
  283. port_range_min: 2224
  284. port_range_max: 2224
  285. - direction: ingress
  286. protocol: udp
  287. port_range_min: 5404
  288. port_range_max: 5405
  289. - direction: ingress
  290. protocol: tcp
  291. port_range_min: 9090
  292. port_range_max: 9090
  293. {% if openshift_use_flannel|default(False)|bool %}
  294. - direction: ingress
  295. protocol: tcp
  296. port_range_min: 2379
  297. port_range_max: 2379
  298. {% endif %}
  299. etcd-secgrp:
  300. type: OS::Neutron::SecurityGroup
  301. properties:
  302. name:
  303. str_replace:
  304. template: openshift-ansible-cluster_id-etcd-secgrp
  305. params:
  306. cluster_id: {{ openshift_openstack_stack_name }}
  307. description:
  308. str_replace:
  309. template: Security group for cluster_id etcd cluster
  310. params:
  311. cluster_id: {{ openshift_openstack_stack_name }}
  312. rules:
  313. - direction: ingress
  314. protocol: tcp
  315. port_range_min: 2379
  316. port_range_max: 2379
  317. remote_mode: remote_group_id
  318. remote_group_id: { get_resource: master-secgrp }
  319. - direction: ingress
  320. protocol: tcp
  321. port_range_min: 2380
  322. port_range_max: 2380
  323. remote_mode: remote_group_id
  324. node-secgrp:
  325. type: OS::Neutron::SecurityGroup
  326. properties:
  327. name:
  328. str_replace:
  329. template: openshift-ansible-cluster_id-node-secgrp
  330. params:
  331. cluster_id: {{ openshift_openstack_stack_name }}
  332. description:
  333. str_replace:
  334. template: Security group for cluster_id OpenShift cluster nodes
  335. params:
  336. cluster_id: {{ openshift_openstack_stack_name }}
  337. rules:
  338. - direction: ingress
  339. protocol: tcp
  340. port_range_min: 10250
  341. port_range_max: 10250
  342. remote_mode: remote_group_id
  343. - direction: ingress
  344. protocol: tcp
  345. port_range_min: 10255
  346. port_range_max: 10255
  347. remote_mode: remote_group_id
  348. - direction: ingress
  349. protocol: udp
  350. port_range_min: 10255
  351. port_range_max: 10255
  352. remote_mode: remote_group_id
  353. - direction: ingress
  354. protocol: udp
  355. port_range_min: 4789
  356. port_range_max: 4789
  357. remote_mode: remote_group_id
  358. - direction: ingress
  359. protocol: tcp
  360. port_range_min: 30000
  361. port_range_max: 32767
  362. remote_ip_prefix: {{ openshift_openstack_node_ingress_cidr }}
  363. - direction: ingress
  364. protocol: tcp
  365. port_range_min: 30000
  366. port_range_max: 32767
  367. remote_ip_prefix: "{{ openshift_openstack_subnet_prefix }}.0/24"
  368. {% endif %}
  369. infra-secgrp:
  370. type: OS::Neutron::SecurityGroup
  371. properties:
  372. name:
  373. str_replace:
  374. template: openshift-ansible-cluster_id-infra-secgrp
  375. params:
  376. cluster_id: {{ openshift_openstack_stack_name }}
  377. description:
  378. str_replace:
  379. template: Security group for cluster_id OpenShift infrastructure cluster nodes
  380. params:
  381. cluster_id: {{ openshift_openstack_stack_name }}
  382. rules:
  383. - direction: ingress
  384. protocol: tcp
  385. port_range_min: 80
  386. port_range_max: 80
  387. - direction: ingress
  388. protocol: tcp
  389. port_range_min: 443
  390. port_range_max: 443
  391. cns-secgrp:
  392. type: OS::Neutron::SecurityGroup
  393. properties:
  394. name:
  395. str_replace:
  396. template: openshift-ansible-cluster_id-cns-secgrp
  397. params:
  398. cluster_id: {{ openshift_openstack_stack_name }}
  399. description:
  400. str_replace:
  401. template: Security group for cluster_id OpenShift cns cluster nodes
  402. params:
  403. cluster_id: {{ openshift_openstack_stack_name }}
  404. rules:
  405. # glusterfs_sshd
  406. - direction: ingress
  407. protocol: tcp
  408. port_range_min: 2222
  409. port_range_max: 2222
  410. # heketi dialing backends
  411. - direction: ingress
  412. protocol: tcp
  413. port_range_min: 10250
  414. port_range_max: 10250
  415. # glusterfs_management
  416. - direction: ingress
  417. protocol: tcp
  418. port_range_min: 24007
  419. port_range_max: 24007
  420. # glusterfs_rdma
  421. - direction: ingress
  422. protocol: tcp
  423. port_range_min: 24008
  424. port_range_max: 24008
  425. # glusterfs_bricks
  426. - direction: ingress
  427. protocol: tcp
  428. port_range_min: 49152
  429. port_range_max: 49251
  430. {% if openshift_openstack_num_masters|int > 1 %}
  431. lb-secgrp:
  432. type: OS::Neutron::SecurityGroup
  433. properties:
  434. name: openshift-ansible-{{ openshift_openstack_stack_name }}-lb-secgrp
  435. description: Security group for {{ openshift_openstack_stack_name }} cluster Load Balancer
  436. rules:
  437. - direction: ingress
  438. protocol: tcp
  439. port_range_min: {{ openshift_master_api_port | default(8443) }}
  440. port_range_max: {{ openshift_master_api_port | default(8443) }}
  441. remote_ip_prefix: {{ openshift_openstack_lb_ingress_cidr }}
  442. {% if openshift_master_console_port is defined and openshift_master_console_port != openshift_master_api_port %}
  443. - direction: ingress
  444. protocol: tcp
  445. port_range_min: {{ openshift_master_console_port | default(8443) }}
  446. port_range_max: {{ openshift_master_console_port | default(8443) }}
  447. remote_ip_prefix: {{ openshift_openstack_lb_ingress_cidr }}
  448. {% endif %}
  449. {% endif %}
  450. etcd:
  451. type: OS::Heat::ResourceGroup
  452. properties:
  453. count: {{ openshift_openstack_num_etcd }}
  454. resource_def:
  455. type: server.yaml
  456. properties:
  457. name:
  458. str_replace:
  459. template: k8s_type-%index%.cluster_id
  460. params:
  461. cluster_id: {{ openshift_openstack_stack_name }}
  462. k8s_type: {{ openshift_openstack_etcd_hostname }}
  463. cluster_env: {{ openshift_openstack_public_dns_domain }}
  464. cluster_id: {{ openshift_openstack_stack_name }}
  465. group:
  466. str_replace:
  467. template: k8s_type.cluster_id
  468. params:
  469. k8s_type: etcds
  470. cluster_id: {{ openshift_openstack_stack_name }}
  471. type: etcd
  472. image: {{ openshift_openstack_etcd_image }}
  473. flavor: {{ openshift_openstack_etcd_flavor }}
  474. key_name: {{ openshift_openstack_keypair_name }}
  475. {% if openshift_openstack_provider_network_name %}
  476. net: {{ openshift_openstack_provider_network_name }}
  477. net_name: {{ openshift_openstack_provider_network_name }}
  478. {% else %}
  479. net: { get_resource: net }
  480. subnet: { get_resource: subnet }
  481. net_name:
  482. str_replace:
  483. template: openshift-ansible-cluster_id-net
  484. params:
  485. cluster_id: {{ openshift_openstack_stack_name }}
  486. {% endif %}
  487. secgrp:
  488. - { get_resource: {% if openshift_openstack_flat_secgrp|default(False)|bool %}flat-secgrp{% else %}etcd-secgrp{% endif %} }
  489. - { get_resource: common-secgrp }
  490. floating_network:
  491. if:
  492. - no_floating
  493. - null
  494. - {{ openshift_openstack_external_network_name }}
  495. {% if openshift_openstack_provider_network_name %}
  496. attach_float_net: false
  497. {% endif %}
  498. volume_size: {{ openshift_openstack_etcd_volume_size }}
  499. {% if not openshift_openstack_provider_network_name %}
  500. depends_on:
  501. - interface
  502. {% endif %}
  503. {% if openshift_openstack_master_server_group_policies|length > 0 %}
  504. master_server_group:
  505. type: OS::Nova::ServerGroup
  506. properties:
  507. name: master_server_group
  508. policies: {{ openshift_openstack_master_server_group_policies }}
  509. {% endif %}
  510. {% if openshift_openstack_infra_server_group_policies|length > 0 %}
  511. infra_server_group:
  512. type: OS::Nova::ServerGroup
  513. properties:
  514. name: infra_server_group
  515. policies: {{ openshift_openstack_infra_server_group_policies }}
  516. {% endif %}
  517. {% if openshift_openstack_num_masters|int > 1 %}
  518. loadbalancer:
  519. type: OS::Heat::ResourceGroup
  520. properties:
  521. count: 1
  522. resource_def:
  523. type: server.yaml
  524. properties:
  525. name:
  526. str_replace:
  527. template: k8s_type-%index%.cluster_id
  528. params:
  529. cluster_id: {{ openshift_openstack_stack_name }}
  530. k8s_type: {{ openshift_openstack_lb_hostname }}
  531. cluster_env: {{ openshift_openstack_public_dns_domain }}
  532. cluster_id: {{ openshift_openstack_stack_name }}
  533. group:
  534. str_replace:
  535. template: k8s_type.cluster_id
  536. params:
  537. k8s_type: lb
  538. cluster_id: {{ openshift_openstack_stack_name }}
  539. type: lb
  540. image: {{ openshift_openstack_lb_image }}
  541. flavor: {{ openshift_openstack_lb_flavor }}
  542. key_name: {{ openshift_openstack_keypair_name }}
  543. {% if openshift_openstack_provider_network_name %}
  544. net: {{ openshift_openstack_provider_network_name }}
  545. net_name: {{ openshift_openstack_provider_network_name }}
  546. {% else %}
  547. net: { get_resource: net }
  548. subnet: { get_resource: subnet }
  549. net_name:
  550. str_replace:
  551. template: openshift-ansible-cluster_id-net
  552. params:
  553. cluster_id: {{ openshift_openstack_stack_name }}
  554. {% endif %}
  555. secgrp:
  556. - { get_resource: lb-secgrp }
  557. - { get_resource: common-secgrp }
  558. {% if not openshift_openstack_provider_network_name %}
  559. floating_network: {{ openshift_openstack_external_network_name }}
  560. {% endif %}
  561. volume_size: {{ openshift_openstack_lb_volume_size }}
  562. {% if not openshift_openstack_provider_network_name %}
  563. depends_on:
  564. - interface
  565. {% endif %}
  566. {% endif %}
  567. masters:
  568. type: OS::Heat::ResourceGroup
  569. properties:
  570. count: {{ openshift_openstack_num_masters }}
  571. resource_def:
  572. type: server.yaml
  573. properties:
  574. name:
  575. str_replace:
  576. template: k8s_type-%index%.cluster_id
  577. params:
  578. cluster_id: {{ openshift_openstack_stack_name }}
  579. k8s_type: {{ openshift_openstack_master_hostname }}
  580. cluster_env: {{ openshift_openstack_public_dns_domain }}
  581. cluster_id: {{ openshift_openstack_stack_name }}
  582. group:
  583. str_replace:
  584. template: k8s_type.cluster_id
  585. params:
  586. k8s_type: masters
  587. cluster_id: {{ openshift_openstack_stack_name }}
  588. type: master
  589. image: {{ openshift_openstack_master_image }}
  590. flavor: {{ openshift_openstack_master_flavor }}
  591. key_name: {{ openshift_openstack_keypair_name }}
  592. {% if openshift_openstack_provider_network_name %}
  593. net: {{ openshift_openstack_provider_network_name }}
  594. net_name: {{ openshift_openstack_provider_network_name }}
  595. {% else %}
  596. net: { get_resource: net }
  597. subnet: { get_resource: subnet }
  598. net_name:
  599. str_replace:
  600. template: openshift-ansible-cluster_id-net
  601. params:
  602. cluster_id: {{ openshift_openstack_stack_name }}
  603. {% if openshift_use_flannel|default(False)|bool %}
  604. attach_data_net: true
  605. data_net: { get_resource: data_net }
  606. data_subnet: { get_resource: data_subnet }
  607. {% endif %}
  608. {% endif %}
  609. secgrp:
  610. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  611. - { get_resource: flat-secgrp }
  612. {% else %}
  613. - { get_resource: master-secgrp }
  614. - { get_resource: node-secgrp }
  615. {% if openshift_openstack_num_etcd|int == 0 %}
  616. - { get_resource: etcd-secgrp }
  617. {% endif %}
  618. {% endif %}
  619. - { get_resource: common-secgrp }
  620. floating_network:
  621. if:
  622. - no_floating
  623. - null
  624. - {{ openshift_openstack_external_network_name }}
  625. {% if openshift_openstack_provider_network_name %}
  626. attach_float_net: false
  627. {% endif %}
  628. volume_size: {{ openshift_openstack_master_volume_size }}
  629. {% if openshift_openstack_master_server_group_policies|length > 0 %}
  630. scheduler_hints:
  631. group: { get_resource: master_server_group }
  632. {% endif %}
  633. {% if not openshift_openstack_provider_network_name %}
  634. depends_on:
  635. - interface
  636. {% endif %}
  637. compute_nodes:
  638. type: OS::Heat::ResourceGroup
  639. properties:
  640. count: {{ openshift_openstack_num_nodes }}
  641. removal_policies:
  642. - resource_list: {{ openshift_openstack_nodes_to_remove }}
  643. resource_def:
  644. type: server.yaml
  645. properties:
  646. name:
  647. str_replace:
  648. template: sub_type_k8s_type-%index%.cluster_id
  649. params:
  650. cluster_id: {{ openshift_openstack_stack_name }}
  651. sub_type_k8s_type: {{ openshift_openstack_node_hostname }}
  652. cluster_env: {{ openshift_openstack_public_dns_domain }}
  653. cluster_id: {{ openshift_openstack_stack_name }}
  654. group:
  655. str_replace:
  656. template: k8s_type.cluster_id
  657. params:
  658. k8s_type: nodes
  659. cluster_id: {{ openshift_openstack_stack_name }}
  660. type: node
  661. subtype: app
  662. node_labels:
  663. {% for k, v in openshift_openstack_cluster_node_labels.app.items() %}
  664. {{ k|e }}: {{ v|e }}
  665. {% endfor %}
  666. image: {{ openshift_openstack_node_image }}
  667. flavor: {{ openshift_openstack_node_flavor }}
  668. key_name: {{ openshift_openstack_keypair_name }}
  669. {% if openshift_openstack_provider_network_name %}
  670. net: {{ openshift_openstack_provider_network_name }}
  671. net_name: {{ openshift_openstack_provider_network_name }}
  672. {% else %}
  673. net: { get_resource: net }
  674. subnet: { get_resource: subnet }
  675. net_name:
  676. str_replace:
  677. template: openshift-ansible-cluster_id-net
  678. params:
  679. cluster_id: {{ openshift_openstack_stack_name }}
  680. {% if openshift_use_flannel|default(False)|bool %}
  681. attach_data_net: true
  682. data_net: { get_resource: data_net }
  683. data_subnet: { get_resource: data_subnet }
  684. {% endif %}
  685. {% endif %}
  686. secgrp:
  687. - { get_resource: {% if openshift_openstack_flat_secgrp|default(False)|bool %}flat-secgrp{% else %}node-secgrp{% endif %} }
  688. - { get_resource: common-secgrp }
  689. floating_network:
  690. if:
  691. - no_floating
  692. - null
  693. - {{ openshift_openstack_external_network_name }}
  694. {% if openshift_openstack_provider_network_name %}
  695. attach_float_net: false
  696. {% endif %}
  697. volume_size: {{ openshift_openstack_node_volume_size }}
  698. {% if not openshift_openstack_provider_network_name %}
  699. depends_on:
  700. - interface
  701. {% endif %}
  702. infra_nodes:
  703. type: OS::Heat::ResourceGroup
  704. properties:
  705. count: {{ openshift_openstack_num_infra }}
  706. resource_def:
  707. type: server.yaml
  708. properties:
  709. name:
  710. str_replace:
  711. template: sub_type_k8s_type-%index%.cluster_id
  712. params:
  713. cluster_id: {{ openshift_openstack_stack_name }}
  714. sub_type_k8s_type: {{ openshift_openstack_infra_hostname }}
  715. cluster_env: {{ openshift_openstack_public_dns_domain }}
  716. cluster_id: {{ openshift_openstack_stack_name }}
  717. group:
  718. str_replace:
  719. template: k8s_type.cluster_id
  720. params:
  721. k8s_type: infra
  722. cluster_id: {{ openshift_openstack_stack_name }}
  723. type: node
  724. subtype: infra
  725. node_labels:
  726. {% for k, v in openshift_openstack_cluster_node_labels.infra.items() %}
  727. {{ k|e }}: {{ v|e }}
  728. {% endfor %}
  729. image: {{ openshift_openstack_infra_image }}
  730. flavor: {{ openshift_openstack_infra_flavor }}
  731. key_name: {{ openshift_openstack_keypair_name }}
  732. {% if openshift_openstack_provider_network_name %}
  733. net: {{ openshift_openstack_provider_network_name }}
  734. net_name: {{ openshift_openstack_provider_network_name }}
  735. {% else %}
  736. net: { get_resource: net }
  737. subnet: { get_resource: subnet }
  738. net_name:
  739. str_replace:
  740. template: openshift-ansible-cluster_id-net
  741. params:
  742. cluster_id: {{ openshift_openstack_stack_name }}
  743. {% if openshift_use_flannel|default(False)|bool %}
  744. attach_data_net: true
  745. data_net: { get_resource: data_net }
  746. data_subnet: { get_resource: data_subnet }
  747. {% endif %}
  748. {% endif %}
  749. secgrp:
  750. # TODO(bogdando) filter only required node rules into infra-secgrp
  751. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  752. - { get_resource: flat-secgrp }
  753. {% else %}
  754. - { get_resource: node-secgrp }
  755. {% endif %}
  756. - { get_resource: infra-secgrp }
  757. - { get_resource: common-secgrp }
  758. {% if not openshift_openstack_provider_network_name %}
  759. floating_network: {{ openshift_openstack_external_network_name }}
  760. {% endif %}
  761. volume_size: {{ openshift_openstack_infra_volume_size }}
  762. {% if openshift_openstack_infra_server_group_policies|length > 0 %}
  763. scheduler_hints:
  764. group: { get_resource: infra_server_group }
  765. {% endif %}
  766. {% if not openshift_openstack_provider_network_name %}
  767. depends_on:
  768. - interface
  769. {% endif %}
  770. cns:
  771. type: OS::Heat::ResourceGroup
  772. properties:
  773. count: {{ openshift_openstack_num_cns }}
  774. resource_def:
  775. type: server.yaml
  776. properties:
  777. name:
  778. str_replace:
  779. template: sub_type_k8s_type-%index%.cluster_id
  780. params:
  781. cluster_id: {{ openshift_openstack_stack_name }}
  782. sub_type_k8s_type: {{ openshift_openstack_cns_hostname }}
  783. cluster_env: {{ openshift_openstack_public_dns_domain }}
  784. cluster_id: {{ openshift_openstack_stack_name }}
  785. group:
  786. str_replace:
  787. template: k8s_type.cluster_id
  788. params:
  789. k8s_type: cns
  790. cluster_id: {{ openshift_openstack_stack_name }}
  791. type: cns
  792. image: {{ openshift_openstack_cns_image }}
  793. flavor: {{ openshift_openstack_cns_flavor }}
  794. key_name: {{ openshift_openstack_keypair_name }}
  795. {% if openshift_openstack_provider_network_name %}
  796. net: {{ openshift_openstack_provider_network_name }}
  797. net_name: {{ openshift_openstack_provider_network_name }}
  798. {% else %}
  799. net: { get_resource: net }
  800. subnet: { get_resource: subnet }
  801. net_name:
  802. str_replace:
  803. template: openshift-ansible-cluster_id-net
  804. params:
  805. cluster_id: {{ openshift_openstack_stack_name }}
  806. {% if openshift_use_flannel|default(False)|bool %}
  807. attach_data_net: true
  808. data_net: { get_resource: data_net }
  809. data_subnet: { get_resource: data_subnet }
  810. {% endif %}
  811. {% endif %}
  812. secgrp:
  813. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  814. - { get_resource: flat-secgrp }
  815. {% else %}
  816. - { get_resource: node-secgrp }
  817. {% endif %}
  818. - { get_resource: cns-secgrp }
  819. - { get_resource: common-secgrp }
  820. {% if not openshift_openstack_provider_network_name %}
  821. floating_network: {{ openshift_openstack_external_network_name }}
  822. {% endif %}
  823. volume_size: {{ openshift_openstack_cns_volume_size }}