Linux : SATA hot plug / unplug
I have 3 hard disks in SATA-to-eSATA external enclosure which I occasionally need to plug to perform backups and to unplug when done. I found it annoying to have to restart the whole computer at every turn, especially when SATA is supposed to bring hotplug abilities. If you mainboard / SATA chipset and disks support hot plugging and unplugging, you can do this by following those instructions.
Hot plug : Scanning for newly added disks
When you plug the disks, you need to tell the OS to scan for new SATA devices, you do this with the following command :
Here “host0” is the SATA channel you want to scan, so you obviously need to replace that by the appropriate channel number. Linux will then hopefully discover the newly attached disk.
Hot unplug : safely removing a disk
First thing, you need to unmount all the mounted filesystems which are residing on the disk you wish to disconnect.
Once this is done, you need to instruct Linux to flush all data still in memory to the disk and then to disconnect it. You do this by issuing the following command :
At this point you’ll usually hear the “click” of the drive spinning down, and you can power off and disconnect it.
9 thoughts on “Linux : SATA hot plug / unplug”
Hi Stéphane,
thanks for sharing this.
If I would put the hotplug scan into a bash script, I would like to have the script wait, until “# fdsik -l” actually recognizes the newly added device / redo the scan until the device has been recognized.
Any ideas on how to do this?
Here are some hints to get you started :
1) here’s how to get the list of the attached disks : fdisk -l | grep ‘^/dev/sd’ | awk ‘
2) Do this at script start up, save result in a temp file
3) Run the command to discover new disks as described in the post
4) Get the disk list again. Is there a new disk (maybe use diff) ? Yes -> terminate. No -> sleep 10 sec and go to 3
Hope this helps ! (and hopefully I understood correctly what you need ;))
Great post dude! Was exactly what I was looking for though for the reverse reasons. I wanted a way to stop/hide the hard disk from the OS once it had loaded the live image in RAM, this was for a media centre I’m building.
Very cool, thanks for sharing. Not sure why this hasn’t been implemented to happen automatically since eSATA with hotplug support has been around for a while now.
Have you checked your BIOS settings? SATA hotplug does not (usually) work until you set BIOS to use AHCI for the chipsets; on most motherboards it is set to ‘ide-emulation’ or such by default.
And for further notes, even AHCI is enabled, some motherboards required to set a seprate option for SATA hotplugging.
Thank you for this posting – it helped me to replace fast one of my faulty SATA RAID disks on a running server.
Cheers 😉
I knew my motherboard and Linux kernel support SATA hotplugging, I enabled it but had no idea on how to use it. Thanks!
SATA hotplug
Интересна поддержка сабжа в железе. Вообще же SATA поддерживает hotplug, но первые интеловские мосты (кажись ICH5) его не поддерживали и это было описано. Сейчас искал инфу про новые чипы (тот же ICH10) и ничего не нашел. Потому вопрос: как сейчас с этим дела? Проверил у себя — вроде работает на ICH10R. Где-то кто-то говорил что в ICHxR поддерживается, а в ICHxx — нет.
Вопрос №2: как привильно вставлять/удалять устройства? Сначала вставлять питание, потом данные? Нужно ли что-то делать в линуксе перед удалением, кроме отмонтирования разделов?
Не путайте SATA и ATA. В SATA «из коробки» hotplug. Главное, отмонтировать диск не забыть, перед тем, как его отключать.
(hot pluggable) SATA/SCSI add/remove scripts for Linux
Re: (hot pluggable) SATA/SCSI add/remove scripts for Linux
При подключении сначала подключаем шлейф с данными, потом с питанием.
При отключении сначала отключаем шлейф с питанием, потом с данными.
При подключении сначала подключаем шлейф с данными, потом с питанием.
При отключении сначала отключаем шлейф с питанием, потом с данными.
Интересно. А почему так?
Спс. Надо такое в DE встроить.
Первый скрипт нужен только для старых SATA/SCSI контроллеров, которые нормативно не поддерживают hot plug (по факту поддерживают почти все, только они не посылают hotplug event’ы по dbus/hal’у, ибо контроллеры глупые).
Ага и он может понабиться, если у вас SATA в режиме IDE/compatible в BIOS стоит.
Re: (hot pluggable) SATA/SCSI add/remove scripts for Linux
Где проверка на примонтированность того что выключается?
Нафига вешать зависимости на два интерфейса когда можно всё через /sys сделать? И практика парсить форматированный выхлоп дебильная, ибо формат вывода изменили и скрипты полетели.
С какого боку ATA стало эквивалентно HDD? Про SSD, например, не слышали?
>Первый скрипт нужен только для старых SATA/SCSI контроллеров
Первый скрипт может понадобиться если в(вы)рубаешь устройство не вынимая его.
Re: (hot pluggable) SATA/SCSI add/remove scripts for Linux
> Где проверка на примонтированность того что выключается?
Я не нашёл как связать /proc/scsi/scsi с /dev/sdX, просто лень было — скрипт для меня родимого.
> Нафига вешать зависимости на два интерфейса когда можно всё через /sys сделать?
It’s a just quick hack.
> И практика парсить форматированный выхлоп дебильная, ибо формат вывода изменили и скрипты полетели.
и в sys оно тоже может поменяться.
> С какого боку ATA стало эквивалентно HDD? Про SSD, например, не слышали?
Полегче!! SSD — это уже не HDD? или вы как-то иначе их называете? 🙂
> Первый скрипт может понадобиться если в(вы)рубаешь устройство не вынимая его.
Можешь поиздеватся над вендузятниками — на рабочей машине внаглую отключаешь винт , а потом подключаешь — и ничего. Т.е. линукс как работал так и работает — лица у народа очень озадаченые. Естественно все это касается SATA винтов и линукса
Во время отключения винта в Линуксе попробуйте открыть хоть один незакэшированный файл — после этого система встаёт раком и ничего не помогает.
Может есче запустить компиляцию ядра с винта который отключен?
вообще hotplug работает только для AHCI как бы по стандарту.
>> на рабочей машине внаглую отключаешь винт , а потом подключаешь — и ничего
Ага, если только имя в /dev/ не сменится, что весьма вероятно.
>Ага, если только имя в /dev/ не сменится, что весьма вероятно.
если никаких скази устройств не пихать, то не сменится.
Весьма нормально работает:
echo 1 > /sys/block/sdh/device/delete
Переписано на sysfs
И да, вот так можно связать с именем блочного устройства.
Скрипты это не прикольно. Это ламерам можно показывать какой я крутой в консоли. А для личного удобства нужен гуй:)
Вы таки решительно не правы. Не буду флеймить насчет винды и привычек к мышковозительству, но скажу, что многие, очень многие вещи в консоли делать ЗНАЧИТЕЛЬНО быстрее и проще. Даже не обсуждаю сейчас вопрос «нах*я гуй на сервере», хотя тоже благодатная почва. Это, конечно, не значит, что гуй не нужен. Нужен. Но далеко не всегда и не везде.
Я даже больше скажу. В скриптах можно гуй сделать, представляете? Curses, или X11 — какой больше нравится (dialog, xdialog)
Даже не обсуждаю сейчас вопрос «нах*я гуй на сервере», хотя тоже благодатная почва.
+1, Нафиг не нужен. На сервере не влом и ручками в /sys записать.
Это, конечно, не значит, что гуй не нужен. Нужен. Но далеко не всегда и не везде.
Вы таки решительно не правы. Не буду флеймить насчет винды и привычек к мышковозительству, но скажу, что многие, очень многие вещи в консоли делать ЗНАЧИТЕЛЬНО быстрее и проще.
Не всегда. Два клика на каком-то device notifier’е против набора команды. В гуе тупо быстрее. Да, всего на секунды.
Я даже больше скажу. В скриптах можно гуй сделать, представляете? Curses, или X11 — какой больше нравится (dialog, xdialog)
Татышо. Я не хочу отдельную прогу, я хочу нормальную интеграфию в DE. Консольное решение и так есть, а гуя нету.