Jump to content



Πώς να εγκαταστήσετε Linux (UEFI) σε εξωτερικό σκληρό/SSD χωρίς ο Grub να τα κάνει άνω-κάτω όλα …


gdp77

Recommended Posts

Πριν λίγα 24ωρα κυκλοφόρησε το ανανεωμένο Ubuntu 22.04 LTS, με πολλές σημαντικές βελτιώσεις, εκ των οποίων 3 με ενδιαφέρουν άμεσα:


1) linux Kernel 5.15
2) wayland display server αντί για X11
3) pipewire audio server αντί για pulse/alsa

 

Αυτές οι αλλαγές θα έρθουν και στο Linux Mint 21 (που θα βασίζεται σε Ubuntu 22.04), αλλά μέχρι τότε ήμουν ανυπόμονος και ήθελα να τα δοκιμάσω, για να δω τη συμπεριφορά στο δικό μου σύστημα.

 

Η λύση ήταν να εγκαταστήσω το Ubuntu 22.04 σε έναν εξωτερικό δίσκο και να boot-άρω από εκεί όποτε ήθελα να κάνω τις δοκιμές μου, χωρίς να επηρεαστεί το σύστημά μου. Θα ρωτήσει κανείς γιατί χρειαζόταν η εγκατάσταση. Λογικό, αλλά το Ubuntu 22.04 σε live παίζει σε X11 για μέγιστη συμβατότητα, ενώ η λύση δοκιμής σε VM δεν θα μου επέτρεπε να δω την πραγματική συμπεριφορά του Wayland με το hardware που έχω (ούτε και του pipewire), μια που η εικονική μηχανή εμφανίζει άλλες συσκευές.

 

Πάω λοιπόν να ξεκινήσω τη διαδικασία, έχω έτοιμο ένα boot-able στικάκι και τον δίσκο που θα γίνει η εγκατάσταση. Εδώ να σημειώσω ότι ξέρω ότι ο πιο ασφαλής τρόπος να γίνουν τέτοια πράγματα είναι να αποσυνδέσεις όλους του υφιστάμενους δίσκους, για να είσαι σίγουρος ότι δεν θα υπάρξουν απρόβλεπτες εξελίξεις. Άβολο. Άντε και αποσυνδέεις τους SATA δίσκους τραβώντας τα καλώδια, αλλά να αποσυνδέσεις τον NVME για να κάνεις τις δοκιμές σου είναι μανούρα μεγάλη. Επίσης δεν μπορούσα να απενεργοποιήσω τον Nvme από το BIOS, δεν υπήρχε επιλογή. Οπότε προχώρησα με τα πάντα όλα συνδεδεμένα, έχοντας κατά νου να είμαι εξαιρετικά προσεκτικός μη στραβώσει κάτι.

Έχω πολλούς δίσκους στο σύστημα, αλλά αυτοί που μας ενδιαφέρουν είναι οι εξής:

 

1072502891_Untitled1.jpg.99a64b15cc14b0de2e5417f579b92680.jpg

 

Εκκινώ λοιπόν με το στικάκι, μπαίνω σε live περιβάλλον, όλα καλά, πάμε για install. Με εξαιρετική προσοχή διαμόρφωσα τον sda για να εγκατασταθεί το Ubuntu και διπλοτσέκαρα ότι επέλεξα να εγκατασταθεί ο grub στο sda και όχι κάπου αλλού.

 

Ολοκληρώνεται η εγκατάσταση σε λίγα λεπτά και boot-άρω από τον sda. Ωραιότατα. Μου έδινε και επιλογές αν ήθελα να μπω στο mint ή στα Win (που είναι θυμίζω στον nvme). Περιεργάζομαι λίγο το περιβάλλον του Ubuntu και αποφασίζω να μπω στο κανονικό μου σύστημα. Επιλέγω restart, το σύστημα κάνει post, αποσυνδέω τον sda και περιμένω να εμφανιστεί το γνώριμο σε εμένα grub από τον nvme (του έχω βάλει και ένα ωραίο theme). Μάταια…. Το σύστημα μπαίνει σε grub cmd περιβάλλον… Έλεος…

 

Αποδείχτηκε ότι ο grub που εγκαταστάθηκε στον sda είχε αποφασίσει να “διαγράψει” ??? τον grub που ήταν εγκατεστημένος στον nvme. Το σύστημα πλέον μπορούσε να μπουτάρει μόνο έχοντας τον sda συνδεδεμένο…

 

Εντάξει δεν ήταν κάτι που δεν μπόρεσα να φτιάξω σε 5 λεπτά… Μπούταρα στο mint και ένα

sudo grub-install /dev/nvme0n1

έλυσε το πρόβλημα.

 

