kubeasz/roles/harbor/tasks/main.yml

45 lines
1.4 KiB
YAML
Raw Normal View History

2017-12-25 15:05:21 +08:00
- name: 下载docker compose 二进制文件
copy: src={{ base_dir }}/bin/docker-compose dest={{ bin_dir }}/docker-compose mode=0755
# 注册变量result根据result结果判断是否已经安装过harbor
# result|failed 说明没有安装过harbor下一步进行安装
# result|succeeded 说明已经安装过harbor下一步跳过安装
- name: 注册变量result
2017-12-25 22:01:44 +08:00
command: ls /data/registry
2017-12-25 15:05:21 +08:00
register: result
ignore_errors: True
- name: 解压harbor离线安装包
unarchive:
src: "{{ base_dir }}/down/harbor-offline-installer-v1.2.2.tgz"
2018-05-31 23:01:54 +08:00
dest: /opt
2017-12-25 15:05:21 +08:00
copy: yes
keep_newer: yes
2018-05-31 23:01:54 +08:00
when: result is failed
2017-12-25 15:05:21 +08:00
- name: 导入harbor所需 docker images
2018-05-31 23:01:54 +08:00
shell: "{{ bin_dir }}/docker load -i /opt/harbor/harbor.v1.2.2.tar.gz"
when: result is failed
2017-12-25 15:05:21 +08:00
- name: 创建harbor证书请求
template: src=harbor-csr.json.j2 dest={{ ca_dir }}/harbor-csr.json
2018-05-31 23:01:54 +08:00
when: result is failed
2017-12-25 15:05:21 +08:00
- name: 创建harbor证书和私钥
shell: "cd {{ ca_dir }} && {{ bin_dir }}/cfssl gencert \
-ca={{ ca_dir }}/ca.pem \
-ca-key={{ ca_dir }}/ca-key.pem \
-config={{ ca_dir }}/ca-config.json \
-profile=kubernetes harbor-csr.json | {{ bin_dir }}/cfssljson -bare harbor"
2018-05-31 23:01:54 +08:00
when: result is failed
2017-12-25 15:05:21 +08:00
- name: 配置 harbor.cfg 文件
2018-05-31 23:01:54 +08:00
template: src=harbor.cfg.j2 dest=/opt/harbor/harbor.cfg
when: result is failed
2017-12-25 15:05:21 +08:00
- name: 安装 harbor
2018-05-31 23:01:54 +08:00
shell: "cd /opt/harbor && \
2017-12-25 15:05:21 +08:00
export PATH={{ bin_dir }}:$PATH && \
./install.sh"
2018-05-31 23:01:54 +08:00
when: result is failed