basic_facts.yml 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. ---
  2. - name: Ensure that all non-node hosts are accessible
  3. hosts: oo_masters_to_config:oo_etcd_to_config:oo_lb_to_config:oo_nfs_to_config
  4. any_errors_fatal: true
  5. tasks:
  6. - name: Initialize basic host facts
  7. # l_init_fact_hosts is passed in via play during control-plane-only
  8. # upgrades and scale-up plays; otherwise oo_all_hosts is used.
  9. hosts: "{{ l_init_fact_hosts | default('oo_all_hosts') }}"
  10. roles:
  11. - role: openshift_facts
  12. tasks:
  13. # TODO: Should this role be refactored into health_checks??
  14. - name: Run openshift_sanitize_inventory to set variables
  15. import_role:
  16. name: openshift_sanitize_inventory
  17. - name: Detecting Operating System from ostree_booted
  18. stat:
  19. path: /run/ostree-booted
  20. get_checksum: false
  21. get_attributes: false
  22. get_mime: false
  23. register: ostree_booted
  24. # TODO(michaelgugino) remove this line once CI is updated.
  25. - name: set openshift_deployment_type if unset
  26. set_fact:
  27. openshift_deployment_type: "{{ deployment_type }}"
  28. when:
  29. - openshift_deployment_type is undefined
  30. - deployment_type is defined
  31. - name: initialize_facts set fact openshift_is_atomic and openshift_is_containerized
  32. set_fact:
  33. openshift_is_atomic: "{{ ostree_booted.stat.exists }}"
  34. openshift_is_containerized: "{{ ostree_booted.stat.exists or (containerized | default(false) | bool) }}"
  35. # TODO: Should this be moved into health checks??
  36. # Seems as though any check that happens with a corresponding fail should move into health_checks
  37. # Fail as early as possible if Atomic and old version of Docker
  38. - when:
  39. - openshift_is_atomic | bool
  40. block:
  41. # See https://access.redhat.com/articles/2317361
  42. # and https://github.com/ansible/ansible/issues/15892
  43. # NOTE: the "'s can not be removed at this level else the docker command will fail
  44. # NOTE: When ansible >2.2.1.x is used this can be updated per
  45. # https://github.com/openshift/openshift-ansible/pull/3475#discussion_r103525121
  46. - name: Determine Atomic Host Docker Version
  47. shell: 'CURLY="{"; docker version --format "$CURLY{json .Server.Version}}"'
  48. register: l_atomic_docker_version
  49. - name: assert atomic host docker version is 1.12 or later
  50. assert:
  51. that:
  52. - l_atomic_docker_version.stdout | replace('"', '') is version('1.12','>=')
  53. msg: Installation on Atomic Host requires Docker 1.12 or later. Please upgrade and restart the Atomic Host.
  54. - name: Retrieve existing master configs and validate
  55. hosts: oo_masters_to_config
  56. gather_facts: no
  57. any_errors_fatal: true
  58. roles:
  59. - openshift_facts
  60. tasks:
  61. - import_role:
  62. name: openshift_control_plane
  63. tasks_from: check_existing_config.yml
  64. - when:
  65. - l_existing_config_master_config is defined
  66. - l_existing_config_master_config.networkConfig is defined
  67. block:
  68. - set_fact:
  69. openshift_portal_net: "{{ l_existing_config_master_config.networkConfig.serviceNetworkCIDR }}"
  70. - set_fact:
  71. osm_cluster_network_cidr: "{{ l_existing_config_master_config.networkConfig.clusterNetworks[0].cidr }}"
  72. osm_host_subnet_length: "{{ l_existing_config_master_config.networkConfig.clusterNetworks[0].hostSubnetLength }}"
  73. when:
  74. - l_existing_config_master_config.networkConfig.clusterNetworks is defined
  75. # End block
  76. - name: Initialize special first-master variables
  77. hosts: oo_first_master
  78. roles:
  79. - role: openshift_facts
  80. tasks:
  81. - when: not (osm_default_node_selector is defined)
  82. block:
  83. - set_fact:
  84. # l_existing_config_master_config is set in openshift_control_plane/tasks/check_existing_config.yml
  85. openshift_master_config_node_selector: "{{ l_existing_config_master_config.projectConfig.defaultNodeSelector }}"
  86. when:
  87. - l_existing_config_master_config is defined
  88. - l_existing_config_master_config.projectConfig is defined
  89. - l_existing_config_master_config.projectConfig.defaultNodeSelector is defined
  90. - l_existing_config_master_config.projectConfig.defaultNodeSelector != ''
  91. - set_fact:
  92. # We need to setup openshift_client_binary here for special uses of delegate_to in
  93. # later roles and plays.
  94. first_master_client_binary: "{{ openshift_client_binary }}"
  95. #Some roles may require this to be set for first master
  96. openshift_client_binary: "{{ openshift_client_binary }}"
  97. # we need to know if a default node selector has been manually set outside the installer
  98. l_osm_default_node_selector: '{{ osm_default_node_selector | default(openshift_master_config_node_selector) | default("node-role.kubernetes.io/compute=true") }}'
  99. - name: Disable web console if required
  100. hosts: oo_masters_to_config
  101. gather_facts: no
  102. tasks:
  103. - set_fact:
  104. openshift_web_console_install: False
  105. when:
  106. - openshift_deployment_subtype is defined
  107. - openshift_deployment_subtype == 'registry' or ( osm_disabled_features is defined and 'WebConsole' in osm_disabled_features )