mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	* Support for live patching systemVMs and deprecating systemVM.iso. Includes: - fix systemVM template version - Include agent.zip, cloud-scripts.tgz to the commons package - Support for live-patching systemVMs - CPVM, SSVM, Routers - Fix Unit test - Remove systemvm.iso dependency * The following commit: - refactors logic added to support SystemVM deployment on KVM - Adds support to copy specific files (required for patching) to the hosts on Xenserver - Modifies vmops method - createFileInDomr to take cleanup param - Adds configuratble sleep param to CitrixResourceBase::connect() used to verify if telnet to specifc port is possible (if sleep is 0, then default to _sleep = 10000ms) - Adds Command/Answer for patch systemVMs on XenServer/Xcp * - Support to patch SystemVMs - VMWare - Remove attaching systemvm.iso to systemVMs - Modify / Refactor VMware start command to copy patch related files to the systemvms - cleanup * Commit comprises of: - remove docker from systemvm template - use containerd as container runtime - update create-k8s-binaries script to use ctr for all docker operations - Update userdata sent to the k8s nodes - update cksnode script, run during patching of the cks/k8s nodes * Add ssh to k8s nodes details in the Access tab on the UI * test * Refactor ca/cert patching logic * Commit comprises of the following changes: - Use restart network/VPC API to patch routers - use livePatch API support patching of only cpvm/ssvm - add timeout to the keystore setup/import script * remove all references of systemvm.iso * Fix keystore-cert-import invocation + refactor cert timeout in CP/SS VMs * fix script timeout * Refactor cert patching for systemVMs + update keystore-cert-import script + patch-sysvms script + remove patchSysvmCommand from networkelementcommand * remove commented code + change core user to cloud for cks nodes * Update ownership of ssh directory * NEED TO DISCUSS - add on the fly template conversion as an ExecStartPre action (systemd) * Add UI changes + move changes from patch file to runcmd * test: validate performance for template modification during seeding * create vms folder in cloudstack-commons directory - debian rules * remove logic for on the fly template convert + update k8s test * fix syntax issue - causing issue with shared network tests * Code cleanup * refactor patching logic - certs * move logic of fixing rootdiskcontroller from upgrade to kubernetes service * add livepatch option to restart network & vpc * smooth upgrade of cks clusters * Support for live patching systemVMs and deprecating systemVM.iso. Includes: - fix systemVM template version - Include agent.zip, cloud-scripts.tgz to the commons package - Support for live-patching systemVMs - CPVM, SSVM, Routers - Fix Unit test - Remove systemvm.iso dependency * The following commit: - refactors logic added to support SystemVM deployment on KVM - Adds support to copy specific files (required for patching) to the hosts on Xenserver - Modifies vmops method - createFileInDomr to take cleanup param - Adds configuratble sleep param to CitrixResourceBase::connect() used to verify if telnet to specifc port is possible (if sleep is 0, then default to _sleep = 10000ms) - Adds Command/Answer for patch systemVMs on XenServer/Xcp * - Support to patch SystemVMs - VMWare - Remove attaching systemvm.iso to systemVMs - Modify / Refactor VMware start command to copy patch related files to the systemvms - cleanup * Commit comprises of: - remove docker from systemvm template - use containerd as container runtime - update create-k8s-binaries script to use ctr for all docker operations - Update userdata sent to the k8s nodes - update cksnode script, run during patching of the cks/k8s nodes * Add ssh to k8s nodes details in the Access tab on the UI * test * Refactor ca/cert patching logic * Commit comprises of the following changes: - Use restart network/VPC API to patch routers - use livePatch API support patching of only cpvm/ssvm - add timeout to the keystore setup/import script * remove all references of systemvm.iso * Fix keystore-cert-import invocation + refactor cert timeout in CP/SS VMs * fix script timeout * Refactor cert patching for systemVMs + update keystore-cert-import script + patch-sysvms script + remove patchSysvmCommand from networkelementcommand * remove commented code + change core user to cloud for cks nodes * Update ownership of ssh directory * NEED TO DISCUSS - add on the fly template conversion as an ExecStartPre action (systemd) * Add UI changes + move changes from patch file to runcmd * test: validate performance for template modification during seeding * create vms folder in cloudstack-commons directory - debian rules * remove logic for on the fly template convert + update k8s test * fix syntax issue - causing issue with shared network tests * Code cleanup * add cgroup config for containerd * add systemd config for kubelet * add additional info during image registry config * address comments * add temp links of download.cloudstack.org * address part of the comments * address comments * update containerd config - as version has upgraded to 1.5 from 1.4.12 in 4.17.0 * address comments - simplify * fix vue3 related icon changes * allow network commands when router template version is lower but is patched * add internal LB to the list of routers to be patched on network restart with live patch * add unit tests for API param validations and new helper utilities - file scp & checksum validations * perform patching only for non-user i.e., system VMs * add test to validate params * remove unused import * add column to domain_router to display software version and support networkrestart with livePatch from router view * Requires upgrade column to consider package (cloud-scripts) checksum to identify if true/false * use router software version instead of checksum * show N/A if no software version reported i.e., in upgraded envs * fix deb failure * update pom to official links of systemVM template
		
			
				
	
	
		
			153 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/bin/bash
 | |
