ubuntuusers.de

Kann GRUB-Bootmenü nicht konfigurieren

Status: Gelöst | Ubuntu-Version: Kubuntu 23.10 (Mantic Minotaur)
Antworten |

Kreuzschnabel

Anmeldungsdatum:
12. Dezember 2011

Beiträge: 1331

Hallo, seit Neuinstallation von Kubuntu 23.10 vor paar Tagen erscheint beim Booten immer das GRUB-Bootmenü mit einem Timeout von 30 Sekunden, obwohl Kubuntu das einzige System auf dem Rechner ist.

Das würde ich gern komplett unterbinden (war es bis jetzt auch immer) oder zumindest den Timeout auf wenige Sekunden runtersetzen. Es gelingt mir aber nicht.

In der /etc/default/grub steht:

GRUB_DEFAULT=0
GRUB_TIMEOUT_STYLE=hidden
GRUB_TIMEOUT=0
GRUB_DISTRIBUTOR=`lsb_release -i -s 2> /dev/null || echo Debian`
GRUB_CMDLINE_LINUX_DEFAULT="quiet splash"
GRUB_CMDLINE_LINUX=""

… der Rest ist auskommentiert. Demnach sollte das Menü gar nicht kommen, oder?

Mein Versuch, eine /etc/default/grub.d/zz.cfg mit mod 755 und

GRUB_TIMEOUT=5

anzulegen, wird zwar zur Kenntnis genommen:

volker@marvin:~$ sudo update-grub
Sourcing file `/etc/default/grub'
Sourcing file `/etc/default/grub.d/zz.cfg'
Generating grub configuration file ...
Found linux image: /boot/vmlinuz-6.5.0-26-generic
Found initrd image: /boot/initrd.img-6.5.0-26-generic
Found linux image: /boot/vmlinuz-6.5.0-9-generic
Found initrd image: /boot/initrd.img-6.5.0-9-generic
Found memtest86+ 64bit EFI image: /@/boot/memtest86+x64.efi
Warning: os-prober will not be executed to detect other bootable partitions.
Systems on them will not be added to the GRUB boot configuration.
Check GRUB_DISABLE_OS_PROBER documentation entry.
Adding boot menu entry for UEFI Firmware Settings ...
done
volker@marvin:~$ 

Aber beim nächsten Reboot haben wir unverändert dasselbe Verhalten.

Dann entnahm ich der Wikiseite GRUB 2/Konfiguration, dass persönliche Einstellungen komplizierter sind, wenn SecureBoot abgeschaltet ist. Also nochmal Reboot, im Setup alles hingebogen (SecureBoot ein, TPM 2.0 enabled, UEFI only), F10, Neustart, selbes Verhalten, nochmal sudo update-grub, Neustart, selbes Verhalten.

Meine Bemühungen scheinen einfach ignoriert zu werden.

--ks

san04

Anmeldungsdatum:
19. Januar 2010

Beiträge: 1247

Kreuzschnabel schrieb:

GRUB-Bootmenü mit einem Timeout von 30 Sekunden

Die sind ja verdächtig, klingen sie doch sehr nach dem recordfail-timeout in der grub.cfg der in /etc/grub.d/00_header definiert wird.

Testhalber würde ich mal GRUB 2/Konfiguration (Abschnitt „GRUB-RECORDFAIL-TIMEOUT“) manuell setzen. Falls das klappt, wäre es natürlich interessant herauszufinden, warum der Fall eintritt.

ls -lah /boot/grub 

Und vielleicht auch mal die grub.cfg zeigen? Ist das System einfach per Installer installiert, oder mit Besonderheiten?

Kreuzschnabel

(Themenstarter)

Anmeldungsdatum:
12. Dezember 2011

Beiträge: 1331

san04 schrieb:

Ist das System einfach per Installer installiert, oder mit Besonderheiten?

