VirtualBox 시스템을 자동으로 시작하고 종료하는 방법은 무엇입니까?


52

전용 컴퓨터에 어플라이언스로 설치하기위한 소프트웨어 시스템을 실행해야합니다. 에너지를 절약하기 위해 VirtualBox VM에서 시스템을 대신 실행할 계획입니다.

호스트는 SysV-Init 시스템이있는 표준 Linux 박스이며 게스트는 크게 수정 된 Linux이므로 더 이상 변경하지 않아도됩니다. VirtualBox는 OSE 버전에서 사용됩니다.

호스트 부팅시 VM을 시작하는 방법을 이미 알아 냈습니다 ( 편집 : Nikhil이 아래에서 언급 한 것처럼 명령을 통해 수행 됨 VBoxManager startvm) 어떻게 VM을 정상적으로 종료 할 수 있습니까? 호스트에서 실행중인 모든 스크립트는 게스트가 완전히 종료 될 때까지 기다려야합니다.

예를 들어 이것을 수행하는 서비스 파일이 어떻게 보일지를 제안 할 수 있습니까?


부팅하는 동안 가상 머신을 시작하도록 시작 스크립트를 제공 할 수 있습니까
초보자 초보자

답변:


34

acpipowerbutton이 명령 세트 를 사용해 보셨습니까 ?

VBoxManage controlvm        <uuid>|<name>
                            pause|resume|reset|poweroff|savestate|
                            acpipowerbutton|acpisleepbutton|

주석을 읽은 후 편집하십시오.

당신은 사용할 수 있습니다 acpid또는 다른 ACPI 유틸리티는 우아하게. 또한 현재 시스템을 종료하는 방법에 대한 자세한 정보를 제공 할 수 있습니까?

평범한 shutdown미완료 작업을 기다리지 않으면 시간 지연이 너무 길 수 있습니다.

나는 당신이 그렇게하려고 윈도우 매니저를 사용하지 않는 가정 도구를.

이 데몬을 보았습니다 . 유용 할 수 있습니다.


답장을 보내 주셔서 감사합니다. unix.stackexchange.com에 오신 것을 환영합니다! 그러나 귀하의 답변으로도 내 문제를 해결하지 못할 것입니다. acpipowerbutton은 실제 컴퓨터에서 전원 버튼을 누르는 것을 시뮬레이션하지만 호스트 에서이 명령을 실행하면 VM이 다시 종료하는 데 시간이 걸립니다.
jstarek

4
확실한. 따라서 VM이 여전히 실행 중인지 확인하는 루프를 작성해야합니다. ACPI는이를 위해 스크립트에서 사용하는 것과 정확히 동일한 방법입니다. vboxmanage list runningvmsVM이 사라질 때까지
Nils

좋아, 나는 실제로 관리 래퍼에 정착 할 것이라고 생각하지만, initscript를 가리 키기 위해 당신에게 +50!
jstarek

16

이를 직접 코딩하는 대신 가상 상자 인스턴스를 인스턴스화하고 제어하기 위해 구축 된 Vagrant 사용을 고려하십시오 . 문서는 훌륭하므로 직접 롤백하지 말고 확인하는 것이 좋습니다.

짧고 간단한 것은 간단한 제어 파일을 만든 다음 vagrant up원하는만큼 VirtualBox 인스턴스를 시작하도록 실행 한다는 것입니다. vagrant ssh호스트에 로그인하고 호스트 vagrant halt를 종료하지 않고 종료 하는 데 사용할 수 있습니다 . vagrant destroy인스턴스를 제거합니다.

퍼펫, Ansible 또는 Chef를 사용한 프로비저닝을 지원하며 노출 된 VBox 구성 설정을 대부분 제어 할 수 있습니다.


2
나는 유랑의 팬이지만이 경우 지구상에서 무엇을 원하십니까? OP는 자체 시스템을 구축하지 않고 어플라이언스를 실행하고 있으므로 프로비저닝은 그 요점을 완전히 놓치지 않습니다. 그리고 기본적으로 virtualbox로 시스템을 구축하는 과정을 거칠 때 방랑자를 사용하는 이유는 무엇입니까?
mc0e

10

한 가지 차이점을 제외하고는 비슷한 응용 프로그램이 있습니다. 시스템을 다시 시작하고 스냅 샷에서 복구해야합니다.

