Commande pour déterminer si Ubuntu s'exécute sur une machine virtuelle?

16

Existe-t-il une commande ou un outil qui peut être utilisé pour déterminer si Ubuntu s'exécute en tant qu'invité dans un programme de virtualisation tel que VirtualBox ou Qemu ou s'il s'exécute sur le métal nu?

Nathan Osman
la source

Réponses:

16

virt-what Installer virt-what est un script shell qui peut être utilisé pour détecter si le programme s'exécute sur une machine virtuelle.

Le programme imprime une liste de "faits" sur la machine virtuelle, dérivés d'heuristiques. Un fait est imprimé par ligne.

Si rien n'est imprimé et les sorties de script avec le code 0 (pas d' erreur), alors cela peut signifier soit que le programme est en cours d' exécution en métal nu ou le programme est en cours d' exécution dans un type de machine virtuelle que nous ne savons pas ou ne peut pas détecter.

SOMMAIRE

sudo virt-what [facts]

LES FAITS

aws Amazon Web Services cloud guest.

    Status: contributed by Qi Guo.

bhyve
    This is a bhyve (FreeBSD hypervisor) guest.

    Status: contributed by Leonardo Brondani Schenkel.

docker
    This is a Docker container.

    Status: confirmed by Charles Nguyen

hyperv
    This is Microsoft Hyper-V hypervisor.

    Status: confirmed by RWMJ

ibm_power-kvm
    This is an IBM POWER KVM guest.

    Status: contributed by Adrian Likins.

ibm_power-lpar_shared
ibm_power-lpar_dedicated
    This is an IBM POWER LPAR (hardware partition) in either shared or
    dedicated mode.

    Status: contributed by Adrian Likins.

ibm_systemz
    This is an IBM SystemZ (or other S/390) hardware partitioning
    system. Additional facts listed below may also be printed.

ibm_systemz-direct
    This is Linux running directly on a IBM SystemZ hardware
    partitioning system.

    This is expected to be a highly unusual configuration - if you see
    this result you should treat it with suspicion.

    Status: not confirmed

ibm_systemz-lpar
    This is Linux running directly on an LPAR on an IBM SystemZ hardware
    partitioning system.

    Status: confirmed by Thomas Huth

ibm_systemz-zvm
    This is a z/VM guest running in an LPAR on an IBM SystemZ hardware
    partitioning system.

    Status: confirmed by RWMJ using a Fedora guest running in z/VM

ibm_systemz-kvm
    This is a KVM guest running on an IBM System Z hardware system.

    Status: contributed by Thomas Huth

ldoms
    The guest appears to be running on an Linux SPARC system with Oracle
    VM Server for SPARC (Logical Domains) support.

    Status: contributed by Darren Kenny

ldoms-control
    The is the Oracle VM Server for SPARC (Logical Domains) control
    domain.

    Status: contributed by Darren Kenny

ldoms-guest
    The is the Oracle VM Server for SPARC (Logical Domains) guest
    domain.

    Status: contributed by Darren Kenny

ldoms-io
    The is the Oracle VM Server for SPARC (Logical Domains) I/O domain.

    Status: contributed by Darren Kenny

ldoms-root
    The is the Oracle VM Server for SPARC (Logical Domains) Root domain.

    Status: contributed by Darren Kenny

linux_vserver
    This is printed for backwards compatibility with older virt-what
    which could not distinguish between a Linux VServer container guest
    and host.

linux_vserver-guest
    This process is running in a Linux VServer container.

    Status: contributed by Barış Metin

linux_vserver-host
    This process is running as the Linux VServer host (VxID 0).

    Status: contributed by Barış Metin and Elan Ruusamäe

lxc This process is running in a Linux LXC container.

    Status: contributed by Marc Fournier

kvm This guest is running on the KVM hypervisor using hardware
    acceleration.

    Note that if the hypervisor is using software acceleration you
    should *not* see this, but should see the "qemu" fact instead.

    Status: confirmed by RWMJ.

lkvm
    This guest is running on the KVM hypervisor using hardware
    acceleration, and the userspace component of the hypervisor is lkvm
    (a.k.a kvmtool).

    Status: contributed by Andrew Jones

openvz
    The guest appears to be running inside an OpenVZ or Virtuozzo
    container.

    Status: contributed by Evgeniy Sokolov

ovirt
    The guest is running on an oVirt node. (See also "rhev" below).

    Status: contributed by RWMJ, not confirmed

parallels
    The guest is running inside Parallels Virtual Platform (Parallels
    Desktop, Parallels Server).

    Status: contributed by Justin Clift

powervm_lx86
    The guest is running inside IBM PowerVM Lx86 Linux/x86 emulator.

    Status: data originally supplied by Jeffrey Scheel, confirmed by
    Yufang Zhang and RWMJ

qemu
    This is QEMU hypervisor using software emulation.

    Note that for KVM (hardware accelerated) guests you should *not* see
    this.

    Status: confirmed by RWMJ.

rhev
    The guest is running on a Red Hat Enterprise Virtualization (RHEV)
    node.

    Status: confirmed by RWMJ

uml This is a User-Mode Linux (UML) guest.

    Status: contributed by Laurent Léonard

virt
    Some sort of virtualization appears to be present, but we are not
    sure what it is. In some very rare corner cases where we know that
    virtualization is hard to detect, we will try a timing attack to see
    if certain machine instructions are running much more slowly than
    they should be, which would indicate virtualization. In this case,
    the generic fact "virt" is printed.

virtage
    This is Hitachi Virtualization Manager (HVM) Virtage hardware
    partitioning system.

    Status: data supplied by Bhavna Sarathy, not confirmed

virtualbox
    This is a VirtualBox guest.

    Status: contributed by Laurent Léonard

virtualpc
    The guest appears to be running on Microsoft VirtualPC.

    Status: not confirmed

vmm This is a vmm (OpenBSD hypervisor) guest.

    Status: contributed by Jasper Lievisse Adriaanse.

vmware
    The guest appears to be running on VMware hypervisor.

    Status: confirmed by RWMJ

xen The guest appears to be running on Xen hypervisor.

    Status: confirmed by RWMJ

xen-dom0
    This is the Xen dom0 (privileged domain).

    Status: confirmed by RWMJ

xen-domU
    This is a Xen domU (paravirtualized guest domain).

    Status: confirmed by RWMJ

xen-hvm
    This is a Xen guest fully virtualized (HVM).

    Status: confirmed by RWMJ

Désolé mais c'est votre GUY ....;)

hhlp
la source
6

Exécutez lspciet recherchez la chaîne «VirtualBox».

Tu pourrais courir lspci | grep VirtualBox

Vous pouvez également exécuter lsusbet vérifier la chaîne «VirtualBox». Tel quelsusb | grep VirtualBox

Fonctionne également dmesg, exécutez dmesg | grep VirtualBoxoudmesg | grep virtual

Anonyme
la source
Au moins un message de virtualbox peut apparaître sur un hôte exécutant des invités de virtualbox, donc je laisserais tomber l'option dmesg. Mais lspci et lsusb sont bons.
Joe P
Je pense que les solutions en ligne de commande sont meilleures que l'installation de packages. Si vous disposez de privilèges de superutilisateur sur un système (pour installer des packages), êtes-vous susceptible d'être incertain s'il est virtualisé ou non?
Joe P
@JoeP Vous avez raison - sauf ... Et si vous exécutez un script sur toutes vos machines et qu'il a besoin de savoir si l'hôte est virtualisé ou non?
Mei
3

imvirt (non installé par défaut mais disponible dans le référentiel de l'univers)

Florian Diesch
la source