config.yml 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. ---
  2. - name: Master Install Checkpoint Start
  3. hosts: all
  4. gather_facts: false
  5. tasks:
  6. - name: Set Master install 'In Progress'
  7. run_once: true
  8. set_stats:
  9. data:
  10. installer_phase_master:
  11. status: "In Progress"
  12. start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
  13. - import_playbook: certificates.yml
  14. - name: Disable excluders and gather facts
  15. hosts: oo_masters_to_config
  16. roles:
  17. - openshift_facts
  18. tasks:
  19. - name: Disable excluders
  20. import_role:
  21. name: openshift_excluder
  22. vars:
  23. r_openshift_excluder_action: disable
  24. - name: Check for RPM generated config marker file .config_managed
  25. stat:
  26. path: /etc/origin/.config_managed
  27. register: rpmgenerated_config
  28. - name: Remove RPM generated config files if present
  29. file:
  30. path: "/etc/origin/{{ item }}"
  31. state: absent
  32. when:
  33. - rpmgenerated_config.stat.exists == true
  34. - openshift_deployment_type == 'openshift-enterprise'
  35. with_items:
  36. - master
  37. - node
  38. - .config_managed
  39. - openshift_facts:
  40. role: master
  41. local_facts:
  42. api_port: "{{ openshift_master_api_port }}"
  43. api_url: "{{ openshift_master_api_url | default(None) }}"
  44. api_use_ssl: "{{ openshift_master_api_use_ssl | default(None) }}"
  45. controllers_port: "{{ openshift_master_controllers_port | default(None) }}"
  46. public_api_url: "{{ openshift_master_public_api_url | default(None) }}"
  47. cluster_hostname: "{{ openshift_master_cluster_hostname | default(None) }}"
  48. cluster_public_hostname: "{{ openshift_master_cluster_public_hostname | default(None) }}"
  49. console_path: "{{ openshift_master_console_path | default(None) }}"
  50. console_port: "{{ openshift_master_console_port | default(None) }}"
  51. console_url: "{{ openshift_master_console_url | default(None) }}"
  52. console_use_ssl: "{{ openshift_master_console_use_ssl | default(None) }}"
  53. public_console_url: "{{ openshift_master_public_console_url | default(None) }}"
  54. - openshift_facts:
  55. role: node
  56. local_facts:
  57. bootstrapped: true
  58. - name: Generate or retrieve existing session secrets
  59. hosts: oo_first_master
  60. roles:
  61. - role: openshift_facts
  62. tasks:
  63. - import_role:
  64. name: openshift_control_plane
  65. tasks_from: generate_session_secrets.yml
  66. - name: Configure masters
  67. hosts: oo_masters_to_config
  68. any_errors_fatal: true
  69. pre_tasks:
  70. - name: Prepare the bootstrap node config on masters for self-hosting
  71. import_role:
  72. name: openshift_node_group
  73. tasks_from: bootstrap
  74. - name: Have the masters automatically pull their configuration
  75. import_role:
  76. name: openshift_node_group
  77. tasks_from: bootstrap_config
  78. vars:
  79. r_node_dynamic_config_name: "{{ openshift_node_group_name | default('node-config-master') }}"
  80. r_node_dynamic_config_force: True
  81. roles:
  82. - role: openshift_master_facts
  83. - role: openshift_cloud_provider
  84. when: openshift_cloudprovider_kind is defined
  85. - role: openshift_builddefaults
  86. - role: openshift_buildoverrides
  87. - role: nickhammond.logrotate
  88. - role: openshift_control_plane
  89. - role: tuned
  90. - role: nuage_ca
  91. when: openshift_use_nuage | default(false) | bool
  92. - role: nuage_common
  93. when: openshift_use_nuage | default(false) | bool
  94. - role: nuage_master
  95. when: openshift_use_nuage | default(false) | bool
  96. - role: calico_master
  97. when: openshift_use_calico | default(false) | bool
  98. tasks:
  99. - name: Set up automatic node config reconcilation
  100. run_once: True
  101. import_role:
  102. name: openshift_node_group
  103. tasks_from: sync
  104. - import_role:
  105. name: kuryr
  106. tasks_from: master
  107. when: openshift_use_kuryr | default(false) | bool
  108. - name: setup bootstrap settings
  109. import_tasks: tasks/enable_bootstrap.yml
  110. post_tasks:
  111. - name: Create group for deployment type
  112. group_by: key=oo_masters_deployment_type_{{ openshift_deployment_type }}
  113. changed_when: False
  114. - name: Re-enable excluders
  115. import_role:
  116. name: openshift_excluder
  117. vars:
  118. r_openshift_excluder_action: enable
  119. - name: Deploy the central bootstrap configuration
  120. hosts: oo_first_master
  121. gather_facts: no
  122. tasks:
  123. - name: setup bootstrap settings
  124. import_tasks: tasks/enable_bootstrap_config.yml
  125. - name: Ensure inventory labels are assigned to masters
  126. hosts: oo_masters_to_config
  127. gather_facts: no
  128. roles:
  129. - role: openshift_manage_node
  130. openshift_master_host: "{{ groups.oo_first_master.0 }}"
  131. openshift_manage_node_is_master: "{{ ('oo_masters_to_config' in group_names) | bool }}"
  132. openshift_node_master_api_url: "{{ hostvars[groups.oo_first_master.0].openshift.master.api_url }}"
  133. - name: Master Install Checkpoint End
  134. hosts: all
  135. gather_facts: false
  136. tasks:
  137. - name: Set Master install 'Complete'
  138. run_once: true
  139. set_stats:
  140. data:
  141. installer_phase_master:
  142. status: "Complete"
  143. end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"