Восстановление пароля администратора: различия между версиями
Asy (обсуждение | вклад) |
Asy (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
==Малыми средствами== | == Малыми средствами == | ||
Пароль пользователя root по [[как хранятся пароли|соображениям безопасности]] нельзя узнать, можно задать ему новый пароль. Для этого: | Пароль пользователя root по [[как хранятся пароли|соображениям безопасности]] нельзя узнать, можно задать ему новый пароль. Для этого: | ||
Строка 10: | Строка 10: | ||
* нажать F10 | * нажать F10 | ||
<li> Загрузится консоль. Выполните в ней | <li> Загрузится консоль. Выполните в ней команду | ||
</li> | </li> | ||
mount / -o rw,remount | mount / -o rw,remount | ||
<li> Если файловая система /usr создана отдельно, найдите (cat /etc/fstab) и примонтируйте /usr | |||
</li> | |||
mount <устройство> /usr | |||
<li> Запустите passwd (можно пропустить предыдущий пункт и вернуться к нему в случае, если команда не будет найдена) | |||
</li> | |||
passwd | passwd | ||
<li> Укажите пароль для пользователя root и подтвердите его. | <li> Укажите пароль для пользователя root и подтвердите его. | ||
<li> Далее выполните команды: | <li> Далее выполните команды (достаточно любой из, но обе лучше): | ||
</li> | </li> | ||
sync | |||
reboot | reboot | ||
</ol> | </ol> | ||
Строка 25: | Строка 30: | ||
{{attention|При редактировании '''не''' следует нажимать Ctrl-c/F2 для получения командной строки, вы и так исправляете уже существующую команду; пользуйтесь курсорными стрелками (Del и Backspace не должны понадобиться).}} | {{attention|При редактировании '''не''' следует нажимать Ctrl-c/F2 для получения командной строки, вы и так исправляете уже существующую команду; пользуйтесь курсорными стрелками (Del и Backspace не должны понадобиться).}} | ||
==С дополнительными ухищрениями при загрузке Вашей системы== | == С дополнительными ухищрениями при загрузке Вашей системы == | ||
Не всегда после минимальной загрузки системы, как в [[#Малыми средствами|первом предложенном способе]], Вы получите полностью рабочую систему, которой Вы смогли бы командовать. А именно, она на этом этапе может ещё не работать с нужными устройствами -- с клавиатурой. (Такое наблюдалось, например, на [[ALT Desktop 4.0]] с USB-клавиатурой.) | Не всегда после минимальной загрузки системы, как в [[#Малыми средствами|первом предложенном способе]], Вы получите полностью рабочую систему, которой Вы смогли бы командовать. А именно, она на этом этапе может ещё не работать с нужными устройствами -- с клавиатурой. (Такое наблюдалось, например, на [[ALT Desktop 4.0]] с USB-клавиатурой.) | ||
Строка 49: | Строка 54: | ||
свою [[initial RAM fs]] на любом разделе и загрузиться с ней (если у Вас загрузчик -- [[grub]]). Но это уже чрезмерно для обычного человека: каждый Unix-пользователь должен представлять себе, как писать shell-скрипт (что мы и сделали) -- это ему будет полезно при пользовании, но вряд ли обязан уметь изготавливать свои initramfs и т.п. -- больше это ему при использовании системы никогда не пригодится. Поэтому разумнее, наверное, перейти к [[#Более универсальный способ|следующему описанному способу]], более универсальному и полезному в других случаях, но требующему дополнительных средств. | свою [[initial RAM fs]] на любом разделе и загрузиться с ней (если у Вас загрузчик -- [[grub]]). Но это уже чрезмерно для обычного человека: каждый Unix-пользователь должен представлять себе, как писать shell-скрипт (что мы и сделали) -- это ему будет полезно при пользовании, но вряд ли обязан уметь изготавливать свои initramfs и т.п. -- больше это ему при использовании системы никогда не пригодится. Поэтому разумнее, наверное, перейти к [[#Более универсальный способ|следующему описанному способу]], более универсальному и полезному в других случаях, но требующему дополнительных средств. | ||
==Более универсальный способ== | == Более универсальный способ == | ||
Можно загрузить "другую" систему и через неё всё сделать; для этого нужны дополнительные средства, помимо Вашей установленной системы, например, загрузочный спасательный или установочный диск, или LiveCD, или что-то подобное. Суть метода - собрать дерево файловых систем и сделать в него chroot, после чего появляется возможность выполнять в целевой система различные команды с правами суперпользователя. | Можно загрузить "другую" систему и через неё всё сделать; для этого нужны дополнительные средства, помимо Вашей установленной системы, например, загрузочный спасательный или установочный диск, или LiveCD, или что-то подобное. Суть метода - собрать дерево файловых систем и сделать в него chroot, после чего появляется возможность выполнять в целевой система различные команды с правами суперпользователя. | ||
Версия от 18:31, 31 марта 2019
Малыми средствами
Пароль пользователя root по соображениям безопасности нельзя узнать, можно задать ему новый пароль. Для этого:
- В меню загрузчика пропишите в параметрах init=/bin/bash
- Если загрузчик -- grub, следует:
- нажать "e" при курсоре на цели загрузки, соответствующей используемому экземпляру ALT Linux;
- в открывшемся редакторе отыскать строку, начинающуюся с linux /boot/vmlinuz;
- в её конец дописать то самое init=/bin/bash
- нажать F10
- Загрузится консоль. Выполните в ней команду mount / -o rw,remount
- Если файловая система /usr создана отдельно, найдите (cat /etc/fstab) и примонтируйте /usr mount <устройство> /usr
- Запустите passwd (можно пропустить предыдущий пункт и вернуться к нему в случае, если команда не будет найдена) passwd
- Укажите пароль для пользователя root и подтвердите его.
- Далее выполните команды (достаточно любой из, но обе лучше): sync reboot
С дополнительными ухищрениями при загрузке Вашей системы
Не всегда после минимальной загрузки системы, как в первом предложенном способе, Вы получите полностью рабочую систему, которой Вы смогли бы командовать. А именно, она на этом этапе может ещё не работать с нужными устройствами -- с клавиатурой. (Такое наблюдалось, например, на ALT Desktop 4.0 с USB-клавиатурой.)
Тогда путь можно немного усложнить: в качестве параметра init передать ядру не командную оболочку, а специально написанный скрипт, который сначала выполнит обычные действия по подготовке устройств к использованию в системе, а потом уже запустит командную оболочку. Скрипт этот нужно расположить в корневом разделе, который только и доступен на этом этапе загрузки.
Подробности: Для наших целей хорошо, если у Вас /var/tmp/ располагается на корневом разделе (проверьте по выводу команды mount или df /var/tmp/) и у Вас есть права записи в него. Пусть наш скрипт будет расположен по пути /var/tmp/myinit. Создайте его нормальным текстовым редактором (например, в меню системы, где такое приходилось делать, нашёлся gedit) с таким содержанием:
#!/bin/sh echo Running myinit. /etc/rc.d/rc.sysinit /bin/sh
(или
#!/bin/sh set -x echo Running myinit. /etc/rc.d/rc.sysinit /bin/sh
чтобы "объявлялись" выполняемые шаги Вашего скрипта и Вы лучше могли бы следить за процессом; см. man set),
сохраните Ваш скрипт, сделайте исполняемым (chmod a+x /var/tmp/myinit), и перезагружайтесь с параметром init=/var/tmp/myinit
.
Если не нашлось места, куда бы Вы могли поместить свой init-скрипт, так чтобы он был доступен на этом раннем этапе загрузки, то нужно будет придумать какую-нибудь ещё хитрость. Возможно, можно сделать свою initial RAM fs на любом разделе и загрузиться с ней (если у Вас загрузчик -- grub). Но это уже чрезмерно для обычного человека: каждый Unix-пользователь должен представлять себе, как писать shell-скрипт (что мы и сделали) -- это ему будет полезно при пользовании, но вряд ли обязан уметь изготавливать свои initramfs и т.п. -- больше это ему при использовании системы никогда не пригодится. Поэтому разумнее, наверное, перейти к следующему описанному способу, более универсальному и полезному в других случаях, но требующему дополнительных средств.
Более универсальный способ
Можно загрузить "другую" систему и через неё всё сделать; для этого нужны дополнительные средства, помимо Вашей установленной системы, например, загрузочный спасательный или установочный диск, или LiveCD, или что-то подобное. Суть метода - собрать дерево файловых систем и сделать в него chroot, после чего появляется возможность выполнять в целевой система различные команды с правами суперпользователя.
Этот путь полезен не только для смены пароля, но и в других необычных случаях.
Сборка дерева ФС для chroot подробно описана в статье Восстановление загрузочной записи.