Anche così root
, non è possibile eseguire file senza x
bit di autorizzazione impostati. Quello che puoi fare è chiamarlo ld.so
(a condizione che siano eseguibili collegati dinamicamente):
$ echo /lib/*/ld*.so
/lib/i386-linux-gnu/ld-2.27.so /lib/x86_64-linux-gnu/ld-2.27.so
Usa quello che corrisponde all'architettura chmod
dell'eseguibile. Nel mio caso x86_64
quello:
sudo /lib/x86_64-linux-gnu/ld-2.27.so /bin/chmod 755 /bin /bin/chmod
O chiama qualcosa in /usr/bin
o altrove per fare il chmod
simile perl
:
sudo perl -e 'chmod 0755, "/bin", "/bin/chmod"
Prestare attenzione quando si ripristinano le autorizzazioni che alcuni file /bin
apprezzano mount
o su
devono avere autorizzazioni diverse da 0755.
Se hai riavviato, tuttavia, potresti non essere in grado di arrivare al punto in cui è possibile eseguire perl
o ld.so
comunque. Puoi risolvere le cose dal initramfs
pensiero (passa una directory root errata per ottenere una shell di ripristino in initramfs; vedi anche il parametro break=bottom
o break=init
kernel su Debian, affinché initramfs ti dia una shell dopo che il file system root è stato montato (sola lettura anche se)). O avvia la tua VM da un'immagine di CD live o correggi montando il file system VM sull'host come altri hanno suggerito.
Correzione del modo initramfs:
In grub
, modifica la voce di avvio e rimuovi il root=
parametro dal linux
comando:
setparams 'Ubuntu, with Linux 3.2.0-27-generic'
recordfail
gfxmode $linux_gfx_mode
insmod gzio
insmod ext2
set root='(hd1)'
search --no-floppy --fs-uuid --set=root dc02b07c-88ef-4804-afe0-4f02db2\
94561
linux /boot/vmlinuz-3.2.0-27-generic
initrd /boot/initrd.img-3.2.0-27-generic
Ctrl-Xavviare. Gli initramfs di Ubuntu non troveranno il file system di root, quindi avvia un ripristino sh
. Quindi montare il filesystem di root (nel mio caso /dev/vdb
, adattarsi alla propria macchina) e sistemare le cose lì:
Target filesystem doesn't have requested /sbin/init.
No init found. Try passing init= bootarg.
BusyBox v1.18.5 (Ubuntu 1:1.18.5-1ubuntu4) built-in shell (ash)
Enter 'help' for a list of built-in commands.
(initramfs) mkdir /x
(initramfs) mount /dev/vdb /x
[ 48.430071] EXT3-fs (vdb): error: couldn't mount because of unsupported optio
nal features (240)
[ 48.477406] EXT4-fs (vdb): recovery complete
[ 48.477747] EXT4-fs (vdb): mounted filesystem with ordered data mode. Opts: (
null)
(initramfs) chmod -R 755 /x/bin
(initramfs) umount /x
(initramfs) reboot
Una volta avviato, correggi le autorizzazioni dei file che non devono avere 755 autorizzazioni confrontandole con un altro sistema.
Riparando eseguendo python
come init
:
In grub
, modifica la voce di avvio, questa volta mantieni il root=
parametro, modifica ro
in rw
e aggiungi un init=/usr/bin/python
:
setparams 'Ubuntu, with Linux 3.2.0-27-generic'
recordfail
gfxmode $linux_gfx_mode
insmod gzio
insmod ext2
set root='(hd1)'
search --no-floppy --fs-uuid --set=root dc02b07c-88ef-4804-afe0-4f02db2\
94561
linux /boot/vmlinuz-3.2.0-27-generic root=UUID=dc02b07c-88ef-4804-afe0-\
4f02db294561 rw init=/usr/bin/python
initrd /boot/initrd.img-3.2.0-27-generic
Quindi, al prompt di Python:
Begin: Running /scripts/init-bottom ... done.
Python 2.7.3 (default, Apr 20 2012, 22:39:59)
[GCC 4.6.3] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import os
>>> os.chmod('/bin/sh',0755)
>>> os.chmod('/bin/chmod',0755)
>>> os.execl('/bin/sh','sh')
sh: 0: can't access tty; job control turned off
# chmod -R 0755 /bin
# mount -o remount,ro /
[ 100.704720] EXT4-fs (vdb): re-mounted. Opts: errors=remount-ro
# exec /sbin/init
Ancora una volta, una volta avviato, correggi le autorizzazioni dei file che non sono pensati per avere 755 autorizzazioni confrontandole con un altro sistema.
/bin
chmoded o i file in/bin
o entrambi?