main.yml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. ---
  2. openshift_aws_create_s3: True
  3. openshift_aws_create_iam_cert: True
  4. openshift_aws_create_iam_role: False
  5. openshift_aws_create_security_groups: True
  6. openshift_aws_create_launch_config: True
  7. openshift_aws_create_scale_group: True
  8. openshift_aws_node_group_upgrade: False
  9. openshift_aws_wait_for_ssh: True
  10. openshift_aws_clusterid: default
  11. openshift_aws_region: us-east-1
  12. openshift_aws_vpc_name: "{{ openshift_aws_clusterid }}"
  13. openshift_aws_build_ami_group: "{{ openshift_aws_clusterid }}"
  14. openshift_aws_iam_cert_name: "{{ openshift_aws_clusterid }}-master-external"
  15. openshift_aws_iam_cert_path: ''
  16. openshift_aws_iam_cert_key_path: ''
  17. openshift_aws_iam_role_name: openshift_node_describe_instances
  18. openshift_aws_iam_role_policy_json: "{{ lookup('file', 'describeinstances.json') }}"
  19. openshift_aws_iam_role_policy_name: "describe_instances"
  20. openshift_aws_iam_kms_alias: "alias/{{ openshift_aws_clusterid }}_kms"
  21. openshift_aws_ami: ''
  22. openshift_aws_ami_copy_wait: False
  23. openshift_aws_ami_encrypt: False
  24. openshift_aws_ami_copy_src_region: "{{ openshift_aws_region }}"
  25. openshift_aws_ami_name: openshift-gi
  26. openshift_aws_base_ami_name: ami_base
  27. openshift_aws_launch_config_bootstrap_token: ''
  28. openshift_aws_users: []
  29. openshift_aws_ami_tags:
  30. bootstrap: "true"
  31. openshift-created: "true"
  32. parent: "{{ openshift_aws_base_ami | default('unknown') }}"
  33. openshift_aws_s3_mode: create
  34. openshift_aws_s3_bucket_name: "{{ openshift_aws_clusterid }}-docker-registry"
  35. openshift_aws_elb_basename: "{{ openshift_aws_clusterid }}"
  36. openshift_aws_elb_cert_arn: ''
  37. openshift_aws_elb_dict:
  38. master:
  39. external:
  40. cross_az_load_balancing: False
  41. health_check:
  42. ping_protocol: tcp
  43. ping_port: "{{ openshift_master_api_port | default(8443) }}"
  44. response_timeout: 5
  45. interval: 30
  46. unhealthy_threshold: 2
  47. healthy_threshold: 2
  48. idle_timout: 400
  49. listeners:
  50. - protocol: tcp
  51. load_balancer_port: 80
  52. instance_protocol: ssl
  53. instance_port: "{{ openshift_master_api_port | default(8443) }}"
  54. - protocol: ssl
  55. load_balancer_port: "{{ openshift_master_api_port | default(8443) }}"
  56. instance_protocol: ssl
  57. instance_port: "{{ openshift_master_api_port | default(8443) }}"
  58. ssl_certificate_id: "{{ openshift_aws_elb_cert_arn }}"
  59. name: "{{ openshift_aws_elb_basename }}-master-external"
  60. tags: "{{ openshift_aws_kube_tags }}"
  61. internal:
  62. cross_az_load_balancing: False
  63. health_check:
  64. ping_protocol: tcp
  65. ping_port: "{{ openshift_master_api_port | default(8443) }}"
  66. response_timeout: 5
  67. interval: 30
  68. unhealthy_threshold: 2
  69. healthy_threshold: 2
  70. idle_timout: 400
  71. listeners:
  72. - protocol: tcp
  73. load_balancer_port: 80
  74. instance_protocol: tcp
  75. instance_port: 80
  76. - protocol: tcp
  77. load_balancer_port: "{{ openshift_master_api_port | default(8443) }}"
  78. instance_protocol: tcp
  79. instance_port: "{{ openshift_master_api_port | default(8443) }}"
  80. name: "{{ openshift_aws_elb_basename }}-master-internal"
  81. tags: "{{ openshift_aws_kube_tags }}"
  82. infra:
  83. external:
  84. cross_az_load_balancing: False
  85. health_check:
  86. ping_protocol: tcp
  87. ping_port: 443
  88. response_timeout: 5
  89. interval: 30
  90. unhealthy_threshold: 2
  91. healthy_threshold: 2
  92. idle_timout: 400
  93. listeners:
  94. - protocol: tcp
  95. load_balancer_port: 80
  96. instance_protocol: tcp
  97. instance_port: 443
  98. proxy_protocol: True
  99. - protocol: tcp
  100. load_balancer_port: 443
  101. instance_protocol: tcp
  102. instance_port: 443
  103. proxy_protocol: True
  104. name: "{{ openshift_aws_elb_basename }}-infra"
  105. tags: "{{ openshift_aws_kube_tags }}"
  106. openshift_aws_node_group_config_master_volumes:
  107. - device_name: /dev/sda1
  108. volume_size: 100
  109. device_type: gp2
  110. delete_on_termination: False
  111. - device_name: /dev/sdb
  112. volume_size: 100
  113. device_type: gp2
  114. delete_on_termination: False
  115. openshift_aws_node_group_config_node_volumes:
  116. - device_name: /dev/sda1
  117. volume_size: 100
  118. device_type: gp2
  119. delete_on_termination: True
  120. - device_name: /dev/sdb
  121. volume_size: 100
  122. device_type: gp2
  123. delete_on_termination: True
  124. # build_instance_tags is a custom filter in role lib_utils
  125. openshift_aws_node_group_config_tags: "{{ openshift_aws_clusterid | build_instance_tags }}"
  126. openshift_aws_node_group_termination_policy: Default
  127. openshift_aws_node_group_replace_instances: []
  128. openshift_aws_node_group_replace_all_instances: False
  129. openshift_aws_ami_map:
  130. master: "{{ openshift_aws_ami }}"
  131. infra: "{{ openshift_aws_ami }}"
  132. compute: "{{ openshift_aws_ami }}"
  133. openshift_aws_master_group:
  134. - name: "{{ openshift_aws_clusterid }} master group"
  135. group: master
  136. tags:
  137. host-type: master
  138. sub-host-type: default
  139. runtime: docker
  140. openshift_aws_node_groups:
  141. - name: "{{ openshift_aws_clusterid }} compute group"
  142. group: compute
  143. tags:
  144. host-type: node
  145. sub-host-type: compute
  146. runtime: docker
  147. - name: "{{ openshift_aws_clusterid }} infra group"
  148. group: infra
  149. tags:
  150. host-type: node
  151. sub-host-type: infra
  152. runtime: docker
  153. openshift_aws_created_asgs: []
  154. openshift_aws_current_asgs: []
  155. # these will be used during upgrade
  156. openshift_aws_master_group_config:
  157. # The 'master' key is always required here.
  158. master:
  159. instance_type: m4.xlarge
  160. volumes: "{{ openshift_aws_node_group_config_master_volumes }}"
  161. health_check:
  162. period: 60
  163. type: EC2
  164. min_size: 3
  165. max_size: 3
  166. desired_size: 3
  167. wait_for_instances: True
  168. termination_policy: "{{ openshift_aws_node_group_termination_policy }}"
  169. replace_all_instances: "{{ openshift_aws_node_group_replace_all_instances }}"
  170. iam_role: "{{ openshift_aws_iam_role_name }}"
  171. policy_name: "{{ openshift_aws_iam_role_policy_name }}"
  172. policy_json: "{{ openshift_aws_iam_role_policy_json }}"
  173. elbs: "{{ openshift_aws_elb_dict | json_query('master.[*][0][*].name') }}"
  174. openshift_aws_node_group_config:
  175. # The 'compute' key is always required here.
  176. compute:
  177. instance_type: m4.xlarge
  178. volumes: "{{ openshift_aws_node_group_config_node_volumes }}"
  179. health_check:
  180. period: 60
  181. type: EC2
  182. min_size: 3
  183. max_size: 100
  184. desired_size: 3
  185. termination_policy: "{{ openshift_aws_node_group_termination_policy }}"
  186. replace_all_instances: "{{ openshift_aws_node_group_replace_all_instances }}"
  187. iam_role: "{{ openshift_aws_iam_role_name }}"
  188. policy_name: "{{ openshift_aws_iam_role_policy_name }}"
  189. policy_json: "{{ openshift_aws_iam_role_policy_json }}"
  190. # The 'infra' key is always required here.
  191. infra:
  192. instance_type: m4.xlarge
  193. volumes: "{{ openshift_aws_node_group_config_node_volumes }}"
  194. health_check:
  195. period: 60
  196. type: EC2
  197. min_size: 2
  198. max_size: 20
  199. desired_size: 2
  200. termination_policy: "{{ openshift_aws_node_group_termination_policy }}"
  201. replace_all_instances: "{{ openshift_aws_node_group_replace_all_instances }}"
  202. iam_role: "{{ openshift_aws_iam_role_name }}"
  203. policy_name: "{{ openshift_aws_iam_role_policy_name }}"
  204. policy_json: "{{ openshift_aws_iam_role_policy_json }}"
  205. elbs: "{{ openshift_aws_elb_dict | json_query('infra.[*][0][*].name') }}"
  206. # build_instance_tags is a custom filter in role lib_utils
  207. openshift_aws_kube_tags: "{{ openshift_aws_clusterid | build_instance_tags }}"
  208. openshift_aws_elb_security_groups: "{{ openshift_aws_launch_config_security_groups }}"
  209. openshift_aws_launch_config_security_groups:
  210. compute:
  211. - "{{ openshift_aws_clusterid }}" # default sg
  212. - "{{ openshift_aws_clusterid }}_compute" # node type sg
  213. - "{{ openshift_aws_clusterid }}_compute_k8s" # node type sg k8s
  214. infra:
  215. - "{{ openshift_aws_clusterid }}" # default sg
  216. - "{{ openshift_aws_clusterid }}_infra" # node type sg
  217. - "{{ openshift_aws_clusterid }}_infra_k8s" # node type sg k8s
  218. master:
  219. - "{{ openshift_aws_clusterid }}" # default sg
  220. - "{{ openshift_aws_clusterid }}_master" # node type sg
  221. - "{{ openshift_aws_clusterid }}_master_k8s" # node type sg k8s
  222. openshift_aws_security_groups_tags: "{{ openshift_aws_kube_tags }}"
  223. openshift_aws_node_security_groups:
  224. default:
  225. name: "{{ openshift_aws_clusterid }}"
  226. desc: "{{ openshift_aws_clusterid }} default"
  227. rules:
  228. - proto: tcp
  229. from_port: 22
  230. to_port: 22
  231. cidr_ip: 0.0.0.0/0
  232. - proto: all
  233. from_port: all
  234. to_port: all
  235. group_name: "{{ openshift_aws_clusterid }}"
  236. master:
  237. name: "{{ openshift_aws_clusterid }}_master"
  238. desc: "{{ openshift_aws_clusterid }} master instances"
  239. rules:
  240. - proto: tcp
  241. from_port: 80
  242. to_port: 80
  243. cidr_ip: 0.0.0.0/0
  244. - proto: tcp
  245. from_port: "{{ openshift_master_api_port | default(8443) }}"
  246. to_port: "{{ openshift_master_api_port | default(8443) }}"
  247. cidr_ip: 0.0.0.0/0
  248. compute:
  249. name: "{{ openshift_aws_clusterid }}_compute"
  250. desc: "{{ openshift_aws_clusterid }} compute node instances"
  251. infra:
  252. name: "{{ openshift_aws_clusterid }}_infra"
  253. desc: "{{ openshift_aws_clusterid }} infra node instances"
  254. rules:
  255. - proto: tcp
  256. from_port: 80
  257. to_port: 80
  258. cidr_ip: 0.0.0.0/0
  259. - proto: tcp
  260. from_port: "{{ openshift_master_api_port | default(8443) }}"
  261. to_port: "{{ openshift_master_api_port | default(8443) }}"
  262. cidr_ip: 0.0.0.0/0
  263. - proto: tcp
  264. from_port: 30000
  265. to_port: 32000
  266. cidr_ip: 0.0.0.0/0
  267. etcd:
  268. name: "{{ openshift_aws_clusterid }}_etcd"
  269. desc: "{{ openshift_aws_clusterid }} etcd instances"
  270. openshift_aws_vpc_tags:
  271. Name: "{{ openshift_aws_vpc_name }}"
  272. openshift_aws_vpc:
  273. name: "{{ openshift_aws_vpc_name }}"
  274. cidr: 172.31.0.0/16
  275. subnets:
  276. us-east-1:
  277. - cidr: 172.31.48.0/20
  278. az: "us-east-1c"
  279. default_az: true
  280. - cidr: 172.31.32.0/20
  281. az: "us-east-1e"
  282. - cidr: 172.31.16.0/20
  283. az: "us-east-1a"
  284. openshift_aws_subnet_az: "{{ openshift_aws_vpc.subnets[openshift_aws_region] | get_default_az }}"
  285. openshift_aws_node_run_bootstrap_startup: True
  286. openshift_aws_node_user_data: ''
  287. openshift_aws_node_config_namespace: openshift-node
  288. openshift_aws_masters_groups: masters,etcd,nodes
  289. # By default, don't delete things like the shared IAM instance
  290. # profile and uploaded ssh keys
  291. openshift_aws_enable_uninstall_shared_objects: False