관심있는 것은 headless-mode 입니다.

그러한 서비스가 몇 가지 있으므로 다음 스크립트를 사용합니다.

VBox_StopRestoreStart.sh

#!/bin/bash
if [ -z "$1" ]; then
        echo "Usage: $0 VMNAME_or_UUID"
        exit 1
fi
set -x
VBoxManage controlvm  "$1" poweroff  #enforce turnoff
VBoxManage snapshot   "$1" restorecurrent   #retore state
VBoxManage showvminfo "$1" | grep State   #display state to ensure
VBoxHeadless -s       "$1"  #run in headless mode in background

VM을 정상적으로 종료하려면 어떻게해야합니까?

VM을 정상적으로 끄려면 응용 프로그램에 따라 두 가지 옵션이 있습니다.

  • "종료 버튼" 또는 "슬립 버튼"을 에뮬레이션 하고 VM이 반응하도록 준비 (정상적으로 종료)
    • VBoxManage controlvm <uuid>|<VMname> acpipowerbutton
    • VBoxManage controlvm <uuid>|<VMname> acpisleepbutton
  • 나중에 복원하기 위해 VM 상태 저장
    • VBoxManage controlvm <uuid>|<VMname> savestate

팁 : 유용한 정보는 다음과 같습니다.

  • VBoxManage list vms -사용 가능한 vms 목록
  • rdesktop IP-ADDR:3389또는 rdesktop-vrdp IP-ADDR:3389- 헤드리스 모드로 실행할 때 GUI를 원할 때 ( 원격 에서도 ) :VBoxHeadless -s <uuid>|<VMname>
  • VBoxManage startvm -로컬 디버깅을위한 GUI로 시작

관련 VirtualBox 매뉴얼 장 : 7 장. 원격 가상 머신-단계별 : 헤드리스 서버에서 가상 머신 작성

PS 이미 구현 된 모든 기능을 갖춘 솔루션에 관심이 있다면 OpenStack 은 흥미로운 선택입니다.


10

http://www.virtualbox.org/manual/ch08.html 에서 VirtualBox VM 관리 설명서를 보면

VM을 나열하려면 다음 명령을 사용하십시오. VBoxManage list vms

VM을 시작하려면 다음 명령을 사용하십시오. VBoxManage startvm

http://www.virtualbox.org/manual/ch08.html#vboxmanage-controlvm

VM을 제어하려면 VBoxManage controlvm

controlvm부속 명령은 현재 실행중인 가상 머신의 상태를 변경할 수 있습니다. 다음을 지정할 수 있습니다.

VBoxManage controlvm <vm> pause상태를 변경하지 않고 가상 머신을 일시적으로 보류 상태로 만듭니다. VM 창은 회색으로 칠해져 VM이 현재 일시 중지되었음을 나타냅니다. (이것은 GUI의 "기계"메뉴에서 "일시 정지"항목을 선택하는 것과 같습니다.)

VBoxManage controlvm <vm> resume이전 일시 중지 명령을 실행 취소하는 데 사용 합니다. (이것은 GUI의 "기계"메뉴에서 "재개"항목을 선택하는 것과 같습니다.)

VBoxManage controlvm <vm> reset실제 컴퓨터에서 "재설정"단추를 누르는 것과 같은 가상 컴퓨터의 효과는 가상 컴퓨터의 콜드 재부팅으로 게스트 운영 체제를 다시 시작하고 즉시 다시 부팅합니다. VM의 상태는 미리 저장되지 않으며 데이터가 손실 될 수 있습니다. (이것은 GUI의 "기계"메뉴에서 "재설정"항목을 선택하는 것과 같습니다.)

VBoxManage controlvm <vm> poweroff실제 컴퓨터에서 전원 케이블을 뽑는 것과 가상 시스템에 동일한 영향을 미칩니다. 다시 말하지만 VM의 상태는 미리 저장되지 않으며 데이터가 손실 될 수 있습니다. (이것은 GUI의 "기계"메뉴에서 "닫기"항목을 선택하거나 창의 닫기 버튼을 누른 다음 대화 상자에서 "기기 전원 끄기"를 선택하는 것과 같습니다.)

그런 다음 VM의 상태는 "전원이 꺼집니다".


