Windows не грузится grub

Обновлено: 07.07.2024

Решено: проблема с grub (не грузит windows из grub, но сам win рабочий)

Для новичков как вообще в Linux, так и в конкретной теме, к которой относится вопрос.

Модератор: Bizdelnick

Решено: проблема с grub

поставил openSuse 10.3, всё нормально встало настроил драйвера под что надо, сеть и т.п. вобщем полностью готовая рабочая система настроенная под себя, однако ж.
windows в grub сам прописался, однако при попытке загрузиться в виндоуз из grub
на экране висит только
rootnoverify (hd0,4)
chainloader (hd2,0)+1

и писискрипер пищит автоматной очередью.

если в биосе ставить загрузочным винтом диск с виндоуз, виндоуз нормально грузится. но не залазить же каждый раз в биос когда понадобится в win? в чём вообще может быть проблема?

конфигурация такая: на первом sata два раздела, один с виндоуз, другой так, для данных. ещё два винта ntfs один сата другой ide. и четвёртый ide под линукс.

если надо то вот чего fdisk -l выдаёт

Disk /dev/sda: 320.0 GB, 320072933376 bytes 255 heads, 63 sectors/track, 38913 cylinders Units = cylinders of 16065 * 512 = 8225280 bytes Disk identifier: 0x4efb4efa Device Boot Start End Blocks Id System /dev/sda1 * 1 1913 15366141 7 HPFS/NTFS /dev/sda2 1914 38913 297202500 f W95 Ext'd (LBA) /dev/sda5 1914 38913 297202468+ 7 HPFS/NTFS Disk /dev/sdb: 400.0 GB, 400088457216 bytes 255 heads, 63 sectors/track, 48641 cylinders Units = cylinders of 16065 * 512 = 8225280 bytes Disk identifier: 0x121e0bed Device Boot Start End Blocks Id System /dev/sdb1 1 48641 390708801 42 SFS Disk /dev/sdc: 120.0 GB, 120060444672 bytes 255 heads, 63 sectors/track, 14596 cylinders Units = cylinders of 16065 * 512 = 8225280 bytes Disk identifier: 0x2083bd6c Device Boot Start End Blocks Id System /dev/sdc1 1 262 2104483+ 82 Linux swap / Solaris /dev/sdc2 * 263 2873 20972857+ 83 Linux /dev/sdc3 2874 14596 94164997+ f W95 Ext'd (LBA) /dev/sdc5 2874 5484 20972826 83 Linux /dev/sdc6 5485 14596 73192108+ 83 Linux Disk /dev/sdd: 164.6 GB, 164696555520 bytes 255 heads, 63 sectors/track, 20023 cylinders Units = cylinders of 16065 * 512 = 8225280 bytes Disk identifier: 0xe39a68e1 Device Boot Start End Blocks Id System /dev/sdd1 1 20023 160834716 42 SFS

menu.lst выглядит так

ну и на всякий случай etc/fstab

/dev/disk/by-id/scsi-SATA_SAMSUNG_SP1203NS00QJ10Y184695-part5 / ext3 acl,user_xattr 1 1 /dev/disk/by-id/scsi-SATA_SAMSUNG_SP1203NS00QJ10Y184695-part6 /home ext3 acl,user_xattr 1 2 /dev/disk/by-id/scsi-SATA_ST3320620AS_9QF3R42Y-part1 /windows/C ntfs-3g users,gid=users,fmask=133,dmask=022,locale=ru_RU.UTF-8 0 0 /dev/disk/by-id/scsi-SATA_ST3320620AS_9QF3R42Y-part5 /windows/D ntfs-3g users,gid=users,fmask=133,dmask=022,locale=ru_RU.UTF-8 0 0 /dev/disk/by-id/scsi-SATA_SAMSUNG_SP1203NS00QJ10Y184695-part1 swap swap defaults 0 0 proc /proc proc defaults 0 0 sysfs /sys sysfs noauto 0 0 debugfs /sys/kernel/debug debugfs noauto 0 0 usbfs /proc/bus/usb usbfs noauto 0 0 devpts /dev/pts devpts mode=0620,gid=5 0 0 /dev/fd0 /media/floppy auto noauto,user,sync 0 0

