Provided by: guestmount_1.52.2-3ubuntu2_amd64
НАЗВА
guestunmount — демонтування змонтованої за допомогою guestmount файлової системи
КОРОТКИЙ ОПИС
guestunmount точка_монтування guestunmount --fd=<дескрипто_файла> точка монтування
ОПИС
guestunmount — програма для автоматичного вилучення змонтованих файлових систем. guestmount(1) монтує файлові системи за допомогою libguestfs. Ця програма демонтує файлову систему, коли програма або скрипт завершує роботу з нею. guestunmount є обгорткою навколо програми FUSE fusermount(1), яка має зберігатися у одному з каталогів, вказаних за допомогою поточної змінної "PATH". Існує два способи використання guestunmount. Якщо програму викликано так: guestunmount точка_монтування вона демонтує точку монтування "точка_монтування" негайно. Якщо ж програму викликано так: guestunmount --fd=FD точка_монтування програма чекатиме, аж доки не буде закрито дескриптор файла "FD" каналу. Цим можна скористатися для спостереження за іншим процесом і вилучення точки монтування після завершення роботи процесу, як це описано нижче. З ПРОГРАМ Ви можете просто викликати "guestunmount точка_монтування" з програми, але розумніше було б скористатися guestunmount так, щоб ця програма спостерігала за вашою програмою і вилучала точку монтування, якщо програма неочікувано завершить роботу. У програмі створіть канал обробки (наприклад, за допомогою виклику pipe(2)). Нехай "FD" є номером дескриптора файла з боку читання у каналі (тобто "pipefd[0]"). Після монтування файлової системи за допомогою guestmount(1) (до точки монтування "точка_монтування") виконайте відгалуження (fork) і запустіть guestunmount ось так: guestunmount --fd=FD точка_монтування Закрийте бік читання у каналі обробки у батьківському процесі. Тепер, коли з якоїсь причини буде закрито бік запису у каналі (тобто "pipefd[1]"), явно або у результаті завершення роботи батьківського процесу, guestunmount зауважить це і демонтує точку монтування. Якщо у вашій операційній системі передбачено підтримку цього, вам слід встановити прапорець "FD_CLOEXEC" на боці запису у каналі. Таким чином ви забороните іншим дочірнім процесам успадковувати дескриптор файла і тримати його відкритим. Guestunmount ніколи не перетворюється на фонову службу. ЗІ СКРИПТІВ ОБОЛОНКИ Оскільки у bash не передбачено способу створення неіменованого каналу обробки, скористайтеся trap для виклику guestunmount при виході, ось так: trap "guestunmount точка_монтування" EXIT INT QUIT TERM
ПАРАМЕТРИ
--fd=FD Вкажіть дескриптор файла каналу для спостереження і відкладіть вилучення до закриття каналу. --help Показати короткі довідкові дані і завершити роботу. -q --quiet Не показувати повідомлень про помилки від fusermount. Стан повернення все одно буде встановлено (див. "СТАН ВИХОДУ" нижче). --no-retry --retry=N Типово, guestunmount виконуватиме повторні спроби fusermount аж до 5 разів (тобто загалом буде виконано 6 спроб = 1 перша спроба + 5 повторних спроб). Скористайтеся параметром --no-retry, щоб наказати guestunmount запускати fusermount лише один раз. Скористайтеся параметром --retry=N, щоб наказати guestunmount виконувати "N" повторних спроб замість 5. guestunmount збільшує час між спробами експоненційно, очікуючи 1 секунду, 2 секунди, 4 секунди тощо перед кожною повторною спробою. -V --version Показати дані щодо версії програми, потім вийти.
ЗМІННІ СЕРЕДОВИЩА
"PATH" Програма fusermount(1) (є частиною комплекту FUSE) має зберігатися у одному з каталогів, вказаних за допомогою поточної змінної "PATH".
СТАН ВИХОДУ
Ця програма повертає значення 0 у разі успішного завершення або один із таких кодів помилок: 1 Помилка програми, наприклад, не вдалося отримати достатній обсяг пам'яті, не вдалося запустити fusermount. Щоб дізнатися більше, ознайомтеся із виведеним повідомленням про помилку. 2 Не вдалося демонтувати точку монтування навіть після повторних спроб. Дані щодо базової помилки fusermount буде показано у виведеному повідомленні про помилку. 3 Точку монтування не змонтовано.
ТАКОЖ ПЕРЕГЛЯНЬТЕ
guestmount(1), fusermount(1), pipe(2), "ЛОКАЛЬНЕ МОНТУВАННЯ" in guestfs(3), http://libguestfs.org/, http://fuse.sf.net/.
АВТОРИ
Richard W.M. Jones ("rjones at redhat dot com")
АВТОРСЬКІ ПРАВА
© Red Hat Inc., 2013
LICENSE
BUGS
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: • The version of libguestfs. • Where you got libguestfs (eg. which Linux distro, compiled from source, etc) • Describe the bug accurately and give a way to reproduce it. • Run libguestfs-test-tool(1) and paste the complete, unedited output into the bug report.