일부 시스템에서는 vboxmanage(모두 소문자)입니다.
Arcege

2
답장을 보내 주셔서 감사하지만 안타깝게도이 문제는 해결되지 않습니다 . 게스트 를 정상적으로 종료 해야합니다 . 즉, 게스트 내부에 "shutdown -h now"를 발행 하고 게스트가 완전히 종료 될 까지 호스트를 기다리도록 해야합니다 . 어떤 VBoxManage controlvm하위 명령도 그렇게하지 않습니다.
jstarek

호스트가 다운되기 전에 호스트에서 모든 vms가 다운되었는지 다시 확인하여 확인할 수 있습니다. 게스트 내부에서 호스트를 제어해야하는 경우 virtualbox.org/manual/ch08.html#vboxmanage-guestcontrol 이지만 원하는 것을 제공하지 못할 수 있습니다. /etc/init.d/vboxvms-service호스트 시스템에서 스크립트와 같은 시작 스크립트를 작성해야합니다. 시작시 모든 vms를 설정하고 중지하면 모든 vms가 중단됩니다.
Nikhil Mulley

VBoxManage controlvm savestate또 다른 가능성이 있습니다 (적어도 구글은 나에게 알려줍니다). 시스템 상태를 저장하고 깨끗하게 종료하지만 여전히 호스트를 기다리게 할 방법은 없습니다.
Baarn

5

시스템 기반 시스템의 경우이를 시도 할 수 있습니다.

1 단계 : 서비스 파일 작성

[Unit]
Description=VBox Virtual Machine %i Service
Requires=systemd-modules-load.service
After=systemd-modules-load.service

[Service]
User=user
Group=vboxusers
ExecStart=/usr/bin/VBoxHeadless -s %i
ExecStop=/usr/bin/VBoxManage controlvm %i savestate

[Install]
WantedBy=multi-user.target

2 단계 : 서비스 파일 사용

$ sudo systemctl enable vboxvmservice@vm_name.service

참고 문헌


1
여기 에 답변 을 포함 하고 선택적 으로 더 자세한 정보에 대한 링크를 제공 하는 것이 좋습니다 . 링크 대상은 예고없이 사라져서 답을 쓸모 없게 만듭니다.
Anthon

글쎄, 문제는 전체 시스템 파일을 여기 링크 1에 실제로 복사 할 수 없다는 것입니다.
Jan Rüegg 2018 년

글쎄, 불행히도 "링크 썩음 (link rot)"은 이런 경우에 큰 문제입니다 ... 후손을 위해 다음 두 줄이 링크의 기본 개념을 포착한다고 생각합니다 . VM VBoxHeadless -s %i을 시작하고 VBoxManage controlvm %i savestate중지 하는 데 사용되는 서비스를 만들고 있습니다.
jstarek

데비안 제시에서 이것을 시도했지만 작동하지 않았습니다. 사용자 및 그룹을 생성하고 모든 파일의 소유권을 설정합니다 (/ dev / vbox * 포함). 그러나 서비스가 시작되면 이름이 맞더라도 VM을 찾을 수 없습니다. 결국 일반 초기화 스크립트를 사용합니다.
mivk

3

ssh를 통해 호스트에서 게스트로 명령을 보내는 방법은 무엇입니까?

그것이 작동하는지 확실하지 않으며 나중에 기계의 상태를 확인하거나 출구 상태와 같은 것을 얻을 수 있는지는 모르겠지만 적어도 깨끗하게 내려야합니다.


좋은 생각이지만 호스트의 네트워크를 통해 게스트 VM에 연결할 수 있으며 ssh 포트 (22)가 가장 적어야합니다.
Nikhil Mulley

기본적으로 이것은 작동하며, DNS 항목을 통해 전체 LAN에서 어플라이언스에 도달 할 수 있습니다. 그러나 호스트가 다운 될 때마다 어플라이언스에 ssh'd 스크립트를 작성했다고 가정합니다. 게스트가 완전히 종료 될 때까지 여전히 차단 (일시 중지)해야합니다. 이것이 바로 내 질문의 요점입니다. 게스트가 다운되었을 때 스크립트가 어떻게 알 수있어 SysV-Init 로의 제어 흐름을 되돌릴 수 있고 호스트가 계속 종료 될 수 있습니까?
jstarek