| # Licensed to the Apache Software Foundation (ASF) under one
 | |
| # or more contributor license agreements.  See the NOTICE file
 | |
| # distributed with this work for additional information
 | |
| # regarding copyright ownership.  The ASF licenses this file
 | |
| # to you 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.
 | |
| 
 | |
| set -e
 | |
| set -x
 | |
| 
 | |
| CLOUDSTACK_RELEASE=4.17.0
 | |
| 
 | |
| function configure_apache2() {
 | |
|    # Enable ssl, rewrite and auth
 | |
|    a2enmod ssl rewrite auth_basic auth_digest
 | |
|    a2ensite default-ssl
 | |
|    # Backup stock apache configuration since we may modify it in Secondary Storage VM
 | |
|    cp /etc/apache2/sites-available/000-default.conf /etc/apache2/sites-available/default.orig
 | |
|    cp /etc/apache2/sites-available/default-ssl.conf /etc/apache2/sites-available/default-ssl.orig
 | |
|    sed -i 's/SSLProtocol .*$/SSLProtocol TLSv1.2/g' /etc/apache2/mods-available/ssl.conf
 | |
| }
 | |
| 
 | |
| function configure_strongswan() {
 | |
|   # change the charon stroke timeout from 3 minutes to 30 seconds
 | |
|   sed -i "s/# timeout = 0/timeout = 30000/" /etc/strongswan.d/charon/stroke.conf
 | |
| }
 | |
| 
 | |
