Назад | Перейти на главную страницу

Как заставить FreeNAS отвечать на запросы завершения работы libvirt

У меня есть виртуальная машина KVM FreeNAS 0.7.1 Shere (версия 5127), работающая на Ubuntu Server 10.04, и я не могу убедить виртуальную машину завершить работу с хоста.

virsh shutdown freenas

Я ожидал, что это отправит немного ACPI? запускать виртуальную машину и FreeNAS, а затем делать то, что он сказал.

Я не сторонник FreeBSD, поэтому я действительно не знаю, какие пакеты или процессы нужно использовать, чтобы это работало. Я пытался убедить powerd запустить, но в процессоре виртуальной машины нет требуемой записи freq

Sysctl HW

$ sysctl hw
hw.machine: amd64
hw.model: QEMU Virtual CPU version 0.12.3
hw.ncpu: 1
hw.byteorder: 1234
hw.physmem: 523116544
hw.usermem: 463806464
hw.pagesize: 4096
hw.floatingpoint: 1
hw.machine_arch: amd64
hw.realmem: 536850432
hw.aac.iosize_max: 65536
hw.amr.force_sg32: 0
hw.an.an_cache_iponly: 1
hw.an.an_cache_mcastonly: 0
hw.an.an_cache_mode: dbm
hw.an.an_dump: off
hw.ata.to: 15
hw.ata.wc: 1
hw.ata.atapi_dma: 1
hw.ata.ata_dma_check_80pin: 1
hw.ata.ata_dma: 1
hw.ath.txbuf: 200
hw.ath.rxbuf: 40
hw.ath.regdomain: 0
hw.ath.countrycode: 0
hw.ath.xchanmode: 1
hw.ath.outdoor: 1
hw.ath.calibrate: 30
hw.ath.hal.swba_backoff: 0
hw.ath.hal.sw_brt: 10
hw.ath.hal.dma_brt: 2
hw.bce.msi_enable: 1
hw.bce.tso_enable: 1
hw.bge.allow_asf: 0
hw.cardbus.cis_debug: 0
hw.cardbus.debug: 0
hw.cs.recv_delay: 570
hw.cs.ignore_checksum_failure: 0
hw.cs.debug: 0
hw.cxgb.snd_queue_len: 50
hw.cxgb.use_16k_clusters: 1
hw.cxgb.force_fw_update: 0
hw.cxgb.singleq: 0
hw.cxgb.ofld_disable: 0
hw.cxgb.msi_allowed: 2
hw.cxgb.txq_mr_size: 1024
hw.cxgb.sleep_ticks: 1
hw.cxgb.tx_coalesce: 0
hw.firewire.hold_count: 3
hw.firewire.try_bmr: 1
hw.firewire.fwmem.speed: 2
hw.firewire.fwmem.eui64_lo: 0
hw.firewire.fwmem.eui64_hi: 0
hw.firewire.phydma_enable: 1
hw.firewire.nocyclemaster: 0
hw.firewire.fwe.rx_queue_len: 128
hw.firewire.fwe.tx_speed: 2
hw.firewire.fwe.stream_ch: 1
hw.firewire.fwip.rx_queue_len: 128
hw.firewire.sbp.tags: 0
hw.firewire.sbp.use_doorbell: 0
hw.firewire.sbp.scan_delay: 500
hw.firewire.sbp.login_delay: 1000
hw.firewire.sbp.exclusive_login: 1
hw.firewire.sbp.max_speed: -1
hw.firewire.sbp.auto_login: 1
hw.mfi.max_cmds: 128
hw.mfi.event_class: 0
hw.mfi.event_locale: 65535
hw.pccard.cis_debug: 0
hw.pccard.debug: 0
hw.cbb.debug: 0
hw.cbb.start_32_io: 4096
hw.cbb.start_16_io: 256
hw.cbb.start_memory: 2281701376
hw.pcic.pd6722_vsense: 1
hw.pcic.intr_mask: 57016
hw.pci.honor_msi_blacklist: 1
hw.pci.enable_msix: 1
hw.pci.enable_msi: 1
hw.pci.do_power_resume: 1
hw.pci.do_power_nodriver: 0
hw.pci.enable_io_modes: 1
hw.pci.host_mem_start: 2147483648
hw.syscons.kbd_debug: 1
hw.syscons.kbd_reboot: 1
hw.syscons.bell: 1
hw.syscons.saver.keybonly: 1
hw.syscons.sc_no_suspend_vtswitch: 0
hw.usb.uplcom.interval: 100
hw.usb.uvscom.interval: 100
hw.usb.uvscom.opktsize: 8
hw.wi.debug: 0
hw.wi.txerate: 0
hw.xe.debug: 0
hw.intr_storm_threshold: 1000
hw.availpages: 127714
hw.bus.devctl_disable: 0
hw.ste.rxsyncs: 0
hw.busdma.total_bpages: 32
hw.busdma.zone0.total_bpages: 32
hw.busdma.zone0.free_bpages: 32
hw.busdma.zone0.reserved_bpages: 0
hw.busdma.zone0.active_bpages: 0
hw.busdma.zone0.total_bounced: 0
hw.busdma.zone0.total_deferred: 0
hw.busdma.zone0.lowaddr: 0xffffffff
hw.busdma.zone0.alignment: 2
hw.busdma.zone0.boundary: 65536
hw.clockrate: 2808
hw.instruction_sse: 1
hw.apic.enable_extint: 0
hw.kbd.keymap_restrict_change: 0
hw.acpi.supported_sleep_state: S3 S4 S5
hw.acpi.power_button_state: S5
hw.acpi.sleep_button_state: S3
hw.acpi.lid_switch_state: NONE
hw.acpi.standby_state: S1
hw.acpi.suspend_state: S3
hw.acpi.sleep_delay: 1
hw.acpi.s4bios: 0
hw.acpi.verbose: 0
hw.acpi.disable_on_reboot: 0
hw.acpi.handle_reboot: 0
hw.acpi.cpu.cx_lowest: C1

