virt-rescue(1) | Virtualization Support | virt-rescue(1) |
virt-rescue — запуск оболонки відновлення у віртуальній машині
virt-rescue [--параметри] -d назва_домену virt-rescue [--параметри] -a диск.img [-a диск.img ...] [-i]
Старий стиль:
virt-rescue [--параметри] назва_домену virt-rescue [--параметри] диск.img [диск.img ...]
virt-rescue — є образом компакт-диска для порятунку системи, але призначеним для віртуальних машин. Його особливістю також є те, що для роботи йому не потрібен фізичний носій. virt-rescue надає у ваше розпорядження командну оболонку порятунку системи та деякі прості інструменти, якими ви можете скористатися для аналізу і виправлення віртуальної машини або образу диска.
Ви можете запускати virt-rescue для будь-якої віртуальної машини, відомої libvirt, або безпосередньо для образів дисків:
virt-rescue -d Назва_гостьової_системи -i virt-rescue --ro -a /шлях/до/диск.img -i virt-rescue -a /dev/sdc
Для активних віртуальних машин вам слід використовувати параметр --ro.
При роботі з virt-rescue над віртуальною машиною або образом диска ви матимете справу із інтерактивною командною оболонкою bash, у якій можна скористатися багатьма звичайними командами Linux. Те, що зберігатиметься у / (/bin, /lib тощо) є рятівною базовою системою. Для роботи з файловими системами віртуальної машини вам слід їх змонтувати. Для монтування файлових систем передбачено порожній каталог із назвою /sysroot.
Щоб автоматично змонтувати файлові системи віртуальної машини до /sysroot, скористайтеся параметром -i. У відповідь програма використає засоби інспектування libguestfs для виявлення файлових систем і монтування їх до належних каталогів. Ви також можете змонтувати окремі файлові системи за допомогою параметра -m.
Іншим способом монтування є отримання списку логічних томів (за допомогою lvs(8)) і розділів (за допомогою parted(8)) і монтування їх вручну:
><rescue> lvs LV VG Attr LSize Origin Snap% Move Log Copy% Convert lv_root vg_f15x32 -wi-a- 8.83G lv_swap vg_f15x32 -wi-a- 992.00M ><rescue> mount /dev/vg_f15x32/lv_root /sysroot ><rescue> mount /dev/vda1 /sysroot/boot ><rescue> ls /sysroot
Іншою програмою для побудови списку доступних файлових систем є virt-filesystems(1).
Для запуску програм у гостьовій системі Linux (наприклад, програми grub) вам слід спочатку змінити кореневий каталог на /sysroot:
><rescue> chroot /sysroot
Virt-rescue можна використовувати для будь-якого файла образу диска або пристрою, не лише для віртуальної машини. Наприклад, ви можете скористатися програмою для порожнього файла, якщо хочете додати розділ у цей файл (втім, ми рекомендуємо для цього користуватися guestfish(1), оскільки цю програму краще пристосовано для виконання подібних завдань). Ви навіть можете використовувати virt-rescue для роботи з дисками USB, картками SD та жорсткими дисками.
Ви можете наказати virt-rescue створити для вас тестовий диск. Це корисно для тестування інструментів Linux (див. --scratch).
Для роботи virt-rescue не потрібні права користувача root. Вам знадобляться права доступу root, лише якщо вам потрібні права root для відкриття образу диска.
Цю програму було розроблено для швидкої інтерактивної роботи з віртуальною машиною. Для структурованішого доступу до образу диска віртуальної машини варто використовувати guestfs(3). Структурованою командною оболонкою для внесення змін до гостьової системи за певним сценарієм є guestfish(1).
Формат образу диска визначається автоматично. Щоб перевизначити його і примусово використати певний формат, скористайтеся параметром --format=...
Якщо вказати блокові пристрої гостьових систем безпосередньо (-a), libvirt не буде використовуватися взагалі.
Див. "КЛАВІША ЕКРАНУВАННЯ" нижче, щоб дізнатися більше.
Приклад:
virt-rescue --format=raw -a диск.img
примусове встановлення формату без обробки (без автоматичного визначення) для disk.img.
virt-rescue --format=raw -a диск.img --format -a інший.img
примусове встановлення формату без обробки (без автоматичного визначення) для diskimg і повернення до автоматичного визначення для another.img.
Якщо ви користуєтеся ненадійними образами гостьових систем у необробленому форматі, вам слід скористатися цим параметром для визначення формату диска. Таким чином можна уникнути можливих проблем з захистом для сформованих зловмисниками гостьових систем (CVE-2010-3851).
Файлові системи у середовищі порятунку системи монтуються до /sysroot.
Якщо точку монтування не вказано, типовим значенням є /. Вам слід змонтувати щось до /.
Файлові системи у середовищі порятунку системи монтуються до /sysroot.
Третьою (і нечасто використовуваною) частиною параметра монтування є список параметрів монтування, які використовуються для того, щоб змонтувати підлеглу файлову систему. Якщо такий список не буде задано, параметрами монтування вважатиметься або порожній рядок, або "ro" (другий варіант використовується, якщо використано прапорець --ro). Заданням параметрів монтування ви перевизначаєте типовий варіант. Ймовірно, єдиним випадком, коли вам може знадобитися це, є випадок вмикання списків керування доступом (ACL) і/або розширених атрибутів, якщо у файловій системі передбачено їхню підтримку:
-m /dev/sda1:/:acl,user_xattr
Четвертою частиною параметра є назва драйвера файлової системи, якою слід скористатися, зокрема "ext3" або "ntfs". У визначенні цієї частини параметра рідко виникає потреба, але вона може бути корисною, якщо для файлової системи можна скористатися декількома драйверами (приклад: "ext2" і "ext3"), або libguestfs визначає файлову систему помилково.
Цей параметр слід завжди використовувати, якщо образ диска або віртуальна машина може працювати. Загалом, рекомендуємо використовувати його у випадках, коли вам не потрібен доступ на запис до диска.
Див. також "OPENING DISKS FOR READ AND WRITE" in guestfish(1).
Ви також можете поєднувати параметри -a, -d і --scratch. Тестові диски додаються до базової системи у порядку, у якому їх було вказано у рядку команди.
Цей параметр неявно використовує --ro і є безпечним для використання, навіть якщо гостьова система працює або запущено інший екземпляр virt-rescue.
Див. "OPENING DISKS FOR READ AND WRITE" in guestfish(1).
У попередніх версіях virt-rescue можна було скомандувати ось так:
virt-rescue disk.img [disk.img ...]
або
virt-rescue назва_гостьової_системи
тоді як у цій версії вам слід скористатися -a або -d, відповідно, щоб уникнути помилок у випадках, коли назва образу диска може збігатися із назвою гостьової системи.
З міркувань зворотної сумісності передбачено підтримку запису параметрів у застарілому форматі.
Додавання параметра --network вмикає для користувача мережу QEMU у базовій системі для порятунку. Існують певні відмінності між звичайною роботою у мережі і роботою у мережі для користувача:
exec 3<>/dev/tcp/redhat.com/80 echo "GET /" >&3 cat <&3
Докладніше про це тут: bash(1).
У virt-rescue передбачено підтримку різноманітних клавіатурних комбінацій із клавішею екранування, які вводяться натисканням "^]" (клавіші Ctrl і клавіші "]").
Змінити клавішу екранування можна за допомогою параметра -e рядка команди (див. вище). Повністю вимкнути клавішу екранування можна за допомогою параметра -e none. У решті цього розділу ми припускаємо, що працює типова клавіша екранування.
Можна використовувати такі клавіші:
Якщо ви працюєте з якоюсь програмою у virt-rescue, і програма (не virt-rescue) завершує роботу у аварійному режимі, перехопити дамп ядра програми поза virt-rescue для подальшого аналізу є доволі складним завданням. У цьому розділі описано один спосіб, у який можна досягти виконання цього завдання.
truncate -s 4G /tmp/corefiles virt-format --partition=mbr --filesystem=ext2 -a /tmp/corefiles virt-filesystems -a /tmp/corefiles --all --long -h
virt-rescue --rw [-a ...] -a /tmp/corefiles
NB. Якщо ви використовуєте параметр --ro, virt-rescue без додаткових питань не записуватиме ніяких файлів дампів ядра до /tmp/corefiles.
><rescue> mkdir /tmp/mnt ><rescue> mount /dev/sdb1 /tmp/mnt
><rescue> echo '/tmp/mnt/core.%p' > /proc/sys/kernel/core_pattern ><rescue> ulimit -Hc unlimited ><rescue> ulimit -Sc unlimited
><rescue> ls -l /tmp/mnt total 1628 -rw------- 1 root root 1941504 Dec 7 13:13 core.130 drwx------ 2 root root 16384 Dec 7 13:00 lost+found
><rescue> umount /tmp/mnt ><rescue> exit
guestfish --ro -a /tmp/corefiles -m /dev/sda1 ><fs> ll / ><fs> download /core.NNN /tmp/core.NNN
На роботу virt-rescue впливають декілька змінних середовища. Повний список змінних наведено у розділі "ЗМІННІ СЕРЕДОВИЩА" in guestfs(3).
Див. libguestfs-tools.conf(5).
guestfs(3), guestfish(1), virt-cat(1), virt-edit(1), virt-filesystems(1), libguestfs-tools.conf(5), http://libguestfs.org/.
Richard W.M. Jones http://people.redhat.com/~rjones/
Copyright (C) 2009-2023 Red Hat Inc.
To get a list of bugs against libguestfs, use this link: https://bugzilla.redhat.com/buglist.cgi?component=libguestfs&product=Virtualization+Tools
To report a new bug against libguestfs, use this link: https://bugzilla.redhat.com/enter_bug.cgi?component=libguestfs&product=Virtualization+Tools
When reporting a bug, please supply:
2024-01-05 | libguestfs-1.52.0 |