forked from ungleich-public/cdist
		
	[explorer/machine_type] Use systemd-detect-virt (if available) to detect containers and VMs
This commit is contained in:
		
							parent
							
								
									2ffa895f57
								
							
						
					
					
						commit
						23fbfaf035
					
				
					 1 changed files with 47 additions and 2 deletions
				
			
		|  | @ -130,6 +130,25 @@ detected_layer() { | |||
| 
 | ||||
| # Check for container | ||||
| 
 | ||||
| has_ct_systemd() { | ||||
| 	is_command systemd-detect-virt && systemd-detect-virt --help | grep -q -e '^  -c' | ||||
| } | ||||
| 
 | ||||
| check_ct_systemd() ( | ||||
| 	_ctengine=$(systemd-detect-virt -c 2>/dev/null) && | ||||
| 	case ${_ctengine} | ||||
| 	in | ||||
| 		(''|'none') | ||||
| 			return 1 ;; | ||||
| 		('container-other') | ||||
| 			return 0 ;; | ||||
| 		('systemd-nspawn') | ||||
| 			echo systemd_nspawn ;; | ||||
| 		(*) | ||||
| 			echo "${_ctengine}" ;; | ||||
| 	esac | ||||
| ) | ||||
| 
 | ||||
| has_ct_pid_1() { | ||||
| 	test -r /run/systemd/container -o -r /proc/1/environ | ||||
| } | ||||
|  | @ -267,6 +286,32 @@ guess_hypervisor_from_cpu_model() { | |||
| 	esac | ||||
| } | ||||
| 
 | ||||
| has_vm_systemd() { | ||||
| 	is_command systemd-detect-virt && systemd-detect-virt --help | grep -q -e '^  -v' | ||||
| } | ||||
| 
 | ||||
| check_vm_systemd() ( | ||||
| 	_hypervisor=$(systemd-detect-virt -v 2>/dev/null) && | ||||
| 	case ${_hypervisor} | ||||
| 	in | ||||
| 		(''|'none') | ||||
| 			return 1 ;; | ||||
| 		('amazon') | ||||
| 			echo aws ;; | ||||
| 		('bochs') | ||||
| 			echo kvm ;; | ||||
| 		('microsoft') | ||||
| 			# assumption | ||||
| 			echo hyperv ;; | ||||
| 		('oracle') | ||||
| 			echo virtualbox ;; | ||||
| 		('vm-other') | ||||
| 			return 0 ;; | ||||
| 		(*) | ||||
| 			echo "${_hypervisor}" ;; | ||||
| 	esac | ||||
| ) | ||||
| 
 | ||||
| has_vm_cpuinfo() { has_cpuinfo; } | ||||
| 
 | ||||
| check_vm_cpuinfo() { | ||||
|  | @ -839,7 +884,7 @@ run_stage() { | |||
| # Execute container stages | ||||
| 
 | ||||
| for stage in \ | ||||
| 	pid_1 cgroup files os_specific | ||||
| 	systemd pid_1 cgroup files os_specific | ||||
| do | ||||
| 	ctengine=$(run_stage ct ${stage}) || continue | ||||
| 	detected_layer 'container' | ||||
|  | @ -861,7 +906,7 @@ fi | |||
| # Execute virtual machine / hypervisor stages | ||||
| 
 | ||||
| for stage in \ | ||||
| 	os_specific hyp_specific sys_hypervisor dt dmi cpuinfo arch_specific | ||||
| 	systemd os_specific hyp_specific sys_hypervisor dt dmi cpuinfo arch_specific | ||||
| do | ||||
| 	hypervisor=$(run_stage vm ${stage}) || continue | ||||
| 	detected_layer 'virtual machine' | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue