heat_stack.yaml.j2 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  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. - ''
  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. floating_network:
  559. if:
  560. - no_floating
  561. - ''
  562. - {{ openshift_openstack_external_network_name }}
  563. {% if openshift_openstack_provider_network_name %}
  564. attach_float_net: false
  565. {% endif %}
  566. volume_size: {{ openshift_openstack_lb_volume_size }}
  567. {% if not openshift_openstack_provider_network_name %}
  568. depends_on:
  569. - interface
  570. {% endif %}
  571. {% endif %}
  572. masters:
  573. type: OS::Heat::ResourceGroup
  574. properties:
  575. count: {{ openshift_openstack_num_masters }}
  576. resource_def:
  577. type: server.yaml
  578. properties:
  579. name:
  580. str_replace:
  581. template: k8s_type-%index%.cluster_id
  582. params:
  583. cluster_id: {{ openshift_openstack_stack_name }}
  584. k8s_type: {{ openshift_openstack_master_hostname }}
  585. cluster_env: {{ openshift_openstack_public_dns_domain }}
  586. cluster_id: {{ openshift_openstack_stack_name }}
  587. group:
  588. str_replace:
  589. template: k8s_type.cluster_id
  590. params:
  591. k8s_type: masters
  592. cluster_id: {{ openshift_openstack_stack_name }}
  593. type: master
  594. image: {{ openshift_openstack_master_image }}
  595. flavor: {{ openshift_openstack_master_flavor }}
  596. key_name: {{ openshift_openstack_keypair_name }}
  597. {% if openshift_openstack_provider_network_name %}
  598. net: {{ openshift_openstack_provider_network_name }}
  599. net_name: {{ openshift_openstack_provider_network_name }}
  600. {% else %}
  601. net: { get_resource: net }
  602. subnet: { get_resource: subnet }
  603. net_name:
  604. str_replace:
  605. template: openshift-ansible-cluster_id-net
  606. params:
  607. cluster_id: {{ openshift_openstack_stack_name }}
  608. {% if openshift_use_flannel|default(False)|bool %}
  609. attach_data_net: true
  610. data_net: { get_resource: data_net }
  611. data_subnet: { get_resource: data_subnet }
  612. {% endif %}
  613. {% endif %}
  614. secgrp:
  615. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  616. - { get_resource: flat-secgrp }
  617. {% else %}
  618. - { get_resource: master-secgrp }
  619. - { get_resource: node-secgrp }
  620. {% if openshift_openstack_num_etcd|int == 0 %}
  621. - { get_resource: etcd-secgrp }
  622. {% endif %}
  623. {% endif %}
  624. - { get_resource: common-secgrp }
  625. floating_network:
  626. if:
  627. - no_floating
  628. - ''
  629. - {{ openshift_openstack_external_network_name }}
  630. {% if openshift_openstack_provider_network_name %}
  631. attach_float_net: false
  632. {% endif %}
  633. volume_size: {{ openshift_openstack_master_volume_size }}
  634. {% if openshift_openstack_master_server_group_policies|length > 0 %}
  635. scheduler_hints:
  636. group: { get_resource: master_server_group }
  637. {% endif %}
  638. {% if not openshift_openstack_provider_network_name %}
  639. depends_on:
  640. - interface
  641. {% endif %}
  642. compute_nodes:
  643. type: OS::Heat::ResourceGroup
  644. properties:
  645. count: {{ openshift_openstack_num_nodes }}
  646. removal_policies:
  647. - resource_list: {{ openshift_openstack_nodes_to_remove }}
  648. resource_def:
  649. type: server.yaml
  650. properties:
  651. name:
  652. str_replace:
  653. template: sub_type_k8s_type-%index%.cluster_id
  654. params:
  655. cluster_id: {{ openshift_openstack_stack_name }}
  656. sub_type_k8s_type: {{ openshift_openstack_node_hostname }}
  657. cluster_env: {{ openshift_openstack_public_dns_domain }}
  658. cluster_id: {{ openshift_openstack_stack_name }}
  659. group:
  660. str_replace:
  661. template: k8s_type.cluster_id
  662. params:
  663. k8s_type: nodes
  664. cluster_id: {{ openshift_openstack_stack_name }}
  665. type: node
  666. subtype: app
  667. node_labels:
  668. {% for k, v in openshift_openstack_cluster_node_labels.app.items() %}
  669. {{ k|e }}: {{ v|e }}
  670. {% endfor %}
  671. image: {{ openshift_openstack_node_image }}
  672. flavor: {{ openshift_openstack_node_flavor }}
  673. key_name: {{ openshift_openstack_keypair_name }}
  674. {% if openshift_openstack_provider_network_name %}
  675. net: {{ openshift_openstack_provider_network_name }}
  676. net_name: {{ openshift_openstack_provider_network_name }}
  677. {% else %}
  678. net: { get_resource: net }
  679. subnet: { get_resource: subnet }
  680. net_name:
  681. str_replace:
  682. template: openshift-ansible-cluster_id-net
  683. params:
  684. cluster_id: {{ openshift_openstack_stack_name }}
  685. {% if openshift_use_flannel|default(False)|bool %}
  686. attach_data_net: true
  687. data_net: { get_resource: data_net }
  688. data_subnet: { get_resource: data_subnet }
  689. {% endif %}
  690. {% endif %}
  691. secgrp:
  692. - { get_resource: {% if openshift_openstack_flat_secgrp|default(False)|bool %}flat-secgrp{% else %}node-secgrp{% endif %} }
  693. - { get_resource: common-secgrp }
  694. floating_network:
  695. if:
  696. - no_floating
  697. - ''
  698. - {{ openshift_openstack_external_network_name }}
  699. {% if openshift_openstack_provider_network_name %}
  700. attach_float_net: false
  701. {% endif %}
  702. volume_size: {{ openshift_openstack_node_volume_size }}
  703. {% if not openshift_openstack_provider_network_name %}
  704. depends_on:
  705. - interface
  706. {% endif %}
  707. infra_nodes:
  708. type: OS::Heat::ResourceGroup
  709. properties:
  710. count: {{ openshift_openstack_num_infra }}
  711. resource_def:
  712. type: server.yaml
  713. properties:
  714. name:
  715. str_replace:
  716. template: sub_type_k8s_type-%index%.cluster_id
  717. params:
  718. cluster_id: {{ openshift_openstack_stack_name }}
  719. sub_type_k8s_type: {{ openshift_openstack_infra_hostname }}
  720. cluster_env: {{ openshift_openstack_public_dns_domain }}
  721. cluster_id: {{ openshift_openstack_stack_name }}
  722. group:
  723. str_replace:
  724. template: k8s_type.cluster_id
  725. params:
  726. k8s_type: infra
  727. cluster_id: {{ openshift_openstack_stack_name }}
  728. type: node
  729. subtype: infra
  730. node_labels:
  731. {% for k, v in openshift_openstack_cluster_node_labels.infra.items() %}
  732. {{ k|e }}: {{ v|e }}
  733. {% endfor %}
  734. image: {{ openshift_openstack_infra_image }}
  735. flavor: {{ openshift_openstack_infra_flavor }}
  736. key_name: {{ openshift_openstack_keypair_name }}
  737. {% if openshift_openstack_provider_network_name %}
  738. net: {{ openshift_openstack_provider_network_name }}
  739. net_name: {{ openshift_openstack_provider_network_name }}
  740. {% else %}
  741. net: { get_resource: net }
  742. subnet: { get_resource: subnet }
  743. net_name:
  744. str_replace:
  745. template: openshift-ansible-cluster_id-net
  746. params:
  747. cluster_id: {{ openshift_openstack_stack_name }}
  748. {% if openshift_use_flannel|default(False)|bool %}
  749. attach_data_net: true
  750. data_net: { get_resource: data_net }
  751. data_subnet: { get_resource: data_subnet }
  752. {% endif %}
  753. {% endif %}
  754. secgrp:
  755. # TODO(bogdando) filter only required node rules into infra-secgrp
  756. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  757. - { get_resource: flat-secgrp }
  758. {% else %}
  759. - { get_resource: node-secgrp }
  760. {% endif %}
  761. - { get_resource: infra-secgrp }
  762. - { get_resource: common-secgrp }
  763. floating_network:
  764. if:
  765. - no_floating
  766. - ''
  767. - {{ openshift_openstack_external_network_name }}
  768. {% if openshift_openstack_provider_network_name %}
  769. attach_float_net: false
  770. {% endif %}
  771. volume_size: {{ openshift_openstack_infra_volume_size }}
  772. {% if openshift_openstack_infra_server_group_policies|length > 0 %}
  773. scheduler_hints:
  774. group: { get_resource: infra_server_group }
  775. {% endif %}
  776. {% if not openshift_openstack_provider_network_name %}
  777. depends_on:
  778. - interface
  779. {% endif %}
  780. cns:
  781. type: OS::Heat::ResourceGroup
  782. properties:
  783. count: {{ openshift_openstack_num_cns }}
  784. resource_def:
  785. type: server.yaml
  786. properties:
  787. name:
  788. str_replace:
  789. template: sub_type_k8s_type-%index%.cluster_id
  790. params:
  791. cluster_id: {{ openshift_openstack_stack_name }}
  792. sub_type_k8s_type: {{ openshift_openstack_cns_hostname }}
  793. cluster_env: {{ openshift_openstack_public_dns_domain }}
  794. cluster_id: {{ openshift_openstack_stack_name }}
  795. group:
  796. str_replace:
  797. template: k8s_type.cluster_id
  798. params:
  799. k8s_type: cns
  800. cluster_id: {{ openshift_openstack_stack_name }}
  801. type: cns
  802. image: {{ openshift_openstack_cns_image }}
  803. flavor: {{ openshift_openstack_cns_flavor }}
  804. key_name: {{ openshift_openstack_keypair_name }}
  805. {% if openshift_openstack_provider_network_name %}
  806. net: {{ openshift_openstack_provider_network_name }}
  807. net_name: {{ openshift_openstack_provider_network_name }}
  808. {% else %}
  809. net: { get_resource: net }
  810. subnet: { get_resource: subnet }
  811. net_name:
  812. str_replace:
  813. template: openshift-ansible-cluster_id-net
  814. params:
  815. cluster_id: {{ openshift_openstack_stack_name }}
  816. {% if openshift_use_flannel|default(False)|bool %}
  817. attach_data_net: true
  818. data_net: { get_resource: data_net }
  819. data_subnet: { get_resource: data_subnet }
  820. {% endif %}
  821. {% endif %}
  822. secgrp:
  823. {% if openshift_openstack_flat_secgrp|default(False)|bool %}
  824. - { get_resource: flat-secgrp }
  825. {% else %}
  826. - { get_resource: node-secgrp }
  827. {% endif %}
  828. - { get_resource: cns-secgrp }
  829. - { get_resource: common-secgrp }
  830. {% if not openshift_openstack_provider_network_name %}
  831. floating_network: {{ openshift_openstack_external_network_name }}
  832. {% endif %}
  833. volume_size: {{ openshift_openstack_cns_volume_size }}