45 Commits

Author SHA1 Message Date
b340b4cdbc feat:Update K8s patch version
All checks were successful
continuous-integration/drone/push Build is passing
2023-06-20 16:35:50 +02:00
f14096e1b4 fix:Enable load_additional_components flag
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-23 16:30:02 +02:00
5efe9a0540 build:Debug SSH connection error
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-22 15:15:15 +02:00
7dfd5c9091 build:Revert image configuration
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-05-22 14:49:03 +02:00
38bae64f01 build:Test shortest possible image name
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-05-22 14:15:33 +02:00
39e0c0dae8 build:Test non-fully-qualified container image name
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-05-22 14:07:11 +02:00
04119f3078 fix:Add missing kube-vip container image (determined by CAPV version)
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-05-22 11:53:39 +02:00
b1cf73f482 Upgrade K8s minor version
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-19 12:22:55 +02:00
f0157db4c1 Replace source image
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-17 12:37:59 +02:00
4979379c51 Upgrade RHEL
Some checks failed
continuous-integration/drone/push Build is failing
2023-05-17 12:27:43 +02:00
9588786c74 Fix rpm name
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-12 16:39:50 +02:00
1be5714f67 Switch from deb to rpm packages
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-05-12 15:55:18 +02:00
4c5025fbd6 Add dependency
All checks were successful
continuous-integration/drone/push Build is passing
2023-05-12 10:43:22 +02:00
7f15853393 Add Redhat subscription manager credentials;Replace iso
All checks were successful
continuous-integration/drone/push Build is passing
2023-04-21 17:35:27 +02:00
bb0c1c5837 Add full path
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-04-21 15:04:43 +02:00
136226ce32 Switch to cdrom for kickstart script
Some checks reported errors
continuous-integration/drone/push Build was killed
2023-04-21 14:55:33 +02:00
1c4858f0ad Enable dhcp
Some checks reported errors
continuous-integration/drone/push Build was killed
2023-04-21 14:48:19 +02:00
dcfdca25a5 Use credentials for source url;Update checksum
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-04-21 14:02:27 +02:00
ddacf57d4a Fix source image
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-04-21 13:34:49 +02:00
bc98e03c49 Remove cloud-init reference
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-04-21 12:40:42 +02:00
4b059cccdb Switch OS
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-04-21 12:20:19 +02:00
e9366081c9 Fix pause image tag
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-23 13:44:59 +01:00
59956a6971 New image version
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-20 20:47:57 +01:00
619923b2d4 Upgrade K8s version
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-18 20:18:09 +01:00
19628c3080 Remove custom ansible role (overwrite cloud-init datasource priority)
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-18 20:15:48 +01:00
e6c366a5be Remove redundant package installation
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-04 15:50:41 +01:00
12ae24f950 Disable unrelated dependency
Some checks failed
continuous-integration/drone/push Build is failing
2023-03-04 13:01:08 +01:00
b94b7a2916 Update versions
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-03-04 12:47:18 +01:00
652a5d25c9 Fix pause image tag
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-03 13:03:21 +01:00
8b30841fc4 Override cloud-init datasource list;Add package open-iscsi
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-03 09:59:03 +01:00
af4c3a1b08 Fix var reference; Revert file move
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-02 12:14:12 +01:00
51f36b921d Copy cloud-init files
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-03-02 12:06:54 +01:00
5d279e0e86 Downgrade OS
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-03-02 11:45:22 +01:00
567749e74d Unlock builder account;Revert debug user
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-02 11:42:39 +01:00
3b644541dd Add additional package;Force ovftool
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-02 09:45:02 +01:00
d29e73a424 Move debug user creation
All checks were successful
continuous-integration/drone/push Build is passing
2023-02-25 13:28:14 +01:00
ad38b34ce4 Copy subfolders
Some checks reported errors
continuous-integration/drone/push Build was killed
2023-02-25 12:52:37 +01:00
0a2cc82e2d Fix non-empty folder move
Some checks failed
continuous-integration/drone/push Build is failing
2023-02-25 11:25:32 +01:00
e27b3f1f6f Revert output directory;Add sleep for debugging
Some checks failed
continuous-integration/drone/push Build is failing
2023-02-25 10:48:18 +01:00
963930e04d Fix var reference
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-02-24 21:35:14 +01:00
8463a257d6 Output directly to volume
All checks were successful
continuous-integration/drone/push Build is passing
2023-02-24 17:23:44 +01:00
ad8df64b13 Fix fileglob
Some checks failed
continuous-integration/drone/push Build is failing
2023-02-24 10:58:11 +01:00
d828b83e0b Debug working directory;Fix path
Some checks failed
continuous-integration/drone/push Build is failing
2023-02-24 10:32:16 +01:00
139629a458 Move artifact to output volume;Add debug user
Some checks failed
continuous-integration/drone/push Build is failing
2023-02-24 09:39:50 +01:00
e220c2bc24 Destroy VM after build;Debug output
All checks were successful
continuous-integration/drone/push Build is passing
2023-02-23 22:22:23 +01:00
10 changed files with 126 additions and 27 deletions