Процессы

$ ps ax
  PID  TT  STAT      TIME COMMAND
    0  ??  DLs    0:00.00 [swapper]
    1  ??  ILs    0:00.00 /sbin/init --
    2  ??  DL     0:00.08 [g_event]
    3  ??  DL     0:00.29 [g_up]
    4  ??  DL     0:00.33 [g_down]
    5  ??  DL     0:00.00 [crypto]
    6  ??  DL     0:00.00 [crypto returns]
    7  ??  DL     0:00.00 [xpt_thrd]
    8  ??  DL     0:00.00 [kqueue taskq]
    9  ??  DL     0:00.00 [acpi_task_0]
   10  ??  RL    34:12.42 [idle: cpu0]
   11  ??  WL     0:01.13 [swi4: clock sio]
   12  ??  WL     0:00.00 [swi3: vm]
   13  ??  WL     0:00.00 [swi1: net]
   14  ??  DL     0:00.04 [yarrow]
   15  ??  WL     0:00.00 [swi6: task queue]
   16  ??  WL     0:00.00 [swi2: cambio]
   17  ??  DL     0:00.00 [acpi_task_1]
   18  ??  DL     0:00.00 [acpi_task_2]
   19  ??  WL     0:00.00 [swi5: +]
   20  ??  DL     0:00.01 [thread taskq]
   21  ??  WL     0:00.00 [swi6: Giant taskq]
   22  ??  WL     0:00.00 [irq9: acpi0]
   23  ??  WL     0:00.09 [irq14: ata0]
   24  ??  WL     0:00.11 [irq15: ata1]
   25  ??  WL     0:00.57 [irq11: ed0 uhci0]
   26  ??  DL     0:00.00 [usb0]
   27  ??  DL     0:00.00 [usbtask-hc]
   28  ??  DL     0:00.00 [usbtask-dr]
   29  ??  WL     0:00.01 [irq1: atkbd0]
   30  ??  WL     0:00.00 [swi0: sio]
   31  ??  DL     0:00.00 [sctp_iterator]
   32  ??  DL     0:00.00 [pagedaemon]
   33  ??  DL     0:00.00 [vmdaemon]
   34  ??  DL     0:00.00 [idlepoll]
   35  ??  DL     0:00.00 [pagezero]
   36  ??  DL     0:00.01 [bufdaemon]
   37  ??  DL     0:00.00 [vnlru]
   38  ??  DL     0:00.14 [syncer]
   39  ??  DL     0:00.01 [softdepflush]
 1221  ??  Is     0:00.00 /sbin/devd
 1289  ??  Is     0:00.01 /usr/sbin/syslogd -ss -f /var/etc/syslog.conf
 1608  ??  Is     0:00.00 /usr/sbin/cron -s
 1692  ??  Ss     0:00.03 /usr/local/sbin/mDNSResponderPosix -b -f /var/etc/mdn
 1730  ??  S      0:00.43 /usr/local/sbin/lighttpd -f /var/etc/lighttpd.conf -m
 1882  ??  DL     0:00.00 [system_taskq]
 1883  ??  DL     0:00.00 [arc_reclaim_thread]
 4139  ??  S      0:00.03 /usr/local/bin/php /usr/local/www/exec.php
 4144  ??  S      0:00.00 sh -c ps ax
 4145  ??  R      0:00.00 ps ax
 1816  v0  Is     0:00.01 login [pam] (login)
 1818  v0  I+     0:00.03 -tcsh (csh)
 1817  v1  Is+    0:00.00 /usr/libexec/getty Pc ttyv1
 1402 con- I      0:00.00 /usr/local/sbin/afpd -F /var/etc/afpd.conf
 1404 con- S      0:00.00 /usr/local/sbin/cnid_metad
 1682 con- I      0:02.78 /usr/local/sbin/mt-daapd -m -c /var/etc/mt-daapd.conf
 1789 con- S      0:00.18 /usr/local/bin/fuppesd --config-dir /var/etc --config