Einfach per Installer (vom Livesystem aus), Firmware ist UEFI. Einzige Besonderheit ist btrfs statt ext4 als Dateisystem für root- und home-Partition. Das scheint deshalb eine Besonderheit zu sein, weil der Installer beim Formatieren der Rootpartition ein Subvolume namens @ anlegt (was er ja gern machen darf) und auf die Anweisung, /dev/nvme0n1p4 ohne Neuformatierung in /home zu mounten, in die /etc/fstab als Optionen dort ungefragt defaults,subvol=home einträgt. Da gibt’s aber kein solches Subvolume, weshalben das Ding erst orntlich bootete, als ich diesen Eintrag händisch aus der /etc/fstab entfernte.

Testhalber würde ich mal GRUB 2/Konfiguration (Abschnitt „GRUB-RECORDFAIL-TIMEOUT“) manuell setzen. Falls das klappt,

Es klappt! 👍

san04 schrieb:

ls -lah /boot/grub 
volker@marvin:~$ ls -lah /boot/grub
insgesamt 2,4M
drwxr-xr-x 1 root root  126 Mär 28 10:38 .
drwxr-xr-x 1 root root  634 Mär 26 22:15 ..
drwxr-xr-x 1 root root   22 Mär 26 21:34 fonts
-rw-r--r-- 1 root root  712 Okt 10 05:15 gfxblacklist.txt
-rw------- 1 root root 8,8K Mär 28 10:38 grub.cfg
-rw-rw-r-- 1 root root 1,0K Mär 28 10:39 grubenv
drwxr-xr-x 1 root root   68 Mär 26 21:34 locale
-rw-r--r-- 1 root root 2,4M Okt 10 05:15 unicode.pf2
drwxr-xr-x 1 root root 6,2K Mär 26 21:34 x86_64-efi
volker@marvin:~$ 

Und vielleicht auch mal die grub.cfg zeigen?

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
volker@marvin:~$ sudo cat /boot/grub/grub.cfg
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#

### BEGIN /etc/grub.d/00_header ###
if [ -s $prefix/grubenv ]; then
  set have_grubenv=true
  load_env
fi
if [ "${initrdfail}" = 2 ]; then
   set initrdfail=
elif [ "${initrdfail}" = 1 ]; then
   set next_entry="${prev_entry}"
   set prev_entry=
   save_env prev_entry
   if [ "${next_entry}" ]; then
      set initrdfail=2
   fi
fi
if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   set boot_once=true
else
   set default="0"
fi

if [ x"${feature_menuentry_id}" = xy ]; then
  menuentry_id_option="--id"
else
  menuentry_id_option=""
fi

export menuentry_id_option

if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    save_env saved_entry
  fi
}
function initrdfail {
    if [ -n "${have_grubenv}" ]; then if [ -n "${partuuid}" ]; then
      if [ -z "${initrdfail}" ]; then
        set initrdfail=1
        if [ -n "${boot_once}" ]; then
          set prev_entry="${default}"
          save_env prev_entry
        fi
      fi
      save_env initrdfail
    fi; fi
}
function recordfail {
  set recordfail=1
  # GRUB lacks write support for btrfs, so recordfail support is disabled.
}
function load_video {
  if [ x$feature_all_video_module = xy ]; then
    insmod all_video
  else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
  fi
}

if [ x$feature_default_font_path = xy ] ; then
   font=unicode
else
insmod part_gpt
insmod btrfs
search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
    font="/@/usr/share/grub/unicode.pf2"
fi

if loadfont $font ; then
  set gfxmode=auto
  load_video
  insmod gfxterm
  set locale_dir=$prefix/locale
  set lang=de_DE
  insmod gettext
fi
terminal_output gfxterm
if [ "${recordfail}" = 1 ] ; then
  set timeout=7
else
  if [ x$feature_timeout_style = xy ] ; then
    set timeout_style=hidden
    set timeout=0
  # Fallback hidden-timeout code in case the timeout_style feature is
  # unavailable.
  elif sleep --interruptible 0 ; then
    set timeout=0
  fi
fi
if [ $grub_platform = efi ]; then
  set timeout=7
  if [ x$feature_timeout_style = xy ] ; then
    set timeout_style=menu
  fi
