2019-02-07 15:10:49 +08:00
|
|
|
# 自动设置LB节点变量'LB_IF'
|
|
|
|
- name: 注册变量 LB_IF_TMP
|
|
|
|
shell: "ip a|grep '{{ inventory_hostname }}/'|awk '{print $NF}'"
|
|
|
|
register: LB_IF_TMP
|
2019-05-30 21:37:01 +08:00
|
|
|
tags: restart_lb
|
2019-02-07 15:10:49 +08:00
|
|
|
|
|
|
|
- name: 设置变量 LB_IF
|
2019-05-30 21:37:01 +08:00
|
|
|
set_fact: LB_IF={{ LB_IF_TMP.stdout }}
|
|
|
|
tags: restart_lb
|
2019-02-07 15:10:49 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: prepare some dirs
|
2019-06-28 21:16:13 +08:00
|
|
|
file: name={{ item }} state=directory
|
|
|
|
with_items:
|
2021-04-09 08:35:12 +08:00
|
|
|
- "/etc/l4lb/sbin"
|
|
|
|
- "/etc/l4lb/logs"
|
|
|
|
- "/etc/l4lb/conf"
|
|
|
|
- "/etc/keepalived"
|
2019-06-28 21:16:13 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 下载二进制文件l4lb(nginx)
|
|
|
|
copy: src={{ base_dir }}/bin/nginx dest=/etc/l4lb/sbin/l4lb mode=0755
|
2019-11-24 21:30:31 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 创建l4lb的配置文件
|
|
|
|
template: src=l4lb.conf.j2 dest=/etc/l4lb/conf/l4lb.conf
|
2019-11-24 21:30:31 +08:00
|
|
|
tags: restart_lb
|
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 创建l4lb的systemd unit文件
|
|
|
|
template: src=l4lb.service.j2 dest=/etc/systemd/system/l4lb.service
|
2019-11-24 21:30:31 +08:00
|
|
|
tags: restart_lb
|
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 开机启用l4lb服务
|
|
|
|
shell: systemctl enable l4lb
|
2019-11-24 21:30:31 +08:00
|
|
|
ignore_errors: true
|
2019-06-28 21:16:13 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 开启l4lb服务
|
|
|
|
shell: systemctl daemon-reload && systemctl restart l4lb
|
|
|
|
ignore_errors: true
|
|
|
|
tags: restart_lb
|
2019-02-07 15:10:49 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 以轮询的方式等待l4lb服务启动
|
2021-05-28 10:11:35 +08:00
|
|
|
shell: "systemctl is-active l4lb.service"
|
2021-04-09 08:35:12 +08:00
|
|
|
register: svc_status
|
2021-05-28 10:11:35 +08:00
|
|
|
until: '"active" in svc_status.stdout'
|
2021-04-09 08:35:12 +08:00
|
|
|
retries: 3
|
|
|
|
delay: 3
|
2019-02-07 15:10:49 +08:00
|
|
|
tags: restart_lb
|
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
|
|
|
|
- name: 下载二进制文件keepalived
|
|
|
|
copy: src={{ base_dir }}/bin/keepalived dest=/usr/local/sbin/keepalived mode=0755
|
|
|
|
|
|
|
|
- name: 配置 keepalived 主节点
|
|
|
|
template: src=keepalived-master.conf.j2 dest=/etc/keepalived/keepalived.conf
|
|
|
|
when: LB_ROLE == "master"
|
2019-02-07 15:10:49 +08:00
|
|
|
tags: restart_lb
|
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 配置 keepalived 备节点
|
|
|
|
template: src=keepalived-backup.conf.j2 dest=/etc/keepalived/keepalived.conf
|
|
|
|
when: LB_ROLE == "backup"
|
|
|
|
tags: restart_lb
|
2019-02-07 15:10:49 +08:00
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 创建keepalived的systemd unit文件
|
|
|
|
template: src=keepalived.service.j2 dest=/etc/systemd/system/keepalived.service
|
2019-02-07 15:10:49 +08:00
|
|
|
tags: restart_lb
|
|
|
|
|
|
|
|
- name: 开机启用keepalived服务
|
|
|
|
shell: systemctl enable keepalived
|
|
|
|
ignore_errors: true
|
|
|
|
|
2021-04-09 08:35:12 +08:00
|
|
|
- name: 开启keepalived服务
|
|
|
|
shell: systemctl daemon-reload && systemctl restart keepalived
|
|
|
|
ignore_errors: true
|
|
|
|
tags: restart_lb
|
|
|
|
|
|
|
|
- name: 以轮询的方式等待keepalived服务启动
|
2021-05-28 10:11:35 +08:00
|
|
|
shell: "systemctl is-active keepalived.service"
|
2021-04-09 08:35:12 +08:00
|
|
|
register: svc_status
|
2021-05-28 10:11:35 +08:00
|
|
|
until: '"active" in svc_status.stdout'
|
2021-04-09 08:35:12 +08:00
|
|
|
retries: 3
|
|
|
|
delay: 3
|
2019-02-07 15:10:49 +08:00
|
|
|
tags: restart_lb
|
2022-12-20 16:28:01 +08:00
|
|
|
|
|
|
|
- name: 检查 ex-lb 的 kube-apiserver 是否正常
|
|
|
|
uri:
|
|
|
|
url: "https://{{ EX_APISERVER_VIP }}:{{ EX_APISERVER_PORT }}"
|
|
|
|
validate_certs: no
|
|
|
|
client_cert: "{{ cluster_dir }}/ssl/admin.pem"
|
|
|
|
client_key: "{{ cluster_dir }}/ssl/admin-key.pem"
|
|
|
|
register: result
|
|
|
|
until: result.status == 200
|
|
|
|
retries: 2
|
|
|
|
delay: 5
|
|
|
|
run_once: true
|
|
|
|
connection: local
|
|
|
|
|
|
|
|
# - debug: var="result"
|