Linux - Disks and Filesystems: Difference between revisions

From Smithnet Wiki
Jump to navigation Jump to search
 
(6 intermediate revisions by the same user not shown)
Line 1: Line 1:


== iSCSI ==
== BTRFS ==
 
See also [https://btrfs.wiki.kernel.org/index.php/SysadminGuide here]
 
Create a RAID5 array for data and metadata:
mkfs.btrfs -L data -d raid5 -m raid5 -f /dev/sdc /dev/sdd /dev/sde
 
View usage:
btrfs filesystem usage /data
 
Look for btrfs filesystems:
blkid --match-token TYPE=btrfs
 
=== Subvolumes ===


* Block storage provider: iSCSI Target
Create subvolume:
* Storage client: iSCSI Initiator
  btrfs subvolume create /data/db
* Dynamic Discovery: Initiator sends  'SendTargets' request to a single IP/port and if the target listens on multiple names and addresses, all of them are sent in a form of TargetName and TargetAddress (IP:port#).
* See [https://en.wikipedia.org/wiki/ISCSI here] for background and IQN naming.


=== Target ===
Info:
btrfs subvolume list .
btrfs subvolume list /data
btrfs subvolume show /data/db


* Install package (and dependencies: targetcli
Delete subvolume:
* Choose/create local area for disk images: /iscsi_disks
  btrfs subvolume delete /data/db


Start admin utility:
Subvolumes can be mounted like separate filesystems
  targetcli
  mount -o subvol=/oldpath /dev/sda5 /newpath
/> cd /backstores/fileio
so the subvolume is now also visible under newpath
/backstores/fileio> create disk01 /iscsi_disks/disk01.img 10G
/backstores/fileio> cd /iscsi
/iscsi> create iqn.2000-01.com.example:storage.target01
/iscsi> cd iqn.2000-01.com.example:storage.target01/tpg1/luns
/iscsi/iqn.20...t01/tpg1/luns> create /backstores/fileio/disk01
/iscsi/iqn.20...t00/tpg1/luns> cd ../acls
/iscsi/iqn.20...t00/tpg1/acls> create iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...t00/tpg1/acls> cd iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...an-server01> set auth userid=someuser
/iscsi/iqn.20...an-server01> set auth password=somepass
exit


Other commands within targetcli:
See also [https://fedoramagazine.org/working-with-btrfs-subvolumes/ here]
ls
delete [object]
help


systemctl enable target
=== Compression ===
systemctl start target


If necessary, open firewall for 3260:
Mount with compression option in fstab:
  firewall-cmd --add-service=iscsi-target --permanent
  compress=zstd:1
firewall-cmd --reload
where the algorirm could also be lzo or zlib. Compression level can be increased to 2 or 3


See also [https://www.lisenet.com/2016/iscsi-target-and-initiator-configuration-on-rhel-7/ here]
Per-file/directory/subvolume compression is also available:
btrfs property get /somefile compression
btrfs property set /etc compression zlib


=== Initiator ===
Degragment:
  btrfs filesystem defragment -r /


Install package: iscsi-initiator-utils
=== Quotas ===


In /etc/iscsi/initiatorname.iscsi specify the iSCSI target:
See [https://btrfs.readthedocs.io/en/latest/Qgroups.html here].
InitiatorName=iqn.2000-01.com.example:initiator01


In /etc/iscsi/iscsid.conf:
== Disk Management ==
node.session.auth.authmethod = CHAP
node.session.auth.username = username
node.session.auth.password = password


Discover target:
=== LUKS Encryptioon ===
# iscsiadm -m discovery -t sendtargets -p san-server01
san-server01:3260,1 iqn.2000-01.com.example:storage.target01


More info:
Create an encrypted partition:
  iscsiadm -m node -o show
  cryptsetup --verify-passphrase luksFormat /dev/sdb1
...


Login:
See also [https://docs.redhat.com/en/documentation/red_hat_enterprise_linux/6/html/security_guide/chap-security_guide-encryption#sect-Security_Guide-LUKS_Disk_Encryption-LUKS_Implementation here] for other cypher options.
iscsiadm -m node --login


Confirm session:
Open the device (to create "/dev/mapper/protected"):
  iscsiadm -m session -o show
  cryptsetup luksOpen /dev/sdb1 protected


Confirm new device added (eg sdc):
Make filesystem:
  cat /proc/partitions
  mkfs.ext4 /dev/mapper/protected


Then, partition, format and mount /dev/sdc as normal.
Emtry om /etc/fstab:
/dev/mapper/protected /mnt/disk2 ext4 defaults 1 2


Logout of iSCSI (after unmounting used filesystems):
To allow partitions to be opened at boot:
  iscsiadm -m node --logout
  echo "datastore /dev/sdb1 none" >> /etc/crypttab


== Disk Management ==
On reboot, the password will be asked for to enable mounting.


=== General ===
=== General ===
Line 82: Line 77:
  lsblk
  lsblk
  dd bs=4M if=somedisk.iso of=/dev/sdb conv=fdatasync status=progress
  dd bs=4M if=somedisk.iso of=/dev/sdb conv=fdatasync status=progress
Show all block devices, and LVMs:
lvmdiskscan


=== Grub ===
=== Grub ===
Line 189: Line 187:
  (parted) mkpart logical
  (parted) mkpart logical
  (parted) mkpart "Data Store" ext4 0% 100%
  (parted) mkpart "Data Store" ext4 0% 100%
  (parted) rm
  (parted) rm <partnum>
  (parted) quit
  (parted) quit


Line 257: Line 255:
  mkfs.xfs -L /home /dev/mapper/vg0-lv0
  mkfs.xfs -L /home /dev/mapper/vg0-lv0


== BTRFS ==
== iSCSI ==
 
* Block storage provider: iSCSI Target
* Storage client: iSCSI Initiator
* Dynamic Discovery: Initiator sends  'SendTargets' request to a single IP/port and if the target listens on multiple names and addresses, all of them are sent in a form of TargetName and TargetAddress (IP:port#).
* See [https://en.wikipedia.org/wiki/ISCSI here] for background and IQN naming.
 
=== Target ===
 
* Install package (and dependencies: targetcli
* Choose/create local area for disk images: /iscsi_disks


See also [https://btrfs.wiki.kernel.org/index.php/SysadminGuide here]
Start admin utility:
targetcli
/> cd /backstores/fileio
/backstores/fileio> create disk01 /iscsi_disks/disk01.img 10G
/backstores/fileio> cd /iscsi
/iscsi> create iqn.2000-01.com.example:storage.target01
/iscsi> cd iqn.2000-01.com.example:storage.target01/tpg1/luns
/iscsi/iqn.20...t01/tpg1/luns> create /backstores/fileio/disk01
/iscsi/iqn.20...t00/tpg1/luns> cd ../acls
/iscsi/iqn.20...t00/tpg1/acls> create iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...t00/tpg1/acls> cd iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...an-server01> set auth userid=someuser
/iscsi/iqn.20...an-server01> set auth password=somepass
exit


Create a RAID5 array for data and metadata:
Other commands within targetcli:
  mkfs.btrfs -L data -d raid5 -m raid5 -f /dev/sdc /dev/sdd /dev/sde
  ls
delete [object]
help


View usage:
systemctl enable target
  btrfs filesystem usage /data
  systemctl start target


Look for btrfs filesystems:
If necessary, open firewall for 3260:
  blkid --match-token TYPE=btrfs
  firewall-cmd --add-service=iscsi-target --permanent
firewall-cmd --reload


=== Subvolumes ===
See also [https://www.lisenet.com/2016/iscsi-target-and-initiator-configuration-on-rhel-7/ here]


Create subvolume:
=== Initiator ===
  btrfs subvolume create /data/db


Info:
Install package: iscsi-initiator-utils
btrfs subvolume list .
btrfs subvolume list /data
btrfs subvolume show /data/db


Delete subvolume:
In /etc/iscsi/initiatorname.iscsi specify the iSCSI target:
  btrfs subvolume delete /data/db
InitiatorName=iqn.2000-01.com.example:initiator01


Subvolumes can be mounted like separate filesystems
In /etc/iscsi/iscsid.conf:
  mount -o subvol=/oldpath /dev/sda5 /newpath
node.session.auth.authmethod = CHAP
so the subvolume is now also visible under newpath
  node.session.auth.username = username
node.session.auth.password = password


See also [https://fedoramagazine.org/working-with-btrfs-subvolumes/ here]
Discover target:
# iscsiadm -m discovery -t sendtargets -p san-server01
san-server01:3260,1 iqn.2000-01.com.example:storage.target01


=== Compression ===
More info:
iscsiadm -m node -o show
...


Mount with compression option in fstab:
Login:
  compress=zstd:1
  iscsiadm -m node --login
where the algorirm could also be lzo or zlib. Compression level can be increased to 2 or 3


Per-file/directory/subvolume compression is also available:
Confirm session:
  btrfs property get /somefile compression
  iscsiadm -m session -o show
btrfs property set /etc compression zlib


Degragment:
Confirm new device added (eg sdc):
  btrfs filesystem defragment -r /
cat /proc/partitions


=== Quotas ===
Then, partition, format and mount /dev/sdc as normal.


See [https://btrfs.readthedocs.io/en/latest/Qgroups.html here].
Logout of iSCSI (after unmounting used filesystems):
iscsiadm -m node --logout


== Loopback Filesystem ==
== Loopback Filesystem ==

Latest revision as of 18:08, 12 July 2024

BTRFS

See also here

Create a RAID5 array for data and metadata:

mkfs.btrfs -L data -d raid5 -m raid5 -f /dev/sdc /dev/sdd /dev/sde

View usage:

btrfs filesystem usage /data

Look for btrfs filesystems:

blkid --match-token TYPE=btrfs

Subvolumes

Create subvolume:

 btrfs subvolume create /data/db

Info:

btrfs subvolume list .
btrfs subvolume list /data
btrfs subvolume show /data/db

Delete subvolume:

 btrfs subvolume delete /data/db

Subvolumes can be mounted like separate filesystems

mount -o subvol=/oldpath /dev/sda5 /newpath

so the subvolume is now also visible under newpath

See also here

Compression

Mount with compression option in fstab:

compress=zstd:1

where the algorirm could also be lzo or zlib. Compression level can be increased to 2 or 3

Per-file/directory/subvolume compression is also available:

btrfs property get /somefile compression
btrfs property set /etc compression zlib

Degragment:

 btrfs filesystem defragment -r /

Quotas

See here.

Disk Management

LUKS Encryptioon

Create an encrypted partition:

cryptsetup --verify-passphrase luksFormat /dev/sdb1

See also here for other cypher options.

Open the device (to create "/dev/mapper/protected"):

cryptsetup luksOpen /dev/sdb1 protected

Make filesystem:

mkfs.ext4 /dev/mapper/protected

Emtry om /etc/fstab:

/dev/mapper/protected /mnt/disk2 ext4 defaults 1 2

To allow partitions to be opened at boot:

echo "datastore /dev/sdb1 none" >> /etc/crypttab

On reboot, the password will be asked for to enable mounting.

General

Copy iso file to USB:

lsblk
dd bs=4M if=somedisk.iso of=/dev/sdb conv=fdatasync status=progress

Show all block devices, and LVMs:

lvmdiskscan

Grub

When installing on a RAID 1 mirror for the OS grub boot loader only installs on the first disk, so it that fails you can't boot off the second. To copy loader to the second disk:

grub> find /grub/stage1

This should find (hd0,0) and (hd1,0) which correspond for /dev/sda and /dev/sdb. Then temporarily make sdb the first disk and install:

device (hd0) /dev/sdb
root (hd0,0)
setup (hd0)

HD Parameters

Show settings/features:

hdparm -I /dev/sda

Test transfer rate:

hdparm -t --direct /dev/sda

Show power management setting:

hdparm -B /dev/sda

MD RAIDs

Create an array of 2 disks in a RAID1 (mirror):

mdadm --create /dev/md0 -l 1 -n 2 /dev/sdb1 /dev/sdc1

Monitor status with:

mdadm --detail /dev/md0
cat /proc/mdstat

Ensure RAID is detected at boot time:

mdadm -Es >> /etc/mdadm.conf

Remove a device from an array:

mdadm --remove /dev/md0 /dev/sdb1

Fail a drive in an array:

mdadm --fail /dev/md0 /dev/sdb1

Add a device to an array:

mdadm --add /dev/md0 /dev/sdb1

The /etc/cron.weekly/99-raid-check script can sometimes report:

WARNING: mismatch_cnt is not 0 on /dev/md1

The actual mismatch count can be found:

cat /sys/block/md1/md/mismatch_cnt

A repair and rebuild can be:

echo repair > /sys/block/md1/md/sync_action
echo check > /sys/block/md1/md/sync_action

Multipath

/sbin/mpconf --enable

Configuration:

  • /etc/multipath.conf
systemctl enable multipathd
systemctl start multipathd
multipath -ll

MP definitions:

       multipath {
              wwid                    a000443abababfeeeccce32c5000003ca
              alias                   data1
       }
       multipath {
              wwid                    a000443abababfeeeccce32c5000003cb
              alias                   datak2
       }

plus a device definition connecting to a hardware device.

Remove warnings for non-MP disks:

blacklist {
    devnode "sda"
}

Partitioning

FDisk

Supports MBR partitions

Parted

Supports MBR and GPT

See Manual and this.

parted /dev/sdb

Some commands:

(parted) print
(parted) print free
(parted) mklabel gpt
(parted) help mklabel
(parted) mkpart primary
(parted) mkpart logical
(parted) mkpart "Data Store" ext4 0% 100%
(parted) rm <partnum>
(parted) quit

LVM

Physical Volumes

To create a PV out of two partions:

pvcreate /dev/sdc1 /dev/sdd1

To show current PVs:

pvscan

Volume Groups

To create a VG:

vgcreate vg00 /dev/sd[cd]

To show all current VGs:

vgscan

To show details of a VG (including free PEs):

vgdisplay vg00

To extend a volume group by adding a new PV:

vgextend vg00 /dev/sde

To make a volume group available:

vgchange -ay vg00

Logical Volumes

To create a new LV:

lvcreate --size 100M vg00 -n lv00

or change --size option to --extents 500 or --extents 60%VG or -l 100%FREE

eg to create a RAID5 array out of 3 disks (2 data):

lvcreate -n lv00 --type raid5 -i 2 --extents 100%FREE vg00

Show status of LVM RAID:

lvs -a vg00

To rename a LV in VG vg01:

lvrename vg00 lvold lvnew

To remove a LV:

lvremove vg00/lv01

To show current LVs:

lvscan

Filesystems

To format with 1% minfree, large file support (see types in /etc/mke2fs.conf), journalling and a label:

mkfs.ext4 -m 1 -T largefile4 -j -L /home /dev/mapper/vg00-lv00

To alter the label:

e2label /dev/sda newlabel

To get the UUID of the disk:

blkid

To mount at boot time, enter in

  • /etc/fstab

Or to use XFS on a LV:

mkfs.xfs -L /home /dev/mapper/vg0-lv0

iSCSI

  • Block storage provider: iSCSI Target
  • Storage client: iSCSI Initiator
  • Dynamic Discovery: Initiator sends 'SendTargets' request to a single IP/port and if the target listens on multiple names and addresses, all of them are sent in a form of TargetName and TargetAddress (IP:port#).
  • See here for background and IQN naming.

Target

  • Install package (and dependencies: targetcli
  • Choose/create local area for disk images: /iscsi_disks

Start admin utility:

targetcli
/> cd /backstores/fileio
/backstores/fileio> create disk01 /iscsi_disks/disk01.img 10G
/backstores/fileio> cd /iscsi
/iscsi> create iqn.2000-01.com.example:storage.target01
/iscsi> cd iqn.2000-01.com.example:storage.target01/tpg1/luns
/iscsi/iqn.20...t01/tpg1/luns> create /backstores/fileio/disk01
/iscsi/iqn.20...t00/tpg1/luns> cd ../acls
/iscsi/iqn.20...t00/tpg1/acls> create iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...t00/tpg1/acls> cd iqn.2000-01.com.example:initiator01
/iscsi/iqn.20...an-server01> set auth userid=someuser
/iscsi/iqn.20...an-server01> set auth password=somepass
exit

Other commands within targetcli:

ls
delete [object]
help
systemctl enable target
systemctl start target

If necessary, open firewall for 3260:

firewall-cmd --add-service=iscsi-target --permanent
firewall-cmd --reload

See also here

Initiator

Install package: iscsi-initiator-utils

In /etc/iscsi/initiatorname.iscsi specify the iSCSI target:

InitiatorName=iqn.2000-01.com.example:initiator01

In /etc/iscsi/iscsid.conf:

node.session.auth.authmethod = CHAP
node.session.auth.username = username
node.session.auth.password = password

Discover target:

# iscsiadm -m discovery -t sendtargets -p san-server01
san-server01:3260,1 iqn.2000-01.com.example:storage.target01

More info:

iscsiadm -m node -o show
...

Login:

iscsiadm -m node --login

Confirm session:

iscsiadm -m session -o show

Confirm new device added (eg sdc):

cat /proc/partitions

Then, partition, format and mount /dev/sdc as normal.

Logout of iSCSI (after unmounting used filesystems):

iscsiadm -m node --logout

Loopback Filesystem

dd if=/dev/zero of=loopback.img bs=1024M count=5
losetup -fP loopback.img

To show loopback device(s):

losetup -a
losetup -l

To delete loopback device:

losetup -d /dev/loop0

Then, create filesystem, eg:

mkfs.xfs -L backups loopback.img

And mount /dev/loop0 (-o loop) as a traditional device. Note: the lo setup configuration is lost at restart so can't be added to /etc/fstab for at-boot mounting.

Smarttools

/etc/smartmontools/smartd.conf

Default to scan ATA/SCSI devices and report problems to root:

DEVICESCAN -H -m root -M exec /usr/libexec/smartmontools/smartdnotify -n standby,10,q

Or a specific device, and email an external user:

/dev/sda -a -o on -S on -s (S/../.././02|L/../../6/03) -m [email protected]

Scan for devices:

smartctl --scan

Show detailed information about a device:

smartctl --all /dev/sda