fi
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/05_debian_theme ###
set menu_color_normal=white/black
set menu_color_highlight=black/light-gray
if background_color 0,0,0; then
  clear
fi

color_normal=white/black

if [ -e ${prefix}/themes/kubuntu-logo/theme.txt ]; then
  insmod png
  theme=${prefix}/themes/kubuntu-logo/theme.txt
fi
### END /etc/grub.d/05_debian_theme ###

### BEGIN /etc/grub.d/10_linux ###
function gfxmode {
        set gfxpayload="${1}"
        if [ "${1}" = "keep" ]; then
                set vt_handoff=vt.handoff=7
        else
                set vt_handoff=
        fi
}
if [ "${recordfail}" != 1 ]; then
  if [ -e ${prefix}/gfxblacklist.txt ]; then
    if [ ${grub_platform} != pc ]; then
      set linux_gfx_mode=keep
    elif hwmatch ${prefix}/gfxblacklist.txt 3; then
      if [ ${match} = 0 ]; then
        set linux_gfx_mode=keep
      else
        set linux_gfx_mode=text
      fi
    else
      set linux_gfx_mode=text
    fi
  else
    set linux_gfx_mode=keep
  fi
else
  set linux_gfx_mode=text
fi
export linux_gfx_mode
menuentry 'Ubuntu' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-518951dc-169b-455b-950a-1cc72fa05ad8' {
        recordfail
        load_video
        gfxmode $linux_gfx_mode
        insmod gzio
        if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
        insmod part_gpt
        insmod btrfs
        search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
        linux   /@/boot/vmlinuz-6.5.0-26-generic root=UUID=518951dc-169b-455b-950a-1cc72fa05ad8 ro rootflags=subvol=@  quiet splash $vt_handoff
        initrd  /@/boot/initrd.img-6.5.0-26-generic
}
submenu 'Advanced options for Ubuntu' $menuentry_id_option 'gnulinux-advanced-518951dc-169b-455b-950a-1cc72fa05ad8' {
        menuentry 'Ubuntu, with Linux 6.5.0-26-generic' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.0-26-generic-advanced-518951dc-169b-455b-950a-1cc72fa05ad8' {
                recordfail
                load_video
                gfxmode $linux_gfx_mode
                insmod gzio
                if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
                insmod part_gpt
                insmod btrfs
                search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
                echo    'Loading Linux 6.5.0-26-generic ...'
                linux   /@/boot/vmlinuz-6.5.0-26-generic root=UUID=518951dc-169b-455b-950a-1cc72fa05ad8 ro rootflags=subvol=@  quiet splash $vt_handoff
                echo    'Loading initial ramdisk ...'
                initrd  /@/boot/initrd.img-6.5.0-26-generic
        }
        menuentry 'Ubuntu, with Linux 6.5.0-26-generic (recovery mode)' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.0-26-generic-recovery-518951dc-169b-455b-950a-1cc72fa05ad8' {
                recordfail
                load_video
                insmod gzio
                if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
                insmod part_gpt
                insmod btrfs
                search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
                echo    'Loading Linux 6.5.0-26-generic ...'
                linux   /@/boot/vmlinuz-6.5.0-26-generic root=UUID=518951dc-169b-455b-950a-1cc72fa05ad8 ro single recovery nomodeset dis_ucode_ldr rootflags=subvol=@ 
                echo    'Loading initial ramdisk ...'
                initrd  /@/boot/initrd.img-6.5.0-26-generic
        }
        menuentry 'Ubuntu, with Linux 6.5.0-9-generic' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.0-9-generic-advanced-518951dc-169b-455b-950a-1cc72fa05ad8' {
                recordfail
                load_video
                gfxmode $linux_gfx_mode
                insmod gzio
                if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
                insmod part_gpt
                insmod btrfs
                search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
                echo    'Loading Linux 6.5.0-9-generic ...'
                linux   /@/boot/vmlinuz-6.5.0-9-generic root=UUID=518951dc-169b-455b-950a-1cc72fa05ad8 ro rootflags=subvol=@  quiet splash $vt_handoff
                echo    'Loading initial ramdisk ...'
                initrd  /@/boot/initrd.img-6.5.0-9-generic
        }
        menuentry 'Ubuntu, with Linux 6.5.0-9-generic (recovery mode)' --class ubuntu --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.0-9-generic-recovery-518951dc-169b-455b-950a-1cc72fa05ad8' {
                recordfail
                load_video
                insmod gzio
                if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
                insmod part_gpt
                insmod btrfs
                search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
                echo    'Loading Linux 6.5.0-9-generic ...'
                linux   /@/boot/vmlinuz-6.5.0-9-generic root=UUID=518951dc-169b-455b-950a-1cc72fa05ad8 ro single recovery nomodeset dis_ucode_ldr rootflags=subvol=@ 
                echo    'Loading initial ramdisk ...'
                initrd  /@/boot/initrd.img-6.5.0-9-generic
        }
}

### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/10_linux_zfs ###
### END /etc/grub.d/10_linux_zfs ###

### BEGIN /etc/grub.d/20_linux_xen ###

### END /etc/grub.d/20_linux_xen ###

### BEGIN /etc/grub.d/20_memtest86+ ###
menuentry "Memory test (memtest86+x64.efi)" --class memtest $menuentry_id_option 'memtest86+' {
        insmod part_gpt
        insmod btrfs
        search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
        linux    /@/boot/memtest86+x64.efi
}
menuentry 'Memory test (memtest86+x64.efi, serial console)' --class memtest $menuentry_id_option 'memtest86+-serial' {
        insmod part_gpt
        insmod btrfs
        search --no-floppy --fs-uuid --set=root 518951dc-169b-455b-950a-1cc72fa05ad8
        linux   /@/boot/memtest86+x64.efi console=ttyS0,115200
}
### END /etc/grub.d/20_memtest86+ ###

### BEGIN /etc/grub.d/25_bli ###
if [ "$grub_platform" = "efi" ]; then
  insmod bli
fi
### END /etc/grub.d/25_bli ###

### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###

### BEGIN /etc/grub.d/30_uefi-firmware ###
if [ "$grub_platform" = "efi" ]; then
        fwsetup --is-supported
        if [ "$?" = 0 ]; then
                menuentry 'UEFI Firmware Settings' $menuentry_id_option 'uefi-firmware' {
                        fwsetup
                }
        fi
fi
### END /etc/grub.d/30_uefi-firmware ###

### BEGIN /etc/grub.d/35_fwupd ###
### END /etc/grub.d/35_fwupd ###

### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  ${config_directory}/custom.cfg ]; then
  source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg
fi
### END /etc/grub.d/41_custom ###
volker@marvin:~$ 

Da fällt mir jetzt Zeile 69 unangenehm auf ☺

--ks

san04

Anmeldungsdatum:
19. Januar 2010

Beiträge: 1247

Kreuzschnabel schrieb:

Einzige Besonderheit ist btrfs statt ext4 als Dateisystem für root- und home-Partition.

Und die /etc/fstab?

Keine separate Boot-Partition, sondern innerhalb der btrfs-formatierten root?

Hab ich so keine Erfahrung mit... Bei einem verschlüsselten btrfs hab ich dann direkt boot in die ESP installiert, damit ist sie dann wieder FAT-formatiert.

Kreuzschnabel

(Themenstarter)

Anmeldungsdatum:
12. Dezember 2011

Beiträge: 1331

san04 schrieb:

Kreuzschnabel schrieb:

Einzige Besonderheit ist btrfs statt ext4 als Dateisystem für root- und home-Partition.

Und die /etc/fstab?

Wo die ist? In der root-Partition. Oder was meinst du?

Keine separate Boot-Partition, sondern innerhalb der btrfs-formatierten root?

Ja. Physisch sind es (außer Swap ud ESP) zwei Partitionen, eine / mit allem plus eine /home.

Sollte ich dann vielleicht ändern ☺ aber da in den Eingeweiden hab ich auch noch nie rumgewerkelt. Oder warten, bis Grub auch btrfs spricht.

--ks

Lidux

Anmeldungsdatum:
18. April 2007