View File

@@ -22,20 +22,29 @@ steps:
image: bv11-cr01.bessems.eu/library/packer-extended
pull: always
commands:
- |
apt-get update
- |
apt-get install -y \
curl \
make
- |
jq '.password="'"$VSPHERE_PASSWORD"'"' ./packer/ova/vsphere.json > /tmp/vsphere.json && \
mv /tmp/vsphere.json ./packer/ova/vsphere.json
jq '.repo_username="'"$REPO_USERNAME"'" | .repo_password="'"$REPO_PASSWORD"'"' --null-input > /tmp/extra_vars.json
- |
make deps-ova
- |
make build-node-ova-vsphere-ubuntu-2204
make build-node-ova-vsphere-rhel-8
- |
mv -fv ./output/**/*.ova /output
environment:
IB_OVFTOOL: true
IB_OVFTOOL_ARGS: --allowExtraConfig
PACKER_FLAGS: -on-error=ask
PACKER_VAR_FILES: /tmp/extra_vars.json
REPO_USERNAME:
from_secret: repo_username
REPO_PASSWORD:
from_secret: repo_password
RHSM_USER:
from_secret: rhsm_username
RHSM_PASS:
from_secret: rhsm_password
VSPHERE_PASSWORD:
from_secret: vsphere_password
volumes:

View File

@@ -81,7 +81,7 @@ deps-osc:
hack/ensure-packer.sh
hack/ensure-goss.sh
packer plugins install github.com/outscale/outscale
.PHONY: deps-gce
deps-gce: ## Installs/checks dependencies for GCE builds
deps-gce:
@@ -93,7 +93,7 @@ deps-gce:
deps-ova: ## Installs/checks dependencies for OVA builds
deps-ova:
hack/ensure-ansible.sh
hack/ensure-ansible-windows.sh
: hack/ensure-ansible-windows.sh
hack/ensure-packer.sh
hack/ensure-goss.sh
hack/ensure-ovftool.sh
@@ -494,7 +494,7 @@ $(OCI_VALIDATE_TARGETS): deps-oci
packer validate $(PACKER_NODE_FLAGS) -var-file="$(abspath packer/oci/$(subst validate-oci-,,$@).json)" $(ABSOLUTE_PACKER_VAR_FILES) packer/oci/packer.json
.PHONY: $(OSC_BUILD_TARGETS)
$(OSC_BUILD_TARGETS): deps-osc
$(OSC_BUILD_TARGETS): deps-osc
packer build $(PACKER_NODE_FLAGS) -var-file="$(abspath packer/outscale/$(subst build-osc-,,$@).json)" $(ABSOLUTE_PACKER_VAR_FILES) packer/outscale/packer.json
.PHONY: $(OSC_VALIDATE_TARGETS)

View File

@@ -2,9 +2,9 @@
"additional_executables": "false",
"additional_executables_destination_path": "",
"additional_executables_list": "",
"additional_registry_images": "false",
"additional_registry_images_list": "",
"additional_registry_images": "true",
"additional_registry_images_list": "ghcr.io/kube-vip/kube-vip:v0.5.5",
"additional_url_images": "false",
"additional_url_images_list": "",
"load_additional_components": "false"
"load_additional_components": "true"
}