Τώρα όμως ο grub εγκατάστηθε στον nvme και δεν μπορούσα να μπουτάρω από τον sda…

 

Για κάποιον λόγο ο grub θέλει να είναι σε ένα μόνο μέρος ή εγώ δεν ξέρω τον τρόπο να το φτιάξω.

 

Ψάχτηκα αρκετά στο διαδίκτυο για αυτό το εξεζητημένο σενάριο χρήσης και τελικά ανακάλυψα τον σωστό τρόπο για να πετύχετε εγκατάσταση ενός Linux OS σε εξωτερικό σκληρό (λογικά δουλεύει και σε εσωτερικό) χωρίς ο grub να κάνει τα δικά του.

 

ΠΡΟΣΟΧΗ ΠΑΝΤΑ ΕΧΟΥΜΕ ΠΛΗΡΕΣ BACKUP ΠΡΙΝ ΕΠΙΧΕΙΡΗΣΟΥΜΕ ΤΕΤΟΙΕΣ ΔΙΑΔΙΚΑΣΙΕΣ.

 

1) Boot με το live media

 

2) Από live περιβάλλον τρέχουμε gparted, ΠΡΙΝ ΠΡΟΧΩΡΗΣΟΥΜΕ σε εγκατάσταση και πάμε και βρίσκουμε τον boot δίσκο μας και συγκεκριμένα το EFI (fat32) partition στον δίσκο μας.

 

444901757_Screenshotfrom2022-04-2209-01-17.png.f6cda4b0357f6cf360347496ea0dad13.png

 

3) Δεξί κλικ στο efi partition-→manage flags

 

Untitled.thumb.png.7265cbb63096bcff1201f2ff4a5327ad.png

 

4) Θα δούμε τσεκαρισμένο το flag ESP (και πιθανόν κάποια άλλα). Τα σημειώνουμε.

 

Untitled2.thumb.jpg.b6670f7068ac59bf054074504fb63146.jpg

 

5) Καταργούμε το flag ESP και close.

 

6) Τώρα πάμε και τρέχουμε τον installer και όταν θα μας ρωτήσει πού θέλουμε να εγκαταστήμουμε το λειτουργικό επιλέγουμε “do something else”.

 

7) Στον δίσκο που θα εγκαταστήσουμε το λειτουργικό, φτιάγνουμε δύο partitions, ένα EFI 300 MB (για σιγουριά) και ένα ext4 partition ως “/”. (Όταν έπαιρνα τα screenshots σε μένα είχε δει τον δίσκο σαν sdb). ΠΡΟΣΟΧΗ ΝΑ ΕΠΙΛΕΞΟΥΜΕ ΣΤΟ ΚΑΤΩ ΜΕΡΟΣ ΝΑ ΕΓΚΑΣΤΑΣΤΗΘΕΙ Ο GRUB ΣΤΟΝ ΕΞΩΤΕΡΙΚΟ ΔΙΣΚΟ και όχι κάπου αλλού

 

Untitled3.thumb.jpg.f2a088a51733397881e46298e3d42af8.jpg

 

8 ) Προχωράμε με “install now” και όταν ολοκληρωθεί η εγκατάσταση ΔΕΝ ΚΑΝΟΥΜΕ restart

 

9) Ανοίγουμε gparted πάλι και πάμε και επαναφέρουμε τα flags στο partition EFI του εσωτερικού boot δίσκου μας.

 

Αυτό ήταν! Τώρα θα μπορείτε να μπουτάρετε από τον εξωτερικό δίσκο όποτε είναι συνδεδεμένος, ή από τον εσωτερικό boot δίσκο σας όταν είναι αποσυνδεδεμένος ο εξωτερικός. Σε μένα χρειάστηκε ένα ακόμα βήμα γιατί είχε αλλαχθεί το boot order στο UEFI bios της μητρικής μου, πήγα και το έφτιαξα, δεν είναι τίποτα. Δεν ξέρω αν θα συμβεί σε κάθε περίπτωση.

Έγινε επεξεργασία από gdp77
  • Like 9
Link to comment
Share on other sites

On 24/4/2022 at 9:29 ΠΜ, το μέλος gdp77 έγραψε:

2) wayland display server αντί για X11

 

Δοκίμασε να κάνεις share full screen :D

 

 

On 24/4/2022 at 9:29 ΠΜ, το μέλος gdp77 έγραψε:

Για κάποιον λόγο ο grub θέλει να είναι σε ένα μόνο μέρος ή εγώ δεν ξέρω τον τρόπο να το φτιάξω.

 

Grub μπορείς να έχεις και σε κάθε δίσκο. Το θέμα είναι ποιος είναι ο πρωτεύων δίσκος στο BIOS