1
귀하의 의견은 모든 것이 게스트 시스템이 아닌 호스트 시스템에서 원활하게 작동한다고 가정합니다. 호스트 시스템에 전원 케이블이 연결되어 있으면 어떻게합니까? 다른 토론입니다. 호스트 스크립트의 SysV-init는 서비스 스크립트가 게스트 VM을 올바른 방식으로 종료 (원격 호스트에서 종료하거나 vbox 인터페이스를 통해 종료)하는 논리를 이해하는 한 서비스 스크립트가 VM을 중지 할 때까지 기다립니다. 그런 다음 yield 또는 성공 상태를 콘솔 또는 init로 되돌립니다.
Nikhil Mulley

1
관련 : 게스트가 다운되었을 때 스크립트가 어떻게 알 수 있는지, VboxManager 인터페이스에서 vm이 켜져 있는지 여부와 게스트가 ssh'able인지 간단한 확인을 시도하십시오. 또한 Vboxmanager에서 VM을 사용할 수 있고 적시에 VM을 사용할 수 있는지 여부를 수행하는 호스트 시스템에 모니터링을 추가하십시오.
Nikhil Mulley

1

내 솔루션 :이 셸 스크립트에서 'root'는 호출자이며 'theuser'는 'thevm'의 소유자입니다.

명령의 출력이 VBoxManage list runningvms빈 문자열을 반환 할 때 vms가 종료되었음을 알고 있습니다.

...
start(){
    su -c "VBoxHeadless --startvm thevm" -s /bin/bash theuser &
    # maybe another vbox command
}

stop(){
    su -c "VBoxManage controlvm thevm acpipowerbutton" -s /bin/bash theuser
    # maybe another vbox command
    while [ "`su -c 'VBoxManage list runningvms' -s /bin/bash theuser`" != "" ]
    do
        echo waiting for VMs to shutdown
        sleep 3
    done
}
...

1

vm을 시작하려면

VBoxManage startvm VMNAME --type headless

vm을 중지하려면 다음을 수행하십시오.

VBoxManage controlvm VMNAME savestate

실행중인 모든 VM을 나열하십시오.

VBoxManage list runningvms

0

아마도 이것은 솔루션의 일부로 도움이 될 것입니다.

VBoxManage list runningvms | tr -s '\" {' '%{' | cut -d '%' -f3  | while read uuid; do
   VBoxManage controlvm $uuid savestate; 
done

0

당신은 왜 당신의 손님에 로그인하고 거기서 종료하지 않습니까?

sshd를 설치하지 않고 VBox를 통해 실제로 VM에 액세스해야 할 합당한 이유가 없다면 ssh shutdown -h now. 솔직히 말해서, 나는 모든 시스템에 대해 스크립트를 올바르게 종료하고 검사를 수행하는 스크립트를 작성했습니다.

호스트에서 다른 스크립트를 호출하는 /etc/init.d/shutdown_vm 스크립트를 압축하면 준비가 될 때까지 호출이 차단됩니다. 설명 된대로이 프로세스는 게스트에서 Linux 종속성을 추가하지만 호스트에서 VBox 종속성을 제거합니다.

체이스 컷 : 머신을 종료하기 위해 VBox에 액세스 할 필요가 없습니다. 머신에 액세스 할 수있는 방법이 있다면 (예 : ssh) OS는 항상 그에 대한 몇 가지 수단을 갖습니다 (켜기 만하면됩니다)


두 가지 이유 : 첫째, 원래 질문에서 언급했듯이 크게 수정되지 않은 게스트 OS가 실제로 필요하지 않은 경우 변경하고 싶지 않았습니다. 둘째, 더 중요한 것은 호스트가 종료 된 경우 실행중인 모든 VM을 자동으로 종료하는 깔끔한 방법을 제공하기위한 것입니다.
jstarek

@jstarek 그러나 원치 않는 경우 게스트 OS를 수정할 필요가 없습니다 (99.99 %의 시간이 로그인 할 수 있거나 예외입니다). 그리고 그것이 바로 아이디어입니다. 호스트가 다운되면 런타임을 변경할 때 적절한 스크립트가 호출되고 게스트에 로그인하고 "내부"에서 종료합니다. 어쨌든 방랑자가하는 것입니다. 힘 "즉 ...
estani
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.