diff options
| author | Brenton Leanhardt <bleanhar@redhat.com> | 2016-03-29 15:00:54 -0400 | 
|---|---|---|
| committer | Brenton Leanhardt <bleanhar@redhat.com> | 2016-03-29 15:00:54 -0400 | 
| commit | 7b42f91f8637f6c3ce49f357bea75a3e6528b1ba (patch) | |
| tree | 9d2e2cc1605034debe7cf917af5e74f5838427f8 /roles | |
| parent | 6d74968b30f3dff2046ab50330c2de55ac103a8b (diff) | |
| parent | e6e5c64508ff876973cc5db768012ec836aea31e (diff) | |
| download | openshift-7b42f91f8637f6c3ce49f357bea75a3e6528b1ba.tar.gz openshift-7b42f91f8637f6c3ce49f357bea75a3e6528b1ba.tar.bz2 openshift-7b42f91f8637f6c3ce49f357bea75a3e6528b1ba.tar.xz openshift-7b42f91f8637f6c3ce49f357bea75a3e6528b1ba.zip | |
Merge pull request #1666 from brenton/systemd1
Reusing the systemd templates for the upgrade
Diffstat (limited to 'roles')
| -rwxr-xr-x | roles/openshift_facts/library/openshift_facts.py | 23 | ||||
| -rw-r--r-- | roles/openshift_master/handlers/main.yml | 6 | ||||
| -rw-r--r-- | roles/openshift_master/tasks/main.yml | 57 | ||||
| -rw-r--r-- | roles/openshift_master/tasks/systemd_units.yml | 69 | ||||
| -rw-r--r-- | roles/openshift_master/vars/main.yml | 3 | ||||
| -rw-r--r-- | roles/openshift_node/tasks/main.yml | 39 | ||||
| -rw-r--r-- | roles/openshift_node/tasks/systemd_units.yml | 40 | 
7 files changed, 138 insertions, 99 deletions
| diff --git a/roles/openshift_facts/library/openshift_facts.py b/roles/openshift_facts/library/openshift_facts.py index 30e29787a..ea7406e5b 100755 --- a/roles/openshift_facts/library/openshift_facts.py +++ b/roles/openshift_facts/library/openshift_facts.py @@ -1167,6 +1167,7 @@ def safe_get_bool(fact):      """      return bool(strtobool(str(fact))) +# pylint: disable=too-many-statements  def set_container_facts_if_unset(facts):      """ Set containerized facts. @@ -1183,24 +1184,44 @@ def set_container_facts_if_unset(facts):          node_image = 'openshift3/node'          ovs_image = 'openshift3/openvswitch'          etcd_image = 'registry.access.redhat.com/rhel7/etcd' +        pod_image = 'openshift3/ose-pod' +        router_image = 'openshift3/ose-haproxy-router' +        registry_image = 'openshift3/ose-docker-registry' +        deployer_image = 'openshift3/ose-deployer'      elif deployment_type == 'atomic-enterprise':          master_image = 'aep3_beta/aep'          cli_image = master_image          node_image = 'aep3_beta/node'          ovs_image = 'aep3_beta/openvswitch'          etcd_image = 'registry.access.redhat.com/rhel7/etcd' +        pod_image = 'aep3_beta/aep-pod' +        router_image = 'aep3_beta/aep-haproxy-router' +        registry_image = 'aep3_beta/aep-docker-registry' +        deployer_image = 'aep3_beta/aep-deployer'      else:          master_image = 'openshift/origin'          cli_image = master_image          node_image = 'openshift/node'          ovs_image = 'openshift/openvswitch'          etcd_image = 'registry.access.redhat.com/rhel7/etcd' +        pod_image = 'openshift/origin-pod' +        router_image = 'openshift/origin-haproxy-router' +        registry_image = 'openshift/origin-docker-registry' +        deployer_image = 'openshift/origin-deployer'      facts['common']['is_atomic'] = os.path.isfile('/run/ostree-booted')      if 'is_containerized' not in facts['common']:          facts['common']['is_containerized'] = facts['common']['is_atomic']      if 'cli_image' not in facts['common']:          facts['common']['cli_image'] = cli_image +    if 'pod_image' not in facts['common']: +        facts['common']['pod_image'] = pod_image +    if 'router_image' not in facts['common']: +        facts['common']['router_image'] = router_image +    if 'registry_image' not in facts['common']: +        facts['common']['registry_image'] = registry_image +    if 'deployer_image' not in facts['common']: +        facts['common']['deployer_image'] = deployer_image      if 'etcd' in facts and 'etcd_image' not in facts['etcd']:          facts['etcd']['etcd_image'] = etcd_image      if 'master' in facts and 'master_image' not in facts['master']: @@ -1350,11 +1371,11 @@ class OpenShiftFacts(object):          facts = set_identity_providers_if_unset(facts)          facts = set_sdn_facts_if_unset(facts, self.system_facts)          facts = set_deployment_facts_if_unset(facts) +        facts = set_container_facts_if_unset(facts)          facts = set_version_facts_if_unset(facts)          facts = set_manageiq_facts_if_unset(facts)          facts = set_aggregate_facts(facts)          facts = set_etcd_facts_if_unset(facts) -        facts = set_container_facts_if_unset(facts)          if not safe_get_bool(facts['common']['is_containerized']):              facts = set_installed_variant_rpm_facts(facts)          return dict(openshift=facts) diff --git a/roles/openshift_master/handlers/main.yml b/roles/openshift_master/handlers/main.yml index e5b9e4977..70c7ef4e4 100644 --- a/roles/openshift_master/handlers/main.yml +++ b/roles/openshift_master/handlers/main.yml @@ -1,17 +1,17 @@  ---  - name: restart master    service: name={{ openshift.common.service_type }}-master state=restarted -  when: (not openshift_master_ha | bool) and (not (master_service_status_changed | default(false) | bool)) +  when: (openshift.master.ha is defined and not openshift.master.ha | bool) and (not (master_service_status_changed | default(false) | bool))    notify: Verify API Server  - name: restart master api    service: name={{ openshift.common.service_type }}-master-api state=restarted -  when: (openshift_master_ha | bool) and (not (master_api_service_status_changed | default(false) | bool)) and openshift.master.cluster_method == 'native' +  when: (openshift.master.ha is defined and openshift_master_ha | bool) and (not (master_api_service_status_changed | default(false) | bool)) and openshift.master.cluster_method == 'native'    notify: Verify API Server  - name: restart master controllers    service: name={{ openshift.common.service_type }}-master-controllers state=restarted -  when: (openshift_master_ha | bool) and (not (master_controllers_service_status_changed | default(false) | bool)) and openshift.master.cluster_method == 'native' +  when: (openshift.master.ha is defined and openshift_master_ha | bool) and (not (master_controllers_service_status_changed | default(false) | bool)) and openshift.master.cluster_method == 'native'  - name: Verify API Server    # Using curl here since the uri module requires python-httplib2 and diff --git a/roles/openshift_master/tasks/main.yml b/roles/openshift_master/tasks/main.yml index 9c3d09d09..e64339ea6 100644 --- a/roles/openshift_master/tasks/main.yml +++ b/roles/openshift_master/tasks/main.yml @@ -97,13 +97,6 @@      docker pull {{ openshift.master.master_image }}:{{ openshift_version }}    when: openshift.common.is_containerized | bool -- name: Install Master docker service file -  template: -    dest: "/etc/systemd/system/{{ openshift.common.service_type }}-master.service" -    src: docker/master.docker.service.j2 -  register: install_result -  when: openshift.common.is_containerized | bool and not openshift_master_ha | bool -  - name: Create openshift.common.data_dir    file:      path: "{{ openshift.common.data_dir }}" @@ -168,54 +161,8 @@    when: item.kind == 'HTPasswdPasswordIdentityProvider'    with_items: openshift.master.identity_providers -- name: Init HA Service Info -  set_fact: -    ha_suffix: "" -    ha_svcdir: "/usr/lib/systemd/system" - -- name: Set HA Service Info for containerized installs -  set_fact: -    ha_suffix: ".docker" -    ha_svcdir: "/etc/systemd/system" -  when: openshift.common.is_containerized | bool - -# workaround for missing systemd unit files for controllers/api -- name: Create the systemd unit files -  template: -    src: "{{ ha_svc_template_path }}/atomic-openshift-master-{{ item }}.service.j2" -    dest: "{{ ha_svcdir }}/{{ openshift.common.service_type }}-master-{{ item }}.service" -  when: openshift_master_ha | bool and openshift_master_cluster_method == "native" -  with_items: -  - api -  - controllers -  register: create_unit_files - -- command: systemctl daemon-reload -  when: create_unit_files | changed -# end workaround for missing systemd unit files - -- name: Create the master api service env file -  template: -    src: "{{ ha_svc_template_path }}/atomic-openshift-master-api.j2" -    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master-api -  when: openshift_master_ha | bool and openshift_master_cluster_method == "native" -  notify: -  - restart master api - -- name: Create the master controllers service env file -  template: -    src: "{{ ha_svc_template_path }}/atomic-openshift-master-controllers.j2" -    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master-controllers -  when: openshift_master_ha | bool and openshift_master_cluster_method == "native" -  notify: -  - restart master controllers - -- name: Create the master service env file -  template: -    src: "atomic-openshift-master.j2" -    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master -  notify: -  - restart master +- name: Install the systemd units +  include: systemd_units.yml  - name: Create session secrets file    template: diff --git a/roles/openshift_master/tasks/systemd_units.yml b/roles/openshift_master/tasks/systemd_units.yml new file mode 100644 index 000000000..a81270bab --- /dev/null +++ b/roles/openshift_master/tasks/systemd_units.yml @@ -0,0 +1,69 @@ +# This file is included both in the openshift_master role and in the upgrade +# playbooks.  For that reason the ha_svc variables are use set_fact instead of +# the vars directory on the role. + +- name: Init HA Service Info +  set_fact: +    containerized_svc_dir: "/usr/lib/systemd/system" +    ha_svc_template_path: "native-cluster" + +- name: Set HA Service Info for containerized installs +  set_fact: +    containerized_svc_dir: "/etc/systemd/system" +    ha_svc_template_path: "docker-cluster" +  when: openshift.common.is_containerized | bool + +# workaround for missing systemd unit files +- name: Create the systemd unit files +  template: +    src: "docker/master.docker.service.j2" +    dest: "{{ containerized_svc_dir }}/{{ openshift.common.service_type }}-master.service" +  when: openshift.common.is_containerized | bool and (openshift.master.ha is not defined or not openshift.master.ha | bool) +  register: create_master_unit_file + +- command: systemctl daemon-reload +  when: create_master_unit_file | changed + +- name: Create the ha systemd unit files +  template: +    src: "{{ ha_svc_template_path }}/atomic-openshift-master-{{ item }}.service.j2" +    dest: "{{ containerized_svc_dir }}/{{ openshift.common.service_type }}-master-{{ item }}.service" +  when: openshift.master.ha is defined and openshift.master.ha | bool and openshift_master_cluster_method == "native" +  with_items: +  - api +  - controllers +  register: create_ha_unit_files + +- command: systemctl daemon-reload +  when: create_ha_unit_files | changed +# end workaround for missing systemd unit files + +- name: Create the master api service env file +  template: +    src: "{{ ha_svc_template_path }}/atomic-openshift-master-api.j2" +    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master-api +  when: openshift.master.ha is defined and openshift.master.ha | bool and openshift_master_cluster_method == "native" +  notify: +  - restart master api + +- name: Create the master controllers service env file +  template: +    src: "{{ ha_svc_template_path }}/atomic-openshift-master-controllers.j2" +    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master-controllers +  when: openshift.master.ha is defined and openshift.master.ha | bool and openshift_master_cluster_method == "native" +  notify: +  - restart master controllers + +- name: Install Master docker service file +  template: +    dest: "/etc/systemd/system/{{ openshift.common.service_type }}-master.service" +    src: docker/master.docker.service.j2 +  register: install_result +  when: openshift.common.is_containerized | bool and openshift.master.ha is defined and not openshift.master.ha | bool + +- name: Create the master service env file +  template: +    src: "atomic-openshift-master.j2" +    dest: /etc/sysconfig/{{ openshift.common.service_type }}-master +  notify: +  - restart master diff --git a/roles/openshift_master/vars/main.yml b/roles/openshift_master/vars/main.yml index 6b5a73238..75f08e378 100644 --- a/roles/openshift_master/vars/main.yml +++ b/roles/openshift_master/vars/main.yml @@ -8,9 +8,6 @@ openshift_master_session_secrets_file: "{{ openshift_master_config_dir }}/sessio  openshift_master_policy: "{{ openshift_master_config_dir }}/policy.json"  openshift_version: "{{ openshift_pkg_version | default(openshift_image_tag) | default(openshift.common.image_tag) | default('') }}" -ha_svc_template_path: "{{ 'docker-cluster' if openshift.common.is_containerized | bool else 'native-cluster' }}" -ha_svc_svc_dir: "{{ '/etc/systemd/system' if openshift.common.is_containerized | bool else '/usr/lib/systemd/system' }}" -  openshift_master_valid_grant_methods:  - auto  - prompt diff --git a/roles/openshift_node/tasks/main.yml b/roles/openshift_node/tasks/main.yml index ca1e26459..993c8c0cd 100644 --- a/roles/openshift_node/tasks/main.yml +++ b/roles/openshift_node/tasks/main.yml @@ -53,27 +53,8 @@      docker pull {{ openshift.node.ovs_image }}:{{ openshift_version }}    when: openshift.common.is_containerized | bool and openshift.common.use_openshift_sdn | bool -- name: Install Node docker service file -  template: -    dest: "/etc/systemd/system/{{ openshift.common.service_type }}-node.service" -    src: openshift.docker.node.service -  register: install_node_result -  when: openshift.common.is_containerized | bool - -- name: Create the openvswitch service env file -  template: -    src: openvswitch.sysconfig.j2 -    dest: /etc/sysconfig/openvswitch -  when: openshift.common.is_containerized | bool -  register: install_ovs_sysconfig - -- name: Install OpenvSwitch docker service file -  template: -    dest: "/etc/systemd/system/openvswitch.service" -    src: openvswitch.docker.service -  when: openshift.common.is_containerized | bool and openshift.common.use_openshift_sdn | bool -  notify: -  - restart openvswitch +- name: Install the systemd units +  include: systemd_units.yml  - name: Reload systemd units    command: systemctl daemon-reload @@ -100,22 +81,6 @@    notify:    - restart node -- name: Configure Node settings -  lineinfile: -    dest: /etc/sysconfig/{{ openshift.common.service_type }}-node -    regexp: "{{ item.regex }}" -    line: "{{ item.line }}" -    create: true -  with_items: -    - regex: '^OPTIONS=' -      line: "OPTIONS=--loglevel={{ openshift.node.debug_level }}" -    - regex: '^CONFIG_FILE=' -      line: "CONFIG_FILE={{ openshift_node_config_file }}" -    - regex: '^IMAGE_VERSION=' -      line: "IMAGE_VERSION={{ openshift_version }}" -  notify: -  - restart node -  - name: Additional storage plugin configuration    include: storage_plugins/main.yml diff --git a/roles/openshift_node/tasks/systemd_units.yml b/roles/openshift_node/tasks/systemd_units.yml new file mode 100644 index 000000000..be4b4ed61 --- /dev/null +++ b/roles/openshift_node/tasks/systemd_units.yml @@ -0,0 +1,40 @@ +# This file is included both in the openshift_master role and in the upgrade +# playbooks. + +- name: Install Node docker service file +  template: +    dest: "/etc/systemd/system/{{ openshift.common.service_type }}-node.service" +    src: openshift.docker.node.service +  register: install_node_result +  when: openshift.common.is_containerized | bool + +- name: Create the openvswitch service env file +  template: +    src: openvswitch.sysconfig.j2 +    dest: /etc/sysconfig/openvswitch +  when: openshift.common.is_containerized | bool +  register: install_ovs_sysconfig + +- name: Install OpenvSwitch docker service file +  template: +    dest: "/etc/systemd/system/openvswitch.service" +    src: openvswitch.docker.service +  when: openshift.common.is_containerized | bool and openshift.common.use_openshift_sdn | bool +  notify: +  - restart openvswitch + +- name: Configure Node settings +  lineinfile: +    dest: /etc/sysconfig/{{ openshift.common.service_type }}-node +    regexp: "{{ item.regex }}" +    line: "{{ item.line }}" +    create: true +  with_items: +    - regex: '^OPTIONS=' +      line: "OPTIONS=--loglevel={{ openshift.node.debug_level }}" +    - regex: '^CONFIG_FILE=' +      line: "CONFIG_FILE={{ openshift_node_config_file }}" +    - regex: '^IMAGE_VERSION=' +      line: "IMAGE_VERSION={{ openshift_version }}" +  notify: +  - restart node | 