в линуксе абсолютный новичёк, что делать не знаю совсем, мне тут ещё один чудик насоветовал так я вообще сюзу в незагружаемое состояние привёл, с грехом пополам восстановил grub в исходное состояние (какое оно было сразу после установке линукса) ну и тепереь без квалифицированных советов страшног уже самодеятельностью заниматься..

Устанавливал сначала Windows 7 затем Debian на два раздела одного HDD. Через некоторое время Windows 7 перестал загружаться, а именно, начал зависать при загрузке. Не появляется флаг Windows, примерно вот так

Отформатировал HDD, поставил на него по-новой сначала Windows 7 затем Debian. Затем проблема повторилась.

Как избежать данной проблемы?



стопроцентный вариант - стереть каку^W винду %)

А вообще, я бы Legacy mode отрубил. Ну, или, предположим, что ты в биосе таки намудрствовал, тогда ставь там все по-дефолту, но не забудь UEFI снова отрубить.

metawishmaster ★★★★ ( 29.03.15 02:37:59 )
Последнее исправление: metawishmaster 29.03.15 02:38:46 (всего исправлений: 1)


!Windows необходим. UEFI на ноутбуке нет. *Насколько я понимаю, может быть либо UEFI, либо Legacy в ноутбуках, поэтому изначально и написал так. Сейчас зашёл в BIOS, увидел, что на ноутбуке UEFI mode отсутствует.


Legacy mode - я подумал, что это способ работы с sata-устройствами, ну так вот, если он, то лучше вырубить :)

metawishmaster ★★★★ ( 29.03.15 03:04:02 )
Последнее исправление: metawishmaster 29.03.15 03:04:26 (всего исправлений: 1)

Скорее всего, Windows не нравится раздел с котрого она грузится. Как вы выделяете раздел на который будете ставить Linux? В общем, установите Windows на чистый диск. При установке укажите размер раздела, на который будет установлена Windows, остальную область оставьте неразмеченной. Затем при установке Linux создавайте разделы в неразмеченной области, ставьте загрузчик. Всё должно быть впорядке.

Так же выполните проверку файловой системы на разделе с которого грузится Windows, всех разделах. Причём проверку NTFS производите утилитой из состава Windows, раз у вас Windows не грузится, то воспользуйтесь установочным диском, запустите на нём командную строку, сейчас не помню, но есть комбинация для запуска командной строки Windows прямо из установщика. Либо воспользуйтесь WinPE. В общем, как запустите командную строку выполните проверку файловых систем:

UPD:
Присоединяюсь к комментатору выше, возможно вы перепутили режим работы контроллера. AHCI и compatible (legacy), попробуйте попереключать этот режим и проверить загрузку Windows.

kostik87 ★★★★★ ( 29.03.15 03:12:09 )
Последнее исправление: kostik87 29.03.15 03:14:30 (всего исправлений: 2)


Сейчас я отсею многие советы.

  • 1) Полное форматирование утилитой Low level format tool (поэтому я очень сомневаюсь, что проверка файловой системы мне что-то даст),
  • 2) Устанавливал Windows 7 в отведённую ему, его же установщиком область. !Остальной диск оставался не размеченным.
  • 3) Устанавливал Debian 7 в не размеченную область !с автоматическими параметрами.
  • 4) Устанавливал GRUB.

!Важно: после установки Windows 7 работала примерно 2 дня (поэтому совет о режиме контроллера compatible не актуален). После чего я перестанавливал всё по этому же алгоритму и она ещё раз работала 2 дня примерно.

Я имел ввиду именно boot mode. Так как знал, что в UEFI используются свои файлы загрузки и условно параллельная, а не цепочная загрузка, как в GRUB. Но у меня относительно старый ноутбук и нет UEFI. Это дополнение сказано чтобы уточнить ситуацию.

*Пишу из-под Debian на этом ноутбуке.

Можно попробовать /boot отдельный сделать.


блин. ну винда - это отличный генератор энтропии.

А попробуй, после установки винды, отключить обновления. Одна и та же проблема после 2х дней использования, винда вполне могла загрузить обновления. Ну или ты в debian'е все время делаешь dd if=/dev/urandom of=/dev/sda1 %)