Фрагмент Libvert

<domain type='kvm'>
  <name>freenas</name>
  <uuid>********-****-****-****-************</uuid>
  <memory>524288</memory>
  <currentMemory>524288</currentMemory>
  <vcpu>1</vcpu>
  <os>
    <type arch='x86_64' machine='pc-0.12'>hvm</type>
    <boot dev='hd'/>
  </os>
  <features>
    <acpi/>
    <apic/>
    <pae/>
  </features>
  <clock offset='utc'/>
  <on_poweroff>destroy</on_poweroff>
  <on_reboot>restart</on_reboot>
  <on_crash>restart</on_crash>
  <devices>
    <emulator>/usr/bin/kvm</emulator>

Это возможно? В идеале я хотел бы иметь возможность останавливать хост без необходимости вручную закрывать виртуальную машину.

Я нашел единственный способ заставить это работать - передать параметр -no-kvm-irqchip в kvm. Самый простой способ сделать это в libvirt - создать сценарий-оболочку (например, / usr / local / bin / kvmbsd)

#!/bin/sh
exec /usr/bin/kvm "$@" -no-kvm-irqchip

И измените строку эмулятора в вашей конфигурации libvirt, чтобы она указывала на сценарий оболочки.

/usr/local/bin/kvmbsd

Это позволяет мне чисто завершить работу (но не перезагрузить - похоже, это еще не реализовано в libvirt / kvm) мою виртуальную машину на основе freebsd.

Убедитесь, что на виртуальной машине включен ACPI, это то, что делает чистое завершение работы - отправляет вызов ACPI. Однако есть и другие способы, такие как создание сценария для команды выключения через ssh, использование monitorCommand sendKey для отправки нажатия клавиши, предназначенной для инициирования выключения, выполнение команды "уничтожить" (по сути, вытягивание плагина) и т. Д.