diff options
Diffstat (limited to 'playbooks/common')
21 files changed, 118 insertions, 32 deletions
| diff --git a/playbooks/common/openshift-cluster/config.yml b/playbooks/common/openshift-cluster/config.yml index 5f420a76c..bbd5a0185 100644 --- a/playbooks/common/openshift-cluster/config.yml +++ b/playbooks/common/openshift-cluster/config.yml @@ -22,6 +22,15 @@    tags:    - always +- name: Set hostname +  hosts: oo_masters_to_config:oo_nodes_to_config +  tasks: +  # TODO: switch back to hostname module once we depend on ansible-2.4 +  # https://github.com/ansible/ansible/pull/25906 +  - name: Set hostname +    command: "hostnamectl set-hostname {{ openshift.common.hostname }}" +    when: openshift_set_hostname | default(false,true) | bool +  - include: ../openshift-etcd/config.yml  - include: ../openshift-nfs/config.yml @@ -34,6 +43,8 @@  - include: ../openshift-master/config.yml +- include: ../openshift-master/additional_config.yml +  - include: ../openshift-node/config.yml    tags:    - node diff --git a/playbooks/common/openshift-cluster/enable_dnsmasq.yml b/playbooks/common/openshift-cluster/enable_dnsmasq.yml index 50351588f..be14b06f0 100644 --- a/playbooks/common/openshift-cluster/enable_dnsmasq.yml +++ b/playbooks/common/openshift-cluster/enable_dnsmasq.yml @@ -27,9 +27,6 @@        role: "{{ item.role }}"        local_facts: "{{ item.local_facts }}"      with_items: -    - role: common -      local_facts: -        use_dnsmasq: True      - role: master        local_facts:          dns_port: '8053' @@ -50,9 +47,6 @@        role: "{{ item.role }}"        local_facts: "{{ item.local_facts }}"      with_items: -    - role: common -      local_facts: -        use_dnsmasq: True      - role: node        local_facts:          dns_ip: "{{ hostvars[inventory_hostname]['ansible_default_ipv4']['address'] }}" diff --git a/playbooks/common/openshift-cluster/evaluate_groups.yml b/playbooks/common/openshift-cluster/evaluate_groups.yml index c9f37109b..16a733899 100644 --- a/playbooks/common/openshift-cluster/evaluate_groups.yml +++ b/playbooks/common/openshift-cluster/evaluate_groups.yml @@ -48,6 +48,7 @@      when:      - g_etcd_hosts | default([]) | length == 0      - not openshift_master_unsupported_all_in_one | default(False) +    - not openshift_node_bootstrap | default(False)    - name: Evaluate oo_all_hosts      add_host: diff --git a/playbooks/common/openshift-cluster/initialize_facts.yml b/playbooks/common/openshift-cluster/initialize_facts.yml index 9eaf3bc34..0723575c2 100644 --- a/playbooks/common/openshift-cluster/initialize_facts.yml +++ b/playbooks/common/openshift-cluster/initialize_facts.yml @@ -126,11 +126,9 @@      openshift_facts:        role: common        local_facts: -        debug_level: "{{ openshift_debug_level | default(2) }}"          deployment_type: "{{ openshift_deployment_type }}"          deployment_subtype: "{{ openshift_deployment_subtype | default(None) }}"          cli_image: "{{ osm_image | default(None) }}" -        cluster_id: "{{ openshift_cluster_id | default('default') }}"          hostname: "{{ openshift_hostname | default(None) }}"          ip: "{{ openshift_ip | default(None) }}"          is_containerized: "{{ l_is_containerized | default(None) }}" @@ -148,8 +146,6 @@          no_proxy: "{{ openshift_no_proxy | default(None) }}"          generate_no_proxy_hosts: "{{ openshift_generate_no_proxy_hosts | default(True) }}"          no_proxy_internal_hostnames: "{{ openshift_no_proxy_internal_hostnames | default(None) }}" -        sdn_network_plugin_name: "{{ os_sdn_network_plugin_name | default(None) }}" -        use_openshift_sdn: "{{ openshift_use_openshift_sdn | default(None) }}"    - name: initialize_facts set_fact repoquery command      set_fact: diff --git a/playbooks/common/openshift-cluster/initialize_openshift_version.yml b/playbooks/common/openshift-cluster/initialize_openshift_version.yml index 7112a6084..7af6b25bc 100644 --- a/playbooks/common/openshift-cluster/initialize_openshift_version.yml +++ b/playbooks/common/openshift-cluster/initialize_openshift_version.yml @@ -12,5 +12,10 @@    hosts: oo_all_hosts:!oo_first_master    vars:      openshift_version: "{{ hostvars[groups.oo_first_master.0].openshift_version }}" +  pre_tasks: +  - set_fact: +      openshift_pkg_version: -{{ openshift_version }} +    when: openshift_pkg_version is not defined +  - debug: msg="openshift_pkg_version set to {{ openshift_pkg_version }}"    roles:    - openshift_version diff --git a/playbooks/common/openshift-cluster/openshift_hosted.yml b/playbooks/common/openshift-cluster/openshift_hosted.yml index 99a634970..75339f6df 100644 --- a/playbooks/common/openshift-cluster/openshift_hosted.yml +++ b/playbooks/common/openshift-cluster/openshift_hosted.yml @@ -29,7 +29,6 @@    - role: openshift_default_storage_class      when: openshift_cloudprovider_kind is defined and (openshift_cloudprovider_kind == 'aws' or openshift_cloudprovider_kind == 'gce')    - role: openshift_hosted -    r_openshift_hosted_use_calico: "{{ openshift.common.use_calico | default(false) | bool }}"    - role: openshift_metrics      when: openshift_hosted_metrics_deploy | default(false) | bool    - role: openshift_logging @@ -49,6 +48,9 @@    - role: cockpit-ui      when: ( openshift.common.version_gte_3_3_or_1_3  | bool ) and ( openshift_hosted_manage_registry | default(true) | bool ) and not (openshift.docker.hosted_registry_insecure | default(false) | bool) +  - role: openshift_prometheus +    when: openshift_hosted_prometheus_deploy | default(false) | bool +  - name: Update master-config for publicLoggingURL    hosts: oo_masters_to_config:!oo_first_master    tags: diff --git a/playbooks/common/openshift-cluster/openshift_prometheus.yml b/playbooks/common/openshift-cluster/openshift_prometheus.yml new file mode 100644 index 000000000..a979c0c00 --- /dev/null +++ b/playbooks/common/openshift-cluster/openshift_prometheus.yml @@ -0,0 +1,9 @@ +--- +- include: std_include.yml + +- name: OpenShift Prometheus +  hosts: oo_first_master +  roles: +  - openshift_prometheus +  vars: +    openshift_prometheus_state: present diff --git a/playbooks/common/openshift-cluster/sanity_checks.yml b/playbooks/common/openshift-cluster/sanity_checks.yml new file mode 100644 index 000000000..26716a92d --- /dev/null +++ b/playbooks/common/openshift-cluster/sanity_checks.yml @@ -0,0 +1,51 @@ +--- +- name: Verify Requirements +  hosts: oo_all_hosts +  tasks: +  - fail: +      msg: Flannel can not be used with openshift sdn, set openshift_use_openshift_sdn=false if you want to use flannel +    when: openshift_use_openshift_sdn | default(true) | bool and openshift_use_flannel | default(false) | bool + +  - fail: +      msg: Nuage sdn can not be used with openshift sdn, set openshift_use_openshift_sdn=false if you want to use nuage +    when: openshift_use_openshift_sdn | default(true) | bool and openshift_use_nuage | default(false) | bool + +  - fail: +      msg: Nuage sdn can not be used with flannel +    when: openshift_use_flannel | default(false) | bool and openshift_use_nuage | default(false) | bool + +  - fail: +      msg: Contiv can not be used with openshift sdn, set openshift_use_openshift_sdn=false if you want to use contiv +    when: openshift_use_openshift_sdn | default(true) | bool and openshift_use_contiv | default(false) | bool + +  - fail: +      msg: Contiv can not be used with flannel +    when: openshift_use_flannel | default(false) | bool and openshift_use_contiv | default(false) | bool + +  - fail: +      msg: Contiv can not be used with nuage +    when: openshift_use_nuage | default(false) | bool and openshift_use_contiv | default(false) | bool + +  - fail: +      msg: Calico can not be used with openshift sdn, set openshift_use_openshift_sdn=false if you want to use Calico +    when: openshift_use_openshift_sdn | default(true) | bool and openshift_use_calico | default(false) | bool + +  - fail: +      msg: The Calico playbook does not yet integrate with the Flannel playbook in Openshift. Set either openshift_use_calico or openshift_use_flannel, but not both. +    when: openshift_use_calico | default(false) | bool and openshift_use_flannel | default(false) | bool + +  - fail: +      msg: Calico can not be used with Nuage in Openshift. Set either openshift_use_calico or openshift_use_nuage, but not both +    when: openshift_use_calico | default(false) | bool and openshift_use_nuage | default(false) | bool + +  - fail: +      msg: Calico can not be used with Contiv in Openshift. Set either openshift_use_calico or openshift_use_contiv, but not both +    when: openshift_use_calico | default(false) | bool and openshift_use_contiv | default(false) | bool + +  - fail: +      msg: openshift_hostname must be 63 characters or less +    when: openshift_hostname is defined and openshift_hostname | length > 63 + +  - fail: +      msg: openshift_public_hostname must be 63 characters or less +    when: openshift_public_hostname is defined and openshift_public_hostname | length > 63 diff --git a/playbooks/common/openshift-cluster/std_include.yml b/playbooks/common/openshift-cluster/std_include.yml index 6cc56889a..cef0072f3 100644 --- a/playbooks/common/openshift-cluster/std_include.yml +++ b/playbooks/common/openshift-cluster/std_include.yml @@ -7,6 +7,10 @@    tags:    - always +- include: sanity_checks.yml +  tags: +  - always +  - include: validate_hostnames.yml    tags:    - node diff --git a/playbooks/common/openshift-cluster/tasks/set_etcd_launch_facts.yml b/playbooks/common/openshift-cluster/tasks/set_etcd_launch_facts.yml index 1a6580795..eb118365a 100644 --- a/playbooks/common/openshift-cluster/tasks/set_etcd_launch_facts.yml +++ b/playbooks/common/openshift-cluster/tasks/set_etcd_launch_facts.yml @@ -3,7 +3,7 @@  - name: Generate etcd instance names(s)    set_fact: -    scratch_name: "{{ cluster_id }}-{{ k8s_type }}-{{ '%05x' | format(1048576 | random) }}" +    scratch_name: "{{ openshift_cluster_id | default('default') }}-{{ k8s_type }}-{{ '%05x' | format(1048576 | random) }}"    register: etcd_names_output    with_sequence: count={{ num_etcd }} diff --git a/playbooks/common/openshift-cluster/tasks/set_master_launch_facts.yml b/playbooks/common/openshift-cluster/tasks/set_master_launch_facts.yml index 36d7b7870..783f70f50 100644 --- a/playbooks/common/openshift-cluster/tasks/set_master_launch_facts.yml +++ b/playbooks/common/openshift-cluster/tasks/set_master_launch_facts.yml @@ -3,7 +3,7 @@  - name: Generate master instance names(s)    set_fact: -    scratch_name: "{{ cluster_id }}-{{ k8s_type }}-{{ '%05x' | format(1048576 | random) }}" +    scratch_name: "{{ openshift_cluster_id | default('default') }}-{{ k8s_type }}-{{ '%05x' | format(1048576 | random) }}"    register: master_names_output    with_sequence: count={{ num_masters }} diff --git a/playbooks/common/openshift-cluster/tasks/set_node_launch_facts.yml b/playbooks/common/openshift-cluster/tasks/set_node_launch_facts.yml index 278942f8b..c103e40a9 100644 --- a/playbooks/common/openshift-cluster/tasks/set_node_launch_facts.yml +++ b/playbooks/common/openshift-cluster/tasks/set_node_launch_facts.yml @@ -5,7 +5,7 @@  - name: Generate node instance names(s)    set_fact: -    scratch_name: "{{ cluster_id }}-{{ k8s_type }}-{{ sub_host_type }}-{{ '%05x' | format(1048576 | random) }}" +    scratch_name: "{{ openshift_cluster_id | default('default') }}-{{ k8s_type }}-{{ sub_host_type }}-{{ '%05x' | format(1048576 | random) }}"    register: node_names_output    with_sequence: count={{ number_nodes }} diff --git a/playbooks/common/openshift-cluster/upgrades/docker/docker_upgrade.yml b/playbooks/common/openshift-cluster/upgrades/docker/docker_upgrade.yml index 7cc13137f..98953f72e 100644 --- a/playbooks/common/openshift-cluster/upgrades/docker/docker_upgrade.yml +++ b/playbooks/common/openshift-cluster/upgrades/docker/docker_upgrade.yml @@ -4,7 +4,6 @@      # Do not allow adding hosts during upgrade.      g_new_master_hosts: []      g_new_node_hosts: [] -    openshift_cluster_id: "{{ cluster_id | default('default') }}"  - include: ../initialize_nodes_to_upgrade.yml diff --git a/playbooks/common/openshift-cluster/upgrades/etcd/backup.yml b/playbooks/common/openshift-cluster/upgrades/etcd/backup.yml index 616ba04f8..2cc6c9019 100644 --- a/playbooks/common/openshift-cluster/upgrades/etcd/backup.yml +++ b/playbooks/common/openshift-cluster/upgrades/etcd/backup.yml @@ -2,7 +2,7 @@  - name: Backup etcd    hosts: oo_etcd_hosts_to_backup    roles: -  - role: openshift_facts +  - role: openshift_etcd_facts    - role: etcd_common      r_etcd_common_action: backup      r_etcd_common_backup_tag: etcd_backup_tag diff --git a/playbooks/common/openshift-cluster/upgrades/init.yml b/playbooks/common/openshift-cluster/upgrades/init.yml index 0f421928b..c98065cf4 100644 --- a/playbooks/common/openshift-cluster/upgrades/init.yml +++ b/playbooks/common/openshift-cluster/upgrades/init.yml @@ -4,7 +4,6 @@      # Do not allow adding hosts during upgrade.      g_new_master_hosts: []      g_new_node_hosts: [] -    openshift_cluster_id: "{{ cluster_id | default('default') }}"  - include: ../initialize_oo_option_facts.yml diff --git a/playbooks/common/openshift-cluster/upgrades/pre/tasks/verify_docker_upgrade_targets.yml b/playbooks/common/openshift-cluster/upgrades/pre/tasks/verify_docker_upgrade_targets.yml index 9d8b73cff..6d8503879 100644 --- a/playbooks/common/openshift-cluster/upgrades/pre/tasks/verify_docker_upgrade_targets.yml +++ b/playbooks/common/openshift-cluster/upgrades/pre/tasks/verify_docker_upgrade_targets.yml @@ -1,8 +1,10 @@  ---  # Only check if docker upgrade is required if docker_upgrade is not  # already set to False. -- include: ../docker/upgrade_check.yml -  when: docker_upgrade is not defined or docker_upgrade | bool and not openshift.common.is_atomic | bool +- include: ../../docker/upgrade_check.yml +  when: +  - docker_upgrade is not defined or (docker_upgrade | bool) +  - not (openshift.common.is_atomic | bool)  # Additional checks for Atomic hosts: diff --git a/playbooks/common/openshift-cluster/upgrades/pre/verify_inventory_vars.yml b/playbooks/common/openshift-cluster/upgrades/pre/verify_inventory_vars.yml index 9a959a959..78923e04f 100644 --- a/playbooks/common/openshift-cluster/upgrades/pre/verify_inventory_vars.yml +++ b/playbooks/common/openshift-cluster/upgrades/pre/verify_inventory_vars.yml @@ -9,6 +9,21 @@          deployment types      when: deployment_type not in ['origin','openshift-enterprise', 'online'] +  # osm_cluster_network_cidr, osm_host_subnet_length and openshift_portal_net are +  # required when upgrading to avoid changes that may occur between releases +  # Reference: https://bugzilla.redhat.com/show_bug.cgi?id=1451023 +  - assert: +      that: +      - "osm_cluster_network_cidr is defined" +      - "osm_host_subnet_length is defined" +      - "openshift_portal_net is defined" +      msg: > +        osm_cluster_network_cidr, osm_host_subnet_length, and openshift_portal_net are required inventory +        variables when upgrading. These variables should match what is currently used in the cluster. If +        you don't remember what these values are you can find them in /etc/origin/master/master-config.yaml +        on a master with the names clusterNetworkCIDR (osm_cluster_network_cidr), +        osm_host_subnet_length (hostSubnetLength), and openshift_portal_net (hostSubnetLength). +    # Error out in situations where the user has older versions specified in their    # inventory in any of the openshift_release, openshift_image_tag, and    # openshift_pkg_version variables. These must be removed or updated to proceed diff --git a/playbooks/common/openshift-master/additional_config.yml b/playbooks/common/openshift-master/additional_config.yml index c0ea93d2c..7468c78f0 100644 --- a/playbooks/common/openshift-master/additional_config.yml +++ b/playbooks/common/openshift-master/additional_config.yml @@ -11,13 +11,13 @@      when: openshift_master_ha | bool and openshift.master.cluster_method == "pacemaker"    - role: openshift_examples      registry_url: "{{ openshift.master.registry_url }}" -    when: openshift.common.install_examples | bool +    when: openshift_install_examples | default(True)    - role: openshift_hosted_templates      registry_url: "{{ openshift.master.registry_url }}"    - role: openshift_manageiq -    when: openshift.common.use_manageiq | bool +    when: openshift_use_manageiq | default(false) | bool    - role: cockpit      when: not openshift.common.is_atomic and ( deployment_type in ['atomic-enterprise','openshift-enterprise'] ) and        (osm_use_cockpit | bool or osm_use_cockpit is undefined ) and ( openshift.common.deployment_subtype != 'registry' )    - role: flannel_register -    when: openshift.common.use_flannel | bool +    when: openshift_use_flannel | default(false) | bool diff --git a/playbooks/common/openshift-master/config.yml b/playbooks/common/openshift-master/config.yml index b29b9ef4f..c77d7bb87 100644 --- a/playbooks/common/openshift-master/config.yml +++ b/playbooks/common/openshift-master/config.yml @@ -208,18 +208,15 @@      openshift_master_default_registry_value_api: "{{ hostvars[groups.oo_first_master.0].l_default_registry_value_api }}"      openshift_master_default_registry_value_controllers: "{{ hostvars[groups.oo_first_master.0].l_default_registry_value_controllers }}"    - role: nuage_master -    when: openshift.common.use_nuage | bool +    when: openshift_use_nuage | default(false) | bool    - role: calico_master -    when: openshift.common.use_calico | bool +    when: openshift_use_calico | default(false) | bool    post_tasks:    - name: Create group for deployment type      group_by: key=oo_masters_deployment_type_{{ openshift.common.deployment_type }}      changed_when: False -- include: additional_config.yml -  when: not g_openshift_master_is_scaleup -  - name: Re-enable excluder if it was previously enabled    hosts: oo_masters_to_config    gather_facts: no diff --git a/playbooks/common/openshift-master/restart.yml b/playbooks/common/openshift-master/restart.yml index 6fec346c3..4d73b8124 100644 --- a/playbooks/common/openshift-master/restart.yml +++ b/playbooks/common/openshift-master/restart.yml @@ -7,7 +7,7 @@      openshift_master_ha: "{{ groups.oo_masters_to_config | length > 1 }}"    serial: 1    handlers: -  - include: roles/openshift_master/handlers/main.yml +  - include: ../../../roles/openshift_master/handlers/main.yml      static: yes    roles:    - openshift_facts diff --git a/playbooks/common/openshift-node/config.yml b/playbooks/common/openshift-node/config.yml index c13417714..0801c41ff 100644 --- a/playbooks/common/openshift-node/config.yml +++ b/playbooks/common/openshift-node/config.yml @@ -71,17 +71,18 @@      etcd_ca_host: "{{ groups.oo_etcd_to_config.0 }}"      etcd_cert_subdir: "openshift-node-{{ openshift.common.hostname }}"      etcd_cert_config_dir: "{{ openshift.common.config_base }}/node" -    when: openshift.common.use_flannel | bool +    when: openshift_use_flannel | default(false) | bool    - role: calico -    when: openshift.common.use_calico | bool +    when: openshift_use_calico | default(false) | bool    - role: nuage_node -    when: openshift.common.use_nuage | bool +    when: openshift_use_nuage | default(false) | bool    - role: contiv      contiv_role: netplugin -    when: openshift.common.use_contiv | bool +    when: openshift_use_contiv | default(false) | bool    - role: nickhammond.logrotate    - role: openshift_manage_node      openshift_master_host: "{{ groups.oo_first_master.0 }}" +    when: not openshift_node_bootstrap | default(False)    tasks:    - name: Create group for deployment type      group_by: key=oo_nodes_deployment_type_{{ openshift.common.deployment_type }} | 
