- name: prepare some dirs file: name={{ ETCD_DATA_DIR }} state=directory mode=0700 - name: 下载etcd二进制文件 copy: src={{ base_dir }}/bin/{{ item }} dest={{ bin_dir }}/{{ item }} mode=0755 with_items: - etcd - etcdctl tags: upgrade_etcd - name: 创建etcd证书请求 template: src=etcd-csr.json.j2 dest={{ cluster_dir }}/ssl/etcd-csr.json connection: local - name: 创建 etcd证书和私钥 shell: "cd {{ cluster_dir }}/ssl && {{ base_dir }}/bin/cfssl gencert \ -ca=ca.pem \ -ca-key=ca-key.pem \ -config=ca-config.json \ -profile=kubernetes etcd-csr.json | {{ base_dir }}/bin/cfssljson -bare etcd" connection: local - name: 分发etcd证书相关 copy: src={{ cluster_dir }}/ssl/{{ item }} dest={{ ca_dir }}/{{ item }} with_items: - ca.pem - etcd.pem - etcd-key.pem - name: 创建etcd的systemd unit文件 template: src=etcd.service.j2 dest=/etc/systemd/system/etcd.service tags: upgrade_etcd, restart_etcd - name: 开机启用etcd服务 shell: systemctl enable etcd ignore_errors: true - name: 开启etcd服务 shell: systemctl daemon-reload && systemctl restart etcd ignore_errors: true tags: upgrade_etcd, restart_etcd - name: 以轮询的方式等待服务同步完成 shell: "systemctl is-active etcd.service" register: etcd_status until: '"active" in etcd_status.stdout' retries: 8 delay: 8 tags: upgrade_etcd, restart_etcd