mirror of
https://github.com/linuxkit/linuxkit.git
synced 2025-07-21 10:09:07 +00:00
149 lines
4.5 KiB
Markdown
149 lines
4.5 KiB
Markdown
# External Disk
|
|
`linuxkit run` has the ability to mount an external disk when booting. It involves two steps:
|
|
|
|
1. Make the disk available as a device
|
|
2. Mount the disk
|
|
|
|
## Make Disk Available
|
|
In order to make the disk available, you need to tell `linuxkit` where the disk file or block device is.
|
|
|
|
All local `linuxkit run` methods (currently `hyperkit`, `qemu`, `virtualization.framework` and `vmware`)
|
|
take a `-disk` argument:
|
|
|
|
* `-disk path,size=100M,format=qcow2`. For size the default is in GB but an `M` can be appended to specify sizes in MB. The format can be omitted for the platform default, and is only useful on `qemu` at present.
|
|
|
|
If a _path_ is specified `linuxkit` will use the disk at location _path_. If you do not provide `-disk ` _path_, `linuxkit` assumes a default path, which is _prefix_`-state/disk.img`.
|
|
|
|
If the disk at the specified or default _path_ does not exist, `linuxkit` will create one of size _size_.
|
|
|
|
The `-disk` specification may be repeated for multiple disks, although a limited number may be supported, and some platforms currently only support a single disk.
|
|
|
|
**TODO:** GCP
|
|
|
|
## Format the disk
|
|
|
|
`pkg/format` creates a partition table and format drives for use with LinuxKit
|
|
|
|
### Example Usage
|
|
|
|
This packages supports two modes of use:
|
|
|
|
```
|
|
onboot:
|
|
- name: format
|
|
image: linuxkit/format:<hash>
|
|
```
|
|
|
|
In this mode of operation, the first disk found that does not have a valid partition table
|
|
will have one linux partition created that fills the entire disk
|
|
|
|
### Options
|
|
|
|
```
|
|
onboot:
|
|
- name: format
|
|
image: linuxkit/format:<hash>
|
|
command: ["/usr/bin/format", "-type", "ext4", "-label", "DATA", "/dev/vda"]
|
|
```
|
|
|
|
```
|
|
onboot:
|
|
- name: format
|
|
image: linuxkit/format:<hash>
|
|
command: ["/usr/bin/format", "-force", "-type", "xfs", "-label", "DATA", "-verbose", "/dev/vda"]
|
|
```
|
|
|
|
```
|
|
onboot:
|
|
- name: format
|
|
image: linuxkit/format:<hash>
|
|
command: ["/usr/bin/format", "-type", "ext4", "-partition", "gpt", "/dev/vda"]
|
|
```
|
|
|
|
- `-force` can be used to force the partition to be cleared and recreated (if applicable), and the recreated partition formatted. This option would be used to re-init the partition on every boot, rather than persisting the partition between boots.
|
|
- `-label` can be used to give the disk a label
|
|
- `-type` can be used to specify the type. This is `ext4` by default but `btrfs` and `xfs` are also supported
|
|
- `-partition` can be used to specify the partition table type. This is `dos` by default but `gpt` is also supported
|
|
- `-verbose` enables verbose logging, which can be used to troubleshoot device auto-detection and (re-)partitioning
|
|
- The final (optional) argument specifies the device name
|
|
|
|
## Mount the disk
|
|
|
|
Once a disk has been prepared it will need to be mounted using `pkg/mount`
|
|
|
|
### Usage
|
|
|
|
**NOTE: Block devices may only be mounted in `/var` unless you have explicitly added an additional bind mount**
|
|
|
|
If no additional arguments are provided the first unmounted linux partition on the first block device is mounted to the mountpoint provided.
|
|
|
|
```
|
|
onboot:
|
|
- name: mount
|
|
image: linuxkit/mount:<hash>
|
|
command: ["/usr/bin/mountie", "/var/lib/docker"]
|
|
```
|
|
|
|
### Options
|
|
|
|
You can provide either a partition label, device name or disk UUID to specify which disk should be used.
|
|
For example:
|
|
|
|
```
|
|
onboot:
|
|
- name: mount
|
|
image: linuxkit/mount:<hash>
|
|
command: ["/usr/bin/mountie", "-label", "DATA", "/var/lib/docker" ]
|
|
```
|
|
|
|
```
|
|
onboot:
|
|
- name: mount
|
|
image: linuxkit/mount:<hash>
|
|
command: ["/usr/bin/mountie", "-uuid", "a-proper-uuid", "/var/lib/docker" ]
|
|
```
|
|
|
|
```
|
|
onboot:
|
|
- name: mount
|
|
image: linuxkit/mount:<hash>
|
|
command: ["/usr/bin/mountie", "-device", "/dev/sda1", "/var/lib/docker" ]
|
|
```
|
|
|
|
For compatibility with the standard `mount` command we also support providing the device name as a positional argument.
|
|
E.g
|
|
|
|
```
|
|
onboot:
|
|
- name: mount
|
|
image: linuxkit/mount:<hash>
|
|
command: ["/usr/bin/mountie", "/dev/sda1", "/var/lib/docker" ]
|
|
```
|
|
|
|
## Extending Partitions
|
|
|
|
`pkg/extend` can extends a single partition to fill the entire disk
|
|
|
|
### Usage
|
|
|
|
In the default mode of operation, any disks that are found and have a single partition and free space will have that partition extended.
|
|
|
|
```
|
|
onboot:
|
|
- name: extend
|
|
image: linuxkit/extend:<hash>
|
|
```
|
|
|
|
### Options
|
|
|
|
`-type` can be used to specify the type. The default is `ext4` but `btrfs` and `xfs` are also supported.
|
|
If you know the name of the disk that you wish to extend you may supply this as an argument
|
|
|
|
```
|
|
onboot:
|
|
- name: extend
|
|
image: linuxkit/extend:<hash>
|
|
command: ["/usr/bin/extend", "-type", "btrfs", "/dev/vda"]
|
|
```
|
|
|