metawishmaster ★★★★ ( 29.03.15 07:37:32 )
Последнее исправление: metawishmaster 29.03.15 07:38:25 (всего исправлений: 1)

!Важно: после установки Windows 7 работала примерно 2 дня (поэтому совет о режиме контроллера compatible не актуален). После чего я перестанавливал всё по этому же алгоритму и она ещё раз работала 2 дня примерно.

А интернет был доступен, когда ты работал в Windows?

А ты пробовал нажимать F8 и применять какую-нибудь из опций восстановления?

Вероятно, это автоматическое обновление как-то ставится, попробуй отключить обновления.

Хотя лучше всего просто удалить Windows. Нафига она тебе? Ну или если очень надо что-то виндовое запускать, есть wine и виртуалки.

Xenius ★★★★★ ( 29.03.15 08:22:41 )
Последнее исправление: Xenius 29.03.15 08:23:14 (всего исправлений: 1)

Windows 7 обычно ставится на два раздела сразу.



у меня update-grub2 (Debian Wheezy) автоматом все прочухал, но винду я ставил после дебиана и на другой физический диск.

поэтому я очень сомневаюсь, что проверка файловой системы мне что-то даст

Видимо, ты ещё вместо решения своей проблемы любишь сидеть сомневаться, а не проверять советы. Ну, что же, сиди сомневайся. По сути, Windows может не грузиться из-за ошибок на файловой системе, в тоже самое время эта файловая система в Linux может прекрасно монтироваться. Поэтому выполни проверку файловой системы Windows, точнее всех файловых систем Windows, проверку делай родной утилитой Windows, т.е.

для всех дисков. Затем пробуй грузить Windows и вот если после такой проверки проблема останет, то вот тогда и пиши здесь об этом.

Приложи схему разбивки диска.

Хотя с большой долей вероятности можно сказать, что Linux и загрузчик Grub к проблеме не имеет ни какого отношения, она полностью имеет отношение только к Windows и действиям, которые ты в ней выполняешь. Но всё же стоит попробовать вот такой вариант, тем более ты грешишь на Linux, так вот, в начале ставь Linux, затем ставь Windows, вызов загрузчика Linux добавь как пункт загрузки в загрузочное меню Windows.

Устанавливал Windows 7 в отведённую ему, его же установщиком область. !Остальной диск оставался не размеченным.

Виндовый установщик по своей инициативе разметил под винду не все дисковое пространство? Чудеса какие-то.

Устанавливал Debian 7 в не размеченную область !с автоматическими параметрами.

А лучше бы с ручными.


У меня тоже xp без проблем ещё с grub1 грузилась, сейчас дуалбута нет, так что с такими граблями не сталкивался. Но я для линукса всегда делаю небольшой основной ext2 boot раздел

Многие новички и опытные пользователи Linux держат также установленной на своем компьютере операционную систему Windows, например, последней, десятой версии. Новичкам это нужно чтобы иметь запасную операционную систему, к которой они смогут вернуться, если их Linux сломается. А для опытных пользователей важно программное обеспечение, которое не поддерживается ни в Linux, ни даже с помощью эмулятора Wine, а таких программ достаточно много.

Но временами случается такая ситуация, что загрузчик Grub не распознает установленную Windows и не отображает ее в списке для систем для загрузки. В этой статье мы рассмотрим почему возникает ошибка grub не видит Windows 10 и как ее решить.

Ошибка Grub не видит Windows 10

Причин такой ошибки может быть несколько, начиная от того, что система установлена на другом жестком диске, и заканчивая неизвестными глюками пакета os-prober, который и занимается определением операционных систем в Linux. Также, если у вас есть несколько версий Windows на компьютере, то программа может видеть только одну из них.

Сначала можно попытаться сделать наш с Windows раздел более видимым для программы. Для этого примонтируйте его в какую-либо папку. Например, в /mnt/:

sudo mount -t ntfs-3g -o ro /dev/sda1

Я предполагаю, что система Windows установлена на разделе, который определяется в Linux, как /dev/sda1. Дальше запустите утилиту os-prober:


Если программа обнаружит Windows, то вам останется обновить конфигурацию загрузчика Grub:


sudo grub2-mkconfig -o /boot/grub/grub.cfg

Если же этот способ не сработает, а он, скорее всего, не сработает, то вам останется только вручную добавить пункт меню для Windows. Это не самое простое, но зато эффективное решение. Сначала нам нужно узнать UUID раздела диска, на который установлена Windows, например, /dev/sda1:


Затем откройте файл /etc/grub.d/40_custom и добавьте туда такой код:

menuentry "Windows 10" insmod ntfs
set root='(hd0,1)'
search --no-floppy --fs-uuid --set B4A6AEB7A6AE7A0E
chainloader +1
>


Если кратко, то здесь мы устанавливаем в качестве корня первый раздел первого диска, а затем указываем загрузчику, что нужно найти раздел с нужным нам UUID. Затем передаем управление загрузчику на этом разделе с помощью chainloader. Дальше осталось обновить конфигурацию Grub:


Мы использовали такой метод потому что теперь настройка не собьется после обновления ядра или другого процесса, инициализирующего обновление конфигурации. Потому что если бы мы добавили эти строки в /boot/grub/grub.cfg, то они были бы перезаписаны если не при первом, то при одном из следующих обновлений системы.

Когда конфигурация обновлена вы можете перезагрузить компьютер и загружать Windows с помощью нового пункта. Таким образом, можно добавить несколько пунктов, только для разных разделов нужно указывать их UUID.

Выводы

Не загружается Linux, чиним загрузчик GRUB

Любите экспериментировать? Наверняка вы когда-либо пытались произвести какие-то действия со своей Linux-системой, причем не так важно какие были цели: изучение и познание новых возможностей или же какая-то более конкретная цель, в виде исправления той или иной ошибки. В любом случае, при работе с дистрибутивами Linux, для загрузки которых, в большинстве случаев, и используется Grub, с последним могут возникать неприятные проблемы, ввиду которых дальнейшая эксплуатация системы просто-напросто невозможна. В этой статье вы узнаете, что делать, если не загружается Linux. Как вести себя в подобной ситуации и какие действия производить, чтобы починить загрузчик Grub. Пожалуй, начнем.

Что такое Grub

GRUB_screenshot

Grub (или GRand Unified Bootloader) - загрузчик операционных систем с открытым исходным кодом. Распространяется он под лицензией GNU GPL, в полностью свободном виде. С помощью этого замечательного лоадера можно сделать много всего - основная же функция не ограничивается загрузкой лишь одной операционной системы. Вы можете иметь куда больше операционных систем на своем ПК, загружая любую из них с помощью Grub. На скриншоте выше вы можете видеть как примерно Grub выглядит. Кстати говоря, если вы захотите установить Ubuntu 18.04 рядом с Windows, вам определенно понадобится помощь Grub.

Grub используется в большинстве дистрибутивов Linux в качестве загрузчика по-умолчанию. Разумеется и с ним иногда возникают проблемы. Этим самые проблемы чреваты полным отказом операционной системы. Поэтому для починки Grub нам понадобятся дополнительные инструменты. Какие именно - узнаете далее.

От чего могут возникнуть проблемы

Одна из самых распространенных причин - это неправильный порядок установки двух операционных систем (Linux и Windows). Допустим, если вы захотите установить две этих операционных системы на свой ПК - вам непременно стоит знать правильную последовательность:

  • Сначала устанавливаем Windows
  • И только потом уже Linux

Если, например, сделать наоборот, то как раз-таки Grub будет поврежден; система будет грузиться напрямую в Windows, а дистрибутив Linux останется недоступным.

Grub может сломаться и по другим причинам. Например, из-за попыток ручного изменения параметров запуска (при недостатке опыта), в таком случае нужно будет либо вручную убирать лишнее, либо полностью переустанавливать Grub.

Восстановление Grub с помощью LiveCD/USB

Для этого способа нам понадобится флешка с дистрибутивом Linux на борту. Подойдет любой: от Ubuntu, Arch или даже Linux Mint. Здесь нужен только терминал, поэтому подойдет даже версия без графической оболочки.