View File

@@ -3,7 +3,7 @@
"disable_public_repos": "false",
"extra_debs": "",
"extra_repos": "",
"extra_rpms": "",
"extra_rpms": "iscsi-initiator-utils ca-certificates",
"firstboot_custom_roles_post": "",
"firstboot_custom_roles_pre": "",
"http_proxy": "",
@@ -11,7 +11,7 @@
"no_proxy": "",
"node_custom_roles_post": "",
"node_custom_roles_pre": "",
"pause_image": "registry.k8s.io/pause:3.9",
"pause_image": "registry.k8s.io/pause:3.8",
"pip_conf_file": "",
"redhat_epel_rpm": "https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm",
"reenable_public_repos": "true",

View File

@@ -8,16 +8,16 @@
"kubernetes_container_registry": "registry.k8s.io",
"kubernetes_deb_gpg_key": "https://packages.cloud.google.com/apt/doc/apt-key.gpg",
"kubernetes_deb_repo": "\"https://apt.kubernetes.io/ kubernetes-xenial\"",
"kubernetes_deb_version": "1.23.15-00",
"kubernetes_deb_version": "1.25.10-00",
"kubernetes_http_source": "https://dl.k8s.io/release",
"kubernetes_load_additional_imgs": "false",
"kubernetes_rpm_gpg_check": "True",
"kubernetes_rpm_gpg_key": "\"https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg\"",
"kubernetes_rpm_repo": "https://packages.cloud.google.com/yum/repos/kubernetes-el7-{{user `kubernetes_rpm_repo_arch`}}",
"kubernetes_rpm_repo_arch": "x86_64",
"kubernetes_rpm_version": "1.23.15-0",
"kubernetes_semver": "v1.23.15",
"kubernetes_series": "v1.23",
"kubernetes_rpm_version": "1.25.10-0",
"kubernetes_semver": "v1.25.10",
"kubernetes_series": "v1.25",
"kubernetes_source_type": "pkg",
"systemd_prefix": "/usr/lib/systemd",
"sysusr_prefix": "/usr",

View File