Αν είχες επιλέξει να μπούνε όλα στον εξωτερικό, δύσκολο να πειράχτηκε το GRUB του εσωτερικού (κάνε reproduce και φέρε logs 😛 )

linux-wallpapers-dreamwallpapers.co_.uk_
WWW.CRYBIT.COM

Have you ever wondered about the processes behind a system boot up? Yeah, as a SysAdmin, it’s very important to know about the...

 

 

On 24/4/2022 at 9:29 ΠΜ, το μέλος gdp77 έγραψε:

5) Καταργούμε το flag ESP και close.

 

Αυτό δεν άλλαξε κάτι. Εκτός αν ο σάπιος Ubuntu installer αποφασίζει να σκανάρει όλα τα ESPartitions και να τους χαλάσει το GRUB 😛

WWW.DISKPART.COM

What is EFI system partition and is it possible to delete the ESP when you no longer need it? Here comes the detailed explanation.
apple-touch-icon@2.png?v=32fb07f7ce26
UNIX.STACKEXCHANGE.COM

When installing Linux, there is an option to set a partition as bootable flag. Do you need to have this option turned on if you are installing...

 

 

On 24/4/2022 at 9:29 ΠΜ, το μέλος gdp77 έγραψε:

Αυτό ήταν! Τώρα θα μπορείτε να μπουτάρετε από τον εξωτερικό δίσκο όποτε είναι συνδεδεμένος, ή από τον εσωτερικό boot δίσκο σας όταν είναι αποσυνδεδεμένος ο εξωτερικός. Σε μένα χρειάστηκε ένα ακόμα βήμα γιατί είχε αλλαχθεί το boot order στο UEFI bios της μητρικής μου, πήγα και το έφτιαξα, δεν είναι τίποτα. Δεν ξέρω αν θα συμβεί σε κάθε περίπτωση.

 

Η εικασία μου είναι ότι κάτι στράβωσε στην αρχική εγκατάσταση.

Τώρα αν δεν κάνω λάθος, έχεις Boot Order : USB first, then internal

Όταν συνδέεις USB, κοιτάει το GPT -> GRUB του USB δισκου

Όταν αποσυνδέεις USB, κοιτάει το GPT -> GRUB του εσωτερικού

(κοινώς έχεις 2 GRUB)

Έγινε επεξεργασία από l2phile
Link to comment
Share on other sites

37 λεπτά πριν, το μέλος l2phile έγραψε:

 

 

 

 

 

 

Η εικασία μου είναι ότι κάτι στράβωσε στην αρχική εγκατάσταση.

Τώρα αν δεν κάνω λάθος, έχεις Boot Order : USB first, then internal

Όταν συνδέεις USB, κοιτάει το GPT -> GRUB του USB δισκου

Όταν αποσυνδέεις USB, κοιτάει το GPT -> GRUB του εσωτερικού

(κοινώς έχεις 2 GRUB)

 

Αυτό που πιθανόν να επηρέασε τη διαδικασία είναι ότι ο nvme μου είναι GPT formatted, ενώ ο εξωτερικός SSD που εγκατέστησα το 22.04 είναι MBR. 

 

Ναι όντως κάτι στράβωσε στην 1η εγκατάσταση και για αυτό, κατόπιν έρευνας για το θέμα, κατέληξα στην διαδικασία που περιγράφω με κάποια "extra steps" για να είμαστε σίγουροι ότι δεν θα "στράβωνε" ξανά. 

 

Από 'κει και πέρα, αν κάποιος καταφέρει να εγκαταστήσει Linux σε εξωτερικό δίσκο χωρίς να πειραχτεί ο υφιστάμενος grub σε κάποιον εσωτερικό του δίσκο και χωρίς τα βήματα που αναφέρω πιο πάνω, ας ποστάρει εδώ.

 

ΥΓ. Για να ακριβολογήσω grub μπορούμε να έχουμε σε πολλούς δίσκους πράγματι. Το θέμα είναι πού γράφεται το "bootable sector" και σε ποια εγκατεστημένη εγγραφή grub (εντός του EFI partition) δείχνει

 

YΓ 2 στον nvme μου υπάρχει dual boot win/linux εγκατάσταση. Πιθανόν και οι εγγραφές των Windows στο EFI κάπως να δημιούργησαν πρόβλημα εξ'αρχής.

Έγινε επεξεργασία από gdp77
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Δημιουργία...

Important Information

Ο ιστότοπος theLab.gr χρησιμοποιεί cookies για να διασφαλίσει την καλύτερη εμπειρία σας κατά την περιήγηση. Μπορείτε να προσαρμόσετε τις ρυθμίσεις των cookies σας , διαφορετικά θα υποθέσουμε ότι είστε εντάξει για να συνεχίσετε.