How to custom partition layout #
When users use the default ros install
, ROS will automatically create one partition on the root disk.
It will be the only partition with the label RANCHER_STATE.
But sometimes users want to be able to customize the root disk partition to isolate the data.
The following defaults to MBR mode, GPT mode has not been tested.
Partions #
RANCHER_STATE #
As mentioned above, the default mode is that ROS will automatically create one partition with the label RANCHER_STATE.
In addition, we can have other partitions, e.g.: two partitions, one is RANCHER_STATE and the other is a normal partition.
First boot a ROS instance from ISO, then manually format and partition /dev/sda
, the reference configuration is as follows:
[root@burmilla oem]# fdisk -l
Disk /dev/sda: 5 GiB, 5377622016 bytes, 10503168 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x9fff87e9
Device Boot Start End Sectors Size Id Type
/dev/sda1 * 2048 7503167 7501120 3.6G 83 Linux
/dev/sda2 7503872 10503167 2999296 1.4G 83 Linux
[root@burmilla oem]# blkid
/dev/sda1: LABEL="RANCHER_STATE" UUID="512f212b-3130-458e-a2d1-1d601c34d4e4" TYPE="ext4" PARTUUID="9fff87e9-01"
/dev/sda2: UUID="3828e3ac-b825-4898-9072-45da9d37c2a6" TYPE="ext4" PARTUUID="9fff87e9-02"
Then install ROS to the disk with ros install -t noformat -d /dev/sda ...
.
After rebooting, you can use /dev/sda2
. For example, changing the data root of user-docker:
$ ros config set mounts '[["/dev/sda2","/mnt/s","ext4",""]]’
$ ros config set rancher.docker.graph /mnt/s
$ reboot
In this mode, the RANCHER_STATE partition capacity cannot exceed 3.8GiB, otherwise the bootloader may not recognize the boot disk. This is the test result on VirtualBox.
RANCHER_BOOT #
When you only use the RANCHER_STATE partition, the bootloader will be installed in the /boot
directory.
$ system-docker run -it --rm -v /:/host alpine
ls /host/boot
...
If you want to use a separate boot partition, you also need to boot a ROS instance from ISO, then manually format and partition /dev/sda
:
[root@burmilla burmilla]# fdisk -l
Disk /dev/sda: 5 GiB, 5377622016 bytes, 10503168 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0xe32b3025
Device Boot Start End Sectors Size Id Type
/dev/sda1 2048 2503167 2501120 1.2G 83 Linux
/dev/sda2 2504704 7503167 4998464 2.4G 83 Linux
/dev/sda3 7503872 10503167 2999296 1.4G 83 Linux
[root@burmilla burmilla]# mkfs.ext4 -L RANCHER_BOOT /dev/sda1
[root@burmilla burmilla]# mkfs.ext4 -L RANCHER_STATE /dev/sda2
[root@burmilla burmilla]# mkfs.ext4 /dev/sda3
[root@burmilla burmilla]# blkid
/dev/sda1: LABEL="RANCHER_BOOT" UUID="43baeac3-11f3-4eed-acfa-64daf66b26c8" TYPE="ext4" PARTUUID="e32b3025-01"
/dev/sda2: LABEL="RANCHER_STATE" UUID="16f1ecef-dbe4-42a2-87a1-611939684e0b" TYPE="ext4" PARTUUID="e32b3025-02"
/dev/sda3: UUID="9f34e161-0eee-48f9-93de-3b7c54dea437" TYPE="ext4" PARTUUID="c9b8f181-03"
Then install ROS to the disk with ros install -t noformat -d /dev/sda ...
.
After rebooting, you can check the boot partition:
[root@burmilla burmilla]# mkdir /boot
[root@burmilla burmilla]# mount /dev/sda1 /boot
[root@burmilla burmilla]# ls -ahl /boot/
total 175388
drwxr-xr-x 4 root root 4.0K Sep 27 03:35 .
drwxr-xr-x 1 root root 4.0K Sep 27 03:38 ..
-rw-r--r-- 1 root root 24 Sep 27 03:05 append
-rw-r--r-- 1 root root 128 Sep 27 03:35 global.cfg
-rw-r--r-- 1 root root 96.8M Sep 27 03:05 initrd
If you are not using the first partition as a BOOT partition, you need to set BOOT flag via the fdisk tool.
In this mode, the RANCHER_BOOT partition capacity cannot exceed 3.8GiB, otherwise the bootloader may not recognize the boot disk. This is the test result on VirtualBox.
BURMILLA_OEM #
If you format any partition with the label BURMILLA_OEM, ROS will mount this partition to /usr/share/ros/oem
:
[root@burmilla burmilla]# blkid
/dev/sda2: LABEL="BURMILLA_OEM" UUID="4f438455-63a3-4d29-ac90-50adbeced412" TYPE="ext4" PARTUUID="9fff87e9-02"
[root@burmilla burmilla]# df -hT | grep sda2
/dev/sda2 ext4 1.4G 4.3M 1.3G 0% /usr/share/ros/oem
Currently, this OEM directory is hardcoded and not configurable.
BURMILLA_SWAP #
Suppose you have a partition(/dev/sda2
) and you want to use it as a SWAP partition:
$ mkswap -L BURMILLA_SWAP /dev/sda2
$ blkid
/dev/sda1: LABEL="RANCHER_STATE" UUID="512f212b-3130-458e-a2d1-1d601c34d4e4" TYPE="ext4" PARTUUID="9fff87e9-01"
/dev/sda2: LABEL="BURMILLA_SWAP" UUID="772b6e76-f89c-458e-931e-10902d78d3e4" TYPE="swap" PARTUUID="9fff87e9-02"
After you install ROS to the disk, you can add the runcmd
to enable SWAP:
runcmd:
- swapon -L BURMILLA_SWAP
Then check the memory information:
[root@burmilla burmilla]# free -m
total used free shared buffers cached
Mem: 1996 774 1221 237 20 614
-/+ buffers/cache: 139 1856
Swap: 487 0 487