Merge pull request #3970 from woopstar/image_builder_1
Add image builder to create Docker vm's for kube-virt
This commit is contained in:
commit
1e09fd8e0f
7 changed files with 111 additions and 0 deletions
2
test-infra/image-builder/Makefile
Normal file
2
test-infra/image-builder/Makefile
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
deploy:
|
||||||
|
ansible-playbook -i hosts.ini -e docker_password=$(docker_password) cluster.yml
|
6
test-infra/image-builder/OWNERS
Normal file
6
test-infra/image-builder/OWNERS
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
approvers:
|
||||||
|
- woopstar
|
||||||
|
- ant31
|
||||||
|
reviewers:
|
||||||
|
- woopstar
|
||||||
|
- ant31
|
4
test-infra/image-builder/cluster.yml
Normal file
4
test-infra/image-builder/cluster.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
- hosts: image-builder
|
||||||
|
gather_facts: false
|
||||||
|
roles:
|
||||||
|
- kubevirt-images
|
4
test-infra/image-builder/hosts.ini
Normal file
4
test-infra/image-builder/hosts.ini
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
image-builder-1 ansible_ssh_host=xxx.xxx.xxx.xxx
|
||||||
|
|
||||||
|
[image-builder]
|
||||||
|
image-builder-1
|
|
@ -0,0 +1,36 @@
|
||||||
|
images_dir: /images/base
|
||||||
|
|
||||||
|
docker_user: kubespray+buildvmimages
|
||||||
|
docker_host: quay.io
|
||||||
|
registry: quay.io/kubespray
|
||||||
|
|
||||||
|
images:
|
||||||
|
ubuntu-1604:
|
||||||
|
filename: xenial-server-cloudimg-amd64-disk1.img
|
||||||
|
url: https://storage.googleapis.com/kubespray-images/ubuntu/xenial-server-cloudimg-amd64-disk1.img
|
||||||
|
checksum: sha256:c0d099383cd064390b568e20d1c39a9c68ba864764404b70f754a7b1b2f808f7
|
||||||
|
converted: false
|
||||||
|
|
||||||
|
ubuntu-1804:
|
||||||
|
filename: bionic-server-cloudimg-amd64.img
|
||||||
|
url: https://cloud-images.ubuntu.com/bionic/current/bionic-server-cloudimg-amd64.img
|
||||||
|
checksum: sha256:c3d0e03f4245ffaabd7647e6dabf346b944a62b9934d0a89f3a04b4236386af2
|
||||||
|
converted: false
|
||||||
|
|
||||||
|
fedora-28:
|
||||||
|
filename: Fedora-Cloud-Base-28-1.1.x86_64.qcow2
|
||||||
|
url: https://mirror.netsite.dk/fedora/linux/releases/28/Cloud/x86_64/images/Fedora-Cloud-Base-28-1.1.x86_64.qcow2
|
||||||
|
checksum: sha256:d987209719fadaf81b8bff85c5d3590a1d3dac6357e4838fde8357086c49b5b4
|
||||||
|
converted: true
|
||||||
|
|
||||||
|
centos-7:
|
||||||
|
filename: CentOS-7-x86_64-GenericCloud-1809.qcow2
|
||||||
|
url: http://cloud.centos.org/centos/7/images/CentOS-7-x86_64-GenericCloud-1809.qcow2
|
||||||
|
checksum: sha256:42c062df8a8c36991ec0282009dd52ac488461a3f7ee114fc21a765bfc2671c2
|
||||||
|
converted: true
|
||||||
|
|
||||||
|
debian-9:
|
||||||
|
filename: debian-9-openstack-amd64.qcow2
|
||||||
|
url: https://cdimage.debian.org/cdimage/openstack/current-9/debian-9-openstack-amd64.qcow2
|
||||||
|
checksum: sha256:01d9345ba7a6523d214d2eaabe07fe7b4b69b28e63d7a6b322521e99e5768719
|
||||||
|
converted: true
|
|
@ -0,0 +1,53 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
- name: Create image directory
|
||||||
|
file:
|
||||||
|
state: directory
|
||||||
|
path: " {{ images_dir }}"
|
||||||
|
|
||||||
|
- name: Download images files
|
||||||
|
get_url:
|
||||||
|
url: "{{ item.value.url }}"
|
||||||
|
dest: "{{ images_dir }}/{{ item.value.filename }}"
|
||||||
|
checksum: "{{ item.value.checksum }}"
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
||||||
|
|
||||||
|
- name: Convert images which is not in qcow2 format
|
||||||
|
command: qemu-img convert -O qcow2 {{ images_dir }}/{{ item.value.filename }} {{ images_dir }}/{{ item.key }}.qcow2
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
||||||
|
when:
|
||||||
|
- item.value.converted|bool != true
|
||||||
|
register: converted
|
||||||
|
|
||||||
|
- name: Make sure all images are ending with qcow2
|
||||||
|
command: cp {{ images_dir }}/{{ item.value.filename }} {{ images_dir }}/{{ item.key }}.qcow2
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
||||||
|
when:
|
||||||
|
- item.value.converted|bool == true
|
||||||
|
|
||||||
|
- name: Resize images
|
||||||
|
command: qemu-img resize {{ images_dir }}/{{ item.key }}.qcow2 +8G
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
||||||
|
|
||||||
|
# STEP 2: Include the images inside a container
|
||||||
|
- name: Template default Dockerfile
|
||||||
|
template:
|
||||||
|
src: Dockerfile
|
||||||
|
dest: "{{ images_dir }}/Dockerfile"
|
||||||
|
|
||||||
|
- name: Create docker images for each OS
|
||||||
|
command: docker build -t {{registry}}/vm-{{ item.key }} --build-arg cloud_image="{{ item.key }}.qcow2" {{ images_dir }}
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
||||||
|
|
||||||
|
- name: docker login
|
||||||
|
command: docker login -u="{{ docker_user }}" -p="{{ docker_password }}" "{{ docker_host }}"
|
||||||
|
|
||||||
|
- name: docker push image
|
||||||
|
command: docker push {{ registry }}/vm-{{ item.key }}:latest
|
||||||
|
with_dict:
|
||||||
|
- "{{ images }}"
|
|
@ -0,0 +1,6 @@
|
||||||
|
FROM kubevirt/registry-disk-v1alpha
|
||||||
|
|
||||||
|
ARG cloud_image
|
||||||
|
MAINTAINER "The Kubespray Project" <kubespray@googlegroups.com>
|
||||||
|
|
||||||
|
COPY $cloud_image /disk
|
Loading…
Reference in a new issue