Beiträge: 16658

Hallo Kreuzschnabel,

Und die komplette /etc/fstab?

Die andere selbsterstellte zz.cfg woandershin schieben.

Sowie hidden in menue ändern.

Gruss Lidux

san04

Anmeldungsdatum:
19. Januar 2010

Beiträge: 1247

Kreuzschnabel schrieb:

san04 schrieb:

Kreuzschnabel schrieb:

Einzige Besonderheit ist btrfs statt ext4 als Dateisystem für root- und home-Partition.

Und die /etc/fstab?

Wo die ist? In der root-Partition. Oder was meinst du?

Ich meinte den Inhalt, weil du oben schriebst, dass ungefragt Änderungen erfolgt sind.

Kreuzschnabel

(Themenstarter)

Anmeldungsdatum:
12. Dezember 2011

Beiträge: 1331

san04 schrieb:

Ich meinte den Inhalt, weil du oben schriebst, dass ungefragt Änderungen erfolgt sind.

Änderungen kann man nicht sagen, es war eine Neuinstallation mit Einbindung der bestehenden /home. Die /etc/fstab wurde also neu erstellt, und dabei wurde ein subvol=@home als Option mit eingebaut, statt das Wurzelverzeichnis der /home-Partition zu mounten. Das kenne ich von extX-Partitionen noch nicht.

Sei’s drum – jetzt hab ich eine boot-Partition, ext2-formatiert (was brauch ich da Journaling), und alles läuft wie vorgesehen, kein Grub-Bootmenü mehr. Neuinstallation ist zwar eine lame Windowsmethode, aber geht bei Ubuntu ja schnell. Hat sich damit also erledigt mit dem Ergebnis, dass Grub2 einfach (noch) nicht so richtig mit btrfs kann und deshalb in einen kaum konfigurierbaren Panikmodus schaltet. Wird kommen. Aber mit separater boot-Partition fühlt sich son System auch gleich viel professioneller an.

Vielen Dank fürs Mitdenken und schöne Feiertage!

--ks

san04

Anmeldungsdatum:
19. Januar 2010

Beiträge: 1247

Der Installer von Ubuntu wurde glaube ich nur selten in höchsten Tönen gelobt 😈

Neuinstallation ist zwar eine lame Windowsmethode, aber geht bei Ubuntu ja schnell.

Wär aber auch ohne gegangen 😉

Hat sich damit also erledigt mit dem Ergebnis, dass Grub einfach (noch) nicht so richtig mit btrfs kann.

Aber prinzipiell lief das System doch, oder? Eigentlich unterstützt GRUB schon eine Weile btrfs Boot-Partitionen. Hast du die root-Partition direkt gemountet? oder auch mit subvol=@? Möglicherweise hat das GRUB ja nicht gepasst...

Vielen Dank fürs Mitdenken und schöne Feiertage!

Dir auch 👍

Kreuzschnabel

(Themenstarter)

Anmeldungsdatum:
12. Dezember 2011

Beiträge: 1331

san04 schrieb:

Neuinstallation ist zwar eine lame Windowsmethode, aber geht bei Ubuntu ja schnell.

Wär aber auch ohne gegangen 😉

Glaub ich dir gern, aber von meiner Seite aus nur mit zwei Stunden Schlaulesen und einer Stunde rumprobieren ☺ Alles neu drauf (Grundinstallation und mein Installationsskript mit der eigenen Software und Konfigurationen) ist in locker 40 Minuten durchgelaufen, und dann gehe ich davon aus, dass alles passt.

Aber prinzipiell lief das System doch, oder?

Ja, nur das Grub-Menü beim Start war ärgerlich.

Eigentlich unterstützt GRUB schon eine Weile btrfs Boot-Partitionen. Hast du die root-Partition direkt gemountet? oder auch mit subvol=@?

Mit subvol=@, wies der Installer vorgesehen hat. Die wurde bei der Installation ja neu formatiert. Ich weiß nicht, wie ich das beeinflussen kann, höchstens hinterher quer vom Livesystem aus.

--ks

Antworten |