| function configure_issue() {
 | |
|   cat > /etc/issue <<EOF
 | |
| 
 | |
|    __?.o/  Apache CloudStack SystemVM $CLOUDSTACK_RELEASE
 | |
|   (  )#    https://cloudstack.apache.org
 | |
|  (___(_)   Debian GNU/Linux 11 \n \l
 | |
| 
 | |
| EOF
 | |
| }
 | |
| 
 | |
| function configure_cacerts() {
 | |
|   CDIR=$(pwd)
 | |
|   cd /tmp
 | |
|   # Add LetsEncrypt ca-cert
 | |
|   wget https://letsencrypt.org/certs/lets-encrypt-r3.der
 | |
|   wget https://letsencrypt.org/certs/isrgrootx1.der
 | |
|   keytool -trustcacerts -keystore /etc/ssl/certs/java/cacerts -storepass changeit -noprompt -importcert -alias letsencryptauthorityr3 -file lets-encrypt-r3.der
 | |
|   keytool -trustcacerts -keystore /etc/ssl/certs/java/cacerts -storepass changeit -noprompt -importcert -alias letsencryptauthorityx1 -file isrgrootx1.der
 | |
|   rm -f lets-encrypt-r3.der isrgrootx1.der
 | |
|   cd $CDIR
 | |
| }
 | |
| 
 | |
| function install_cloud_scripts() {
 | |
|   # ./cloud_scripts/ has been put there by ../../cloud_scripts_shar_archive.sh
 | |
|   rsync -av ./cloud_scripts/ /
 | |
| 
 | |
|   chmod +x /opt/cloud/bin/* /opt/cloud/bin/setup/* \
 | |
|     /root/{clearUsageRules.sh,reconfigLB.sh,monitorServices.py} \
 | |
|     /etc/profile.d/cloud.sh /etc/cron.daily/* /etc/cron.hourly/*
 | |
| 
 | |
|   chmod +x /root/health_checks/*
 | |
|   chmod -x /etc/systemd/system/* || true
 | |
| 
 | |
|   systemctl daemon-reload
 | |
|   systemctl enable cloud-preinit
 | |
|   systemctl enable cloud-early-config
 | |
|   systemctl enable cloud-postinit
 | |
| }
 | |
| 
 | |
| function do_signature() {
 | |
|   mkdir -p /var/cache/cloud/ /usr/share/cloud/
 | |
|   (cd ./cloud_scripts/; tar -cvf - * | gzip > /usr/share/cloud/cloud-scripts.tgz)
 | |
|   md5sum /usr/share/cloud/cloud-scripts.tgz | awk '{print $1}' > /var/cache/cloud/cloud-scripts-signature
 | |
|   echo "Cloudstack Release $CLOUDSTACK_RELEASE $(date)" > /etc/cloudstack-release
 | |
| }
 | |
| 
 | |
| function configure_services() {
 | |
|   mkdir -p /var/www/html
 | |
|   mkdir -p /opt/cloud/bin
 | |
|   mkdir -p /var/cache/cloud
 | |
|   mkdir -p /usr/share/cloud
 | |
|   mkdir -p /usr/local/cloud
 | |
| 
 | |
|   # Fix dnsmasq directory issue
 | |
|   mkdir -p /opt/tftpboot
 | |
| 
 | |
|   # Fix haproxy directory issue
 | |
|   mkdir -p /var/lib/haproxy
 | |
| 
 | |
|   install_cloud_scripts
 | |
|   do_signature
 | |
| 
 | |
|   systemctl daemon-reload
 | |
|   systemctl disable apt-daily.service
 | |
|   systemctl disable apt-daily.timer
 | |
|   systemctl disable apt-daily-upgrade.timer
 | |
| 
 | |
|   # Disable services that slow down boot and are not used anyway
 | |
|   systemctl disable apache2
 | |
|   systemctl disable conntrackd
 | |
|   systemctl disable console-setup
 | |
|   systemctl disable dnsmasq
 | |
|   systemctl disable haproxy
 | |
|   systemctl disable keepalived
 | |
|   systemctl disable radvd
 | |
|   systemctl disable strongswan-starter
 | |
|   systemctl disable x11-common
 | |
|   systemctl disable xl2tpd
 | |
|   systemctl disable vgauth
 | |
|   systemctl disable sshd
 | |
|   systemctl disable nfs-common
 | |
|   systemctl disable portmap
 | |
| 
 | |
|   # Disable guest services which will selectively be started based on hypervisor
 | |
|   systemctl disable open-vm-tools
 | |
|   systemctl disable xe-daemon
 | |
|   systemctl disable hyperv-daemons.hv-fcopy-daemon.service
 | |
|   systemctl disable hyperv-daemons.hv-kvp-daemon.service
 | |
|   systemctl disable hyperv-daemons.hv-vss-daemon.service
 | |
|   systemctl disable qemu-guest-agent
 | |
| 
 | |
|   # Disable container services
 | |
|   systemctl disable containerd
 | |
| 
 | |
|   # Disable cloud init by default
 | |
| cat <<EOF > /etc/cloud/cloud.cfg.d/cloudstack.cfg
 | |
| datasource_list: ['CloudStack']
 | |
| datasource:
 | |
|   CloudStack:
 | |
|     max_wait: 120
 | |
|     timeout: 50
 | |
| EOF
 | |
| 
 | |
|   touch /etc/cloud/cloud-init.disabled
 | |
|   systemctl stop cloud-init
 | |
|   systemctl disable cloud-init
 | |
| 
 | |
|   configure_apache2
 | |
|   configure_strongswan
 | |
|   configure_issue
 | |
|   configure_cacerts
 | |
| }
 | |
| 
 | |
| return 2>/dev/null || configure_services
 |