@@ -0,0 +1,87 @@
#cloud-config
# Copyright 2022 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# For more information on how autoinstall is configured, please refer to
# https://ubuntu.com/server/docs/install/autoinstall-reference
autoinstall:
version: 1
# Disable ssh server during installation, otherwise packer tries to connect and exceed max attempts
early-commands:
- systemctl stop ssh
# Configure the locale
locale: en_US.UTF-8
keyboard:
layout: us
# Create a single-partition with no swap space. Kubernetes
# really dislikes the idea of anyone else managing memory.
# For more information on how partitioning is configured,
# please refer to https://curtin.readthedocs.io/en/latest/topics/storage.html.
storage:
config:
- type: disk
id: disk-0
size: largest
grub_device: true
preserve: false
ptable: msdos
wipe: superblock
- type: partition
id: partition-0
device: disk-0
size: -1
number: 1
preserve: false
flag: boot
- type: format
id: format-0
volume: partition-0
fstype: ext4
preserve: false
- type: mount
id: mount-0
device: format-0
path: /
updates: 'all'
ssh:
install-server: true
allow-pw: true
# Customize the list of packages installed.
packages:
- open-vm-tools
# Create the default user.
# Ensures the "builder" user doesn't require a password to use sudo.
user-data:
users:
- name: builder
# openssl passwd -6 -stdin <<< builder
passwd: $6$xyz$UtXVazU08Q5b8AW.TJ3MPYZglyXa3Ttf2RCel8MCUPlEYO1evWxeWBhZ2QqivU/Ij4tqYAxMCqc2ujEM4dMSe1
groups: [adm, cdrom, dip, plugdev, lxd, sudo]
lock-passwd: false
sudo: ALL=(ALL) NOPASSWD:ALL
shell: /bin/bash
# This command runs after all other steps; it:
# 1. Disables swapfiles
# 2. Removes the existing swapfile
# 3. Removes the swapfile entry from /etc/fstab
# 4. Cleans up any packages that are no longer required
# 5. Removes the cached list of packages
late-commands:
- swapoff -a
- rm -f /swapfile
- sed -ri '/\sswap\s/s/^#?/#/' /etc/fstab
- apt-get purge --auto-remove -y
- rm -rf /var/lib/apt/lists/*

View File

@@ -188,13 +188,14 @@
],
"boot_wait": "{{user `boot_wait`}}",
"cluster": "{{user `cluster`}}",
"cd_files": ["{{user `cd_file_path`}}/meta-data", "{{user `cd_file_path`}}/user-data"],
"cd_label": "cidata",
"cd_files": ["{{user `http_directory`}}"],
"cd_label": "OEMDRV",
"communicator": "ssh",
"convert_to_template": "{{user `convert_to_template`}}",
"cpu_cores": "{{user `cpu_cores`}}",
"datacenter": "{{user `datacenter`}}",
"datastore": "{{user `datastore`}}",
"destroy": true,
"disk_controller_type": "{{user `disk_controller_type`}}",
"export": {
"force": true,
@@ -220,7 +221,7 @@
}
],
"password": "{{user `password`}}",
"shutdown_command": "echo '{{user `ssh_password`}}' | sudo -S -E sh -c 'usermod -L {{user `ssh_username`}} && {{user `shutdown_command`}}'",
"shutdown_command": "echo '{{user `ssh_password`}}' | sudo -S -E sh -c '{{user `shutdown_command`}}'",
"ssh_password": "{{user `ssh_password`}}",
"ssh_timeout": "4h",
"ssh_username": "{{user `ssh_username`}}",
@@ -358,7 +359,8 @@
"--extra-vars",
"{{user `ansible_user_vars`}}",
"--scp-extra-args",
"{{user `ansible_scp_extra_args`}}"
"{{user `ansible_scp_extra_args`}}",
"-vvvvv"
],
"playbook_file": "./ansible/firstboot.yml",
"type": "ansible",

View File

@@ -1,7 +1,7 @@
{
"boot_command_prefix": "<up><tab> text inst.ks=",
"boot_command_suffix": "/8/ks.cfg<enter><wait>",
"boot_media_path": "http://{{ .HTTPIP }}:{{ .HTTPPort }}",
"boot_command_suffix": "packer/ova/linux/{{user `distro_name`}}/http/8/ks.cfg<enter><wait>",
"boot_media_path": "cdrom:",
"build_name": "rhel-8",
"distro_arch": "amd64",
"distro_name": "rhel",
@@ -9,9 +9,9 @@
"epel_rpm_gpg_key": "https://dl.fedoraproject.org/pub/epel/RPM-GPG-KEY-EPEL-8",
"guest_os_type": "rhel8-64",
"http_directory": "./packer/ova/linux/{{user `distro_name`}}/http/",
"iso_checksum": "48f955712454c32718dcde858dea5aca574376a1d7a4b0ed6908ac0b85597811",
"iso_checksum": "517ABCC67EE3B7212F57E180F5D30BE3E8269E7A99E127A3399B7935C7E00A09",
"iso_checksum_type": "sha256",
"iso_url": "file:///rhel-8.4-x86_64-dvd.iso",
"iso_url": "https://{{ user `repo_username` }}:{{ user `repo_password` }}@sn.itch.fyi/Repository/iso/Redhat/rhel-8.8-x86_64-dvd.iso",
"os_display_name": "RHEL 8",
"redhat_epel_rpm": "https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm",
"shutdown_command": "shutdown -P now",

View File

@@ -4,6 +4,7 @@
"boot_disable_ipv6": "0",
"boot_media_path": "/media/HTTP",
"build_name": "ubuntu-2004",
"cd_file_path": "./packer/ova/linux/{{user `distro_name`}}/http/{{user `distro_version`}}",
"distro_arch": "amd64",
"distro_name": "ubuntu",
"distro_version": "20.04",