Differenze tra le versioni di "Installare Arch Linux su ZFS"

Da GolemWiki.
Jump to navigation Jump to search
Riga 15: Riga 15:
 
Copiare il contenuto del pacchetto in una directory di lavoro, es.: ''/root/media''
 
Copiare il contenuto del pacchetto in una directory di lavoro, es.: ''/root/media''
 
  # cp -r /usr/share/archiso/configs/releng /root/media
 
  # cp -r /usr/share/archiso/configs/releng /root/media
 
  
 
Per aggiungere il supporto allo ZFS occorre:
 
Per aggiungere il supporto allo ZFS occorre:
Riga 44: Riga 43:
 
  # systemctl start sshd.service
 
  # systemctl start sshd.service
  
== Partizionamento ==
+
== Preparazione del disco ==
Per non dover ricorrere ad una partizione di /boot in un formato supportato da Linux (es.: ext2,3,4 o reiser) ed utilizzare ZFS come unico filesystem del sistema si consiglia di partizionare il disco secondo il nuovo formato [https://wiki.archlinux.org/index.php/GUID_Partition_Table GPT].
+
=== Cenni di teoria ===
 
+
Per fare a meno della tradizionale partizione di /boot ed utilizzare ZFS come unico filesystem si consiglia di partizionare il disco secondo il nuovo formato [https://wiki.archlinux.org/index.php/GUID_Partition_Table GPT].
 
 
  
You need to create two partitions on your devices. The first will be a small utility partition where Grub itself will be installed. The second is for your main zpool. Since the contents of the utility partition change very infrequently (only when Grub is upgraded), there's no need to mirror this partition with MDADM or similar. This partition serves the same purpose as the first few blocks of the MBR where Grub is traditionally installed. Giving Grub this additional utility partition is required since the total amount of code necessary to support ZFS is too big to fit in the usual boot locations.
+
Sarà comunque necessario creare due partizioni: una per il Grub ed una per gli [http://it.wikipedia.org/wiki/ZFS_(file_system)#I_pool_dello_storage zpool].  
  
In contrast to a traditional /boot partition where the kernel and initramfs are kept on the separate /boot partition, this arrangement allows the kernel and ramdisk to reside within ZFS and be mirrored or otherwise replicated by the normal ZFS logic.
+
La prima, denominata [http://en.wikipedia.org/wiki/BIOS_Boot_partition Bios Grub Partition], è concettualmente l'equivalente del MBR nei sistemi GPT. A differenza del MBR, la Bios Grub Partition può però essere sufficientemente grande da contenere il codice per il supporto allo ZFS.
 +
Il vantaggio sta nel fatto che a differenza della tradizionale partizione /boot dove risiedono anche kernel e ramdisk, il contenuto di quest'ultima cambia esclusivamente nei rari casi di upgrade del Grub.
  
# Create a bios_grub partition (type EF02) starting at 1MB with size 64MB.  The
+
=== Partizionamento ===
# 1MB offset is to ensure proper sector alignment for SSD's and other 4k sector drives.
+
Col seguente comando verrà creata la partizione di Grub (EF02) a partire dal 1MB, della grandezza di 64MB; il resto del disco resterà disponibile per lo i pool dello ZFS.
# After the utility partition, the rest of the drive is setup for ZFS. Repeat for all
+
Se avete più dischi da utilizzare in raid, questa operazione andrà ripetuta per ciascun disco.
# drives to be used in the pool.
 
 
 
  $ sgdisk \
 
    --new=1:2048:133120 --typecode=1:EF02 --change-name=1:"grub" \
 
    --largest-new=2 --typecode=2:BF01 --change-name=2:"zfs" \
 
    /dev/sda
 
  
 +
# sgdisk \
 +
--new=1:2048:133120 --typecode=1:EF02 --change-name=1:"grub" \
 +
--largest-new=2 --typecode=2:BF01 --change-name=2:"zfs" /dev/sda
  
# Create a pool:
+
=== ZFS pool ===
    $ zpool create rpool sda2
+
Creazione del pool principale
 +
# zpool create rpool sda2
  
#The zpool will initially be mounted at /rpool, but we need to move it to /mnt/ to work on it
+
Inizialmente il pool sarà montato in ''/rpool'', per i nostri scopi avremo bisogno di spostarlo in ''/mnt''
 +
# zfs unmount rpool
 +
# zfs set mountpoint=/mnt/ rpool
  
    $ zfs unmount rpool
+
Creazione del root dataset rpool/ROOT (necessario per il boot del sistema)
    $ zfs set mountpoint=/mnt/ rpool
+
# zfs create -o mountpoint=legacy rpool/ROOT
######################  $ zfs set canmount=off rpool
+
# zpool set bootfs=rpool/ROOT rpool
 
 
    $ zfs create -o mountpoint=legacy rpool/ROOT
 
    $ zpool set bootfs=rpool/ROOT rpool
 
 
      
 
      
#Now mount the root filesystem in the usual spot:
+
Montaggio del filesystem
 +
# mount -t zfs rpool/ROOT /mnt
  
    $ mount -t zfs rpool/ROOT /mnt
+
In aggiunta al root dataset è possibile crearne altri al fine di ottimizzare l'ordine del sistema, es.:
 +
# zfs create rpool/home
 +
# zfs create rpool/usr/src
 +
# zfs create rpool/var
 +
# zfs create rpool/srv
  
 +
'''NB:''' /bin, /boot, /sbin, /etc, /dev, /sys e /proc devono stare nel root dataset, non possono essere parte di sub-dataset.
  
# In addition to the root dataset, we'll create several other datasets to help keep things organized.
+
=== zpool cache ===
# Note that /bin, /boot, /sbin, /etc, /dev, /sys, and /proc must all be in the root dataset, not part of sub-datasets.
+
Configurare la cache degli zpool
 +
# zpool set cachefile=/etc/zfs/rpool.cache rpool
  
    $ zfs create rpool/home
+
Copiare il file di cache nel sistema dove dovremo eseguire il chroot per l'installazione.
    $ zfs create rpool/usr/src
+
# mkdir -p /mnt/etc/zfs
    $ zfs create rpool/var
+
# cp /etc/zfs/rpool.cache /mnt/etc/zfs/rpool.cache
    $ zfs create rpool/srv
 
  
  
# zpool set cachefile=/etc/zfs/rpool.cache rpool
+
== Installazione ==
 +
=== Pacchetti base ===
 +
# pacstrap /mnt base base-devel net-tools
  
Copy zpool.cache
+
=== Chroot ===
Now is also a good time to copy over the zpool cache so your initramfs will have access to it.
+
Effettuare il chroot nel nuovo sistama
 +
# arch-chroot /mnt
  
    $ mkdir -p /mnt/etc/zfs
+
==== Configurazione del sistema di base ====
    $ cp /etc/zfs/rpool.cache /mnt/etc/zfs/rpool.cache
+
Aggiungere la seguente riga nel file '''/etc/fstab''' per il mountpoint del filesystem
 +
rpool/ROOT      /               zfs         noatime    0 0
  
 +
Editare il file '''/etc/mkinitcpio.conf''' aggiungendo ''zfs'' prima del ''filesystem'' e spostare ''keyboard'' prima di ''zfs'', in modo che il vostro HOOKS assomigli a qualcosa di questo tipo
 +
HOOKS="base udev autodetect modconf block keyboard zfs filesystems"
  
 +
Aggiungere il repository per lo zfs nel ''pacman.conf'' del sistema Arch sotto chroot
 +
[demz-repo-core]
 +
Server = http://demizerone.com/$repo/$arch
 +
SigLevel = Never
  
# pacstrap /mnt base base-devel
+
Installare il supporto per lo ZFS
 
+
  # pacman -Sy
 
+
# pacman -S archzfs
 
 
#####################
 
#                  #
 
#      CHROOT      #
 
#                  #
 
#####################
 
 
 
# arch-chroot /mnt
 
 
 
 
 
# zpool set cachefile=/etc/zfs/rpool.cache rpool
 
 
 
 
 
I don't have uefi so I install the regular grub
 
# pacman -S grub
 
 
 
 
 
########################## DIVERSAMENTE  ########################################################
 
# mkdir /boot/EFI
 
# mount /dev/sda1 /boot/EFI
 
# grub-install --target=x86_64-efi --efi-directory=$esp --bootloader-id=grub --recheck --debug
 
# grub-mkconfig -o /boot/grub/grub.cfg
 
##################################################################################################
 
 
 
 
 
 
 
# nano /etc/fstab
 
rpool/ROOT      /              zfs        noatime    0 0
 
 
 
 
 
Edit /etc/mkinitcpio.conf and add zfs before filesystems. Also, move keyboard hook before zfs so you can type in console if something goes wrong. Your HOOKS line should look something like this:
 
 
 
HOOKS="base udev autodetect modconf block keyboard zfs filesystems"
 
 
 
 
 
Edit the pacman.conf in the chroot adding those lines
 
 
 
[demz-repo-core]
 
Server = http://demizerone.com/$repo/$arch
 
SigLevel = Never
 
 
 
# pacman -Sy
 
# pacman -S archzfs
 
 
 
 
 
To regenerate the initramfs with the command:
 
# mkinitcpio -p linux
 
 
 
# ln -s /usr/share/zoneinfo/Europe/Rome /etc/localtime
 
  
# nano /etc/vconsole.conf
+
In caso di necessità è possibile rigenerare il ramdisk col seguente comando
KEYMAP=it
+
# mkinitcpio -p linux
  
 +
Impostare il fuso orario
 +
# ln -s /usr/share/zoneinfo/Europe/Rome /etc/localtime
  
Create Swap (Optional)
+
Impostare la mappatura della tastiera
Running swap in ZVOL will currently deadlock when the system grows into swap.
+
# echo KEYMAP=it > /etc/vconsole.conf
If you NEED swap, you must create separate partitions for it and setup mdadm in necessary.
+
  
  Swap can be run from with the zpool as a zvol:
+
=== Boot loader ===
 +
Installazione del boot loader
 +
* Sistema con BIOS normale
 +
  # pacman -S grub
 +
# grub-mkconfig -o /boot/grub/grub.cfg
 +
# grub-install /dev/sda
  
    # Set size as desired. Checksum'ing isn't necessary for swap and turning it off improves performance.
+
* Sistema UEFI
 +
Per l'installazione su sistemi EFI
 +
# mkdir /boot/EFI
  
    $ zfs create -V 2G rpool/swap
 
    $ zfs set checksum=off rpool/swap
 
    $ swapon /dev/rpool/swap
 
    $ echo "/dev/rpool/swap    none    swap    sw    0 0" >> /mnt/etc/fstab
 
  
 +
# mount /dev/sda1 /boot/EFI
 +
# grub-install --target=x86_64-efi --efi-directory=$esp --bootloader-id=grub --recheck --debug
 +
# grub-mkconfig -o /boot/grub/grub.cfg
  
# grub-mkconfig -o /boot/grub/grub.cfg
 
# grub-install /dev/sda
 
  
 
Add  
 
Add  

Versione delle 14:30, 9 feb 2014

Requisiti

  • Un sistema funzionante con Arch Linux x86_64
  • Almeno 4 GB di RAM

Installation media

Dato che lo ZFS non è ufficialmente supportato da nessuna distribuzione Linux, tantomento da Arch, sarà necessario realizzare un'immagine live creata appositamente per questo scopo.

Archiso

A tale scopo, Arch Linux mette a disposizione un pacchetto, denominato Archiso, contenente una serie di script per la realizzazione di supporti per l'installazione.

# pacman -S archiso

Copiare il contenuto del pacchetto in una directory di lavoro, es.: /root/media

# cp -r /usr/share/archiso/configs/releng /root/media

Per aggiungere il supporto allo ZFS occorre:

  • Modificare le seguenti righe al file pacman.conf di archiso
[demz-repo-core]
SigLevel = Never
Server = http://demizerone.com/$repo/$arch
  • Aggiungere le seguenti righe al file packages.x86_64
spl-utils
spl
zfs-utils
zfs
net-tools
  • Lanciare lo script
# ./build.sh -v

L'immagine sarà generata nella directory /root/media/out

Boot col nuovo supporto (CD/USB)

Effettuare il boot e scegliere l'architettura x86_64, ZFS non è ben supportato su i686.

SSH

Si consiglia di abilitare il demone ssh ed effettuare il processo di installazione collegandosi da un altro computer così da poter effettuare copia ed incolla da questa o altre guide.

# systemctl enable sshd.service
# systemctl start sshd.service

Preparazione del disco

Cenni di teoria

Per fare a meno della tradizionale partizione di /boot ed utilizzare ZFS come unico filesystem si consiglia di partizionare il disco secondo il nuovo formato GPT.

Sarà comunque necessario creare due partizioni: una per il Grub ed una per gli zpool.

La prima, denominata Bios Grub Partition, è concettualmente l'equivalente del MBR nei sistemi GPT. A differenza del MBR, la Bios Grub Partition può però essere sufficientemente grande da contenere il codice per il supporto allo ZFS. Il vantaggio sta nel fatto che a differenza della tradizionale partizione /boot dove risiedono anche kernel e ramdisk, il contenuto di quest'ultima cambia esclusivamente nei rari casi di upgrade del Grub.

Partizionamento

Col seguente comando verrà creata la partizione di Grub (EF02) a partire dal 1MB, della grandezza di 64MB; il resto del disco resterà disponibile per lo i pool dello ZFS. Se avete più dischi da utilizzare in raid, questa operazione andrà ripetuta per ciascun disco.

# sgdisk \
--new=1:2048:133120 --typecode=1:EF02 --change-name=1:"grub" \
--largest-new=2 --typecode=2:BF01 --change-name=2:"zfs" /dev/sda

ZFS pool

Creazione del pool principale

# zpool create rpool sda2

Inizialmente il pool sarà montato in /rpool, per i nostri scopi avremo bisogno di spostarlo in /mnt

# zfs unmount rpool
# zfs set mountpoint=/mnt/ rpool

Creazione del root dataset rpool/ROOT (necessario per il boot del sistema)

# zfs create -o mountpoint=legacy rpool/ROOT
# zpool set bootfs=rpool/ROOT rpool
   

Montaggio del filesystem

# mount -t zfs rpool/ROOT /mnt

In aggiunta al root dataset è possibile crearne altri al fine di ottimizzare l'ordine del sistema, es.:

# zfs create rpool/home
# zfs create rpool/usr/src
# zfs create rpool/var
# zfs create rpool/srv

NB: /bin, /boot, /sbin, /etc, /dev, /sys e /proc devono stare nel root dataset, non possono essere parte di sub-dataset.

zpool cache

Configurare la cache degli zpool

# zpool set cachefile=/etc/zfs/rpool.cache rpool 

Copiare il file di cache nel sistema dove dovremo eseguire il chroot per l'installazione.

# mkdir -p /mnt/etc/zfs
# cp /etc/zfs/rpool.cache /mnt/etc/zfs/rpool.cache


Installazione

Pacchetti base

# pacstrap /mnt base base-devel net-tools

Chroot

Effettuare il chroot nel nuovo sistama

# arch-chroot /mnt 

Configurazione del sistema di base

Aggiungere la seguente riga nel file /etc/fstab per il mountpoint del filesystem

rpool/ROOT      /               zfs         noatime     0 0

Editare il file /etc/mkinitcpio.conf aggiungendo zfs prima del filesystem e spostare keyboard prima di zfs, in modo che il vostro HOOKS assomigli a qualcosa di questo tipo

HOOKS="base udev autodetect modconf block keyboard zfs filesystems"

Aggiungere il repository per lo zfs nel pacman.conf del sistema Arch sotto chroot

[demz-repo-core] 
Server = http://demizerone.com/$repo/$arch 
SigLevel = Never

Installare il supporto per lo ZFS

# pacman -Sy
# pacman -S archzfs

In caso di necessità è possibile rigenerare il ramdisk col seguente comando

# mkinitcpio -p linux

Impostare il fuso orario

# ln -s /usr/share/zoneinfo/Europe/Rome /etc/localtime 

Impostare la mappatura della tastiera

# echo KEYMAP=it > /etc/vconsole.conf 

Boot loader

Installazione del boot loader

  • Sistema con BIOS normale
# pacman -S grub
# grub-mkconfig -o /boot/grub/grub.cfg
# grub-install /dev/sda
  • Sistema UEFI

Per l'installazione su sistemi EFI

# mkdir /boot/EFI


# mount /dev/sda1 /boot/EFI
# grub-install --target=x86_64-efi --efi-directory=$esp --bootloader-id=grub --recheck --debug
# grub-mkconfig -o /boot/grub/grub.cfg


Add zfs=bootfs to the kernel line of grub.cfg


  1. systemctl enable zfs.service
  1. exit
  2. zfs unmount -a
  3. zfs set mountpoint=/ rpool
  1. cp /etc/zfs/rpool.cache /mnt/etc/zfs/rpool.cache
  1. zpool export rpool


After the first boot

If everything went fine up to this point, your system will boot. Once. For your system to be able to reboot without issues, you need to enable the zfs service and set the hostid. When running ZFS on root, the machine's hostid will not be available at the time of mounting the root filesystem. There are two solutions to this. You can either place your spl hostid in the kernel parameters in your boot loader. For example, adding spl.spl_hostid=0x00bab10c. The other solution is to make sure that there is a hostid in /etc/hostid, and then regenerate the initramfs image. Which will copy the hostid into the initramfs image.

# hostid > /etc/hostid
# mkinitcpio -p linux


Trucchi

Limitare l'utilizzo di RAM

# echo "options zfs zfs_arc_max=2147483648" > /etc/modprobe.d/zfs.conf


Bibliografia

https://github.com/pendor/gentoo-zfs-install/blob/master/install/GentooInstall.mdown

https://github.com/zfsonlinux/pkg-zfs/wiki/HOWTO-install-Ubuntu-to-a-Native-ZFS-Root-Filesystem

http://www.howtoforge.com/a-beginners-guide-to-btrfs

https://wiki.archlinux.org/index.php/Installing_Arch_Linux_on_ZFS

https://bbs.archlinux.org/viewtopic.php?pid=1365007#p1365007