Как создать LiveCD/USB

Само собой, нам понадобится носитель, на который мы временно (а может и нет) запишем систему. Сохраните все важные файлы, которые были на этом носителе, после чего (имеется ввиду на другом ПК, желательно под управлением Windows) запишите загруженный образ дистрибутива на носитель. В качестве примера мы будем использовать дистрибутив Ubuntu.

Идем на официальную страницу загрузки. Загружаем любую понравившуюся версию (лучше взять новейшую для десктопа), после чего записываем ее на USB/CD.

С помощью Rufus:

Последняя версия приложения доступна на официальном сайте. Сразу после загрузки и запуска/установки мы увидим такое окно:

Rufus

Вставляем носитель, выбираем его в соответствующем меню. Далее выбираем нужную схему раздела и тип системного интерфейса, и после уже открываем файловый менеджер с помощью этой кнопки:

Rufus obraz

Находим загруженный образ через менеджер, после чего жмем "Старт".

С помощью Etcher:

Опять же, идем на официальный сайт, где скачиваем последнюю версию утилиты. Далее делаем все так, как показано на этой гифке:

Ну а теперь, собственно, можно переходить к восстановлению Grub. Вставляем флешку в наш ПК (где сломан загрузчик), после чего перезагружаем его с этой самой флешки. Как только мы войдем в лайв-систему, сразу открываем терминал, после чего проделываем следующие действия:

Открываем таблицу разделов с помощью команды:

Примерно такая таблица будет выведена на экран:

По этой таблице мы видим, что Linux, в нашем случае, расположен на разделе /dev/sda1.

С помощью следующей команды мы смонтируем этот раздел в /mnt:

Теперь, для записи grub в MBR, нужно ввести следующую команду:

Если нужно только восстановить MBR диска (после переустановки Windows, к примеру), то этих действий будет вполне достаточно.

Если же необходимо обновить и меню grub (после установки Windows), то нужно выполнить еще и эту команду:

Вот и все, восстановление закончено!

Восстановление с помощью chroot

Помимо вышеописанного способа, при восстановлении Grub с помощью LiveCD можно использовать и этот. Тут мы будем использовать утилиту chroot.

Здесь нам, опять же, понадобится таблица разделов. Вводим уже известную команду:

В выводе снова будет эта таблица. Теперь нам надо присмотреться к ней еще внимательнее.

В этом способе нам необходимо примонтировать системный, а также нескольких других важных разделов. Для этого вводим эти команды:

Обратите внимание, что если если разделы /boot или /var находятся отдельно, то Вам нужно будет примонтировать их в /mnt/boot и /mnt/var.

Далее мы переходим в окружающую среду chroot с помощью команды:

И теперь, наконец-таки переустанавливаем Grub с помощью следующей команды:

Если все прошло успешно, выходим из chroot, используя команду:

Далее нужно отмонтировать все разделы. Для этого вводим в терминал:

В случае, если вы монтировали раздел /boot введите команду:

Теперь перезагружаем систему с помощью:

Можно также обновить меню Grub, используя команду:

Восстановление Grub в rescue mode

Если по каким-то причинам у вас нет доступа к LiveCD/USB-носителю, а также к компьютеру, с помощью которого этот самый носитель можно было бы сделать, то этот способ для вас.

Само восстановление проходит таким образом: сначала мы подгружаем все модули, чтобы открыть доступ ко всей функциональной части Grub, после чего запуститься с нужного раздела. Надо понимать, что Grub состоит из двух частей:

Одна из этих частей (первая) записана в MBR диска. В ней присутствует базовый функционал и ничего больше (консоль в rescue mode).

Стало быть, нам нужно определить, в каком разделе находится вторая часть Grub (находится в каталоге /boot/grub), и после чего подгрузить все недостающие модули. А вот уже после этого мы сможем запустить загрузчик с нужного раздела. В rescue mode есть всего четыре команды:

Для начала вводим следующую команду:

В выводе будет что-то подобное:

В некоторых случаях Grub неправильно опеределяет файловые системы находящиеся на разделах дисков. В данном примере загрузчик показывает их как msdos. Мы должны попытаться угадать диски, которые видим. В примере доступно два диска. Диск с индексом 0 содержащий три раздела, и диск с индексом 1 содержащий два раздела. Если вы знаете структуру своих дисков, определить нужный труда не составит.

В загрузчике Grub разделы нумеруются в обратном исчислении. Не очень ясно какой именно из разделов назван, к примеру (hd0,msdos3). Чтобы было более понятно, можно использовать вид (hd0,1). Если в грабе отсчет дисков идет с 0, а разделов с 1, то можно определить, что операционная система установлена в первый раздел первого раздела - (hd0,1). Используем следующую команду:

С помощью этих команд мы приказываем системе использовать какой-то конкретный диск, для выполнения всех остальных операций (в нашем случае, это диск (hd0,1)). Чтобы проверить есть ли на данном диске загрузчик, введем эту команду:

Если в выводе будет список файлов и папок, значит мы все сделали правильно. Теперь можно загрузить все необходимые модули. Для этого выполним команды:

После выполнения команд Grub загрузится в полнофункциональном режиме. Будут найдены все операционные системы, которые установлены на компьютере, после чего будет показано стандартное меню загрузки.

Чтобы закрепить результат (и не проделывать все то же самое после перезапуска ПК), нужно зайти в терминал своего дистрибутива Linux, где с root правами выполнить следующую команду:

sdX - диск, на который должен быть установлен Grub.

Если операционная система расположена на разделе с файловой системой btrfs, то нам необходимо выполнить следующие команды:

И подгрузить модули:

Ну и теперь запустить GRUB:

Восстановление Grub с помощью утилиты Boot repair

1335260967

С помощью этой замечательной утилиты вы сможете восстановить загрузчик всего в пару кликов. Как видно из скриншота, утилита имеет собственный GUI, ее использование не вызовет трудностей.

Чтобы установить boot repair, вы можете воспользоваться одним из приведенных способов:

  • Запись и установка специального образа диска Boot Repair (и дальнейшая загрузка с него)
  • Установка Boot repair из PPA-репозитория в LiveCD/USB дистрибутиве.

Если с первым способом все понятно: нужно просто скачать и записать образ с помощью соответствующих инструментов. То во втором уже нужно знать конкретные команды, которые выглядят следующим образом:

В утилите будет доступно два варианта на выбор:

Recommended repair исправляет большую часть известных ошибок, которые могли бы возникнуть при запуске. С его помощью вы сможете пофиксить и загрузчик Grub.

Create a BootInfo summary создает Boot-Info-Script – скрипт, который позволяет диагностировать большинство проблем при загрузке.

Здесь же есть и Advanced options. Он включает в себя варианты для восстановления и настройки загрузчика Grub2 (загрузка по-умолчанию, опции загрузки ядра, отображение или скрытие GRUB при загрузке, удаление GRUB). С помощью этих же инструментов, вы можете восстановить MBR и т.д.

Вам обязательно стоит заглянуть на официальный сайт Boot Repair. Там вы сможете найти более подробную информацию обо всех возможностях и особенностях программы. Там же будет доступна информация о выходе новых версий: фиксах и улучшениях самой утилиты, а также многом и многом другом.

Выводы

Вот мы и рассмотрели несколько вариантов исправления загрузчика Grub. Стоит сказать, что некоторые из них могут показаться сложными или даже невыполнимыми. Это не так, каждый из рассмотренных способов нашел подтверждение в виде сотен и тысяч актов исправления загрузчика Grub в опенсорсном сообществе. Кстати говоря, какой из способов выбрать - решать только вам, любой из них достаточно эффективен, чтобы попасть в этот материал.

Возможно вас заинтересуют и другие похожие материалы про починку загрузчика Grub2. Например, в этом материале вы узнаете, как починить GRUB2 если Ubuntu не хочет загружаться. Там более подробно рассказывается, как фиксить груб с помощью утилиты Boot Repair, возможно вам стоит заглянуть туда, если вы не поняли что-то из этого материала. Что же, ну а на сегодня это все. Надеюсь, что данный материал помог вам разобраться в ошибках. Что, в свою очередь, поможет вам их решить.

Читайте также: