2017-07-13 19:08:15 -04:00
|
|
|
# nvme-cli {#nvme-cli}
|
|
|
|
|
|
|
|
# nvme-cli with SPDK Getting Started Guide
|
|
|
|
|
2018-01-12 02:45:39 -05:00
|
|
|
Now nvme-cli can support both kernel driver and SPDK user mode driver for most of its available commands and
|
|
|
|
Intel specific commands.
|
2017-07-13 19:08:15 -04:00
|
|
|
|
2018-10-29 06:43:05 -04:00
|
|
|
1. Clone the nvme-cli repository from the SPDK GitHub fork. Make sure you check out the spdk-1.6 branch.
|
2017-07-13 19:08:15 -04:00
|
|
|
~~~{.sh}
|
2018-10-29 06:43:05 -04:00
|
|
|
git clone -b spdk-1.6 https://github.com/spdk/nvme-cli.git
|
2017-07-13 19:08:15 -04:00
|
|
|
~~~
|
|
|
|
|
|
|
|
2. Clone the SPDK repository from https://github.com/spdk/spdk under the nvme-cli folder.
|
|
|
|
|
|
|
|
3. Refer to the "README.md" under SPDK folder to properly build SPDK.
|
|
|
|
|
|
|
|
4. Refer to the "README.md" under nvme-cli folder to properly build nvme-cli.
|
|
|
|
|
|
|
|
5. Execute "<spdk_folder>/scripts/setup.sh" with the "root" account.
|
|
|
|
|
|
|
|
6. Update the "spdk.conf" file under nvme-cli folder to properly configure the SPDK. Notes as following:
|
|
|
|
~~~{.sh}
|
2018-11-15 15:46:18 -07:00
|
|
|
spdk=1
|
|
|
|
Indicates whether or not to use spdk. Can be 0 (off) or 1 (on).
|
|
|
|
Defaults to 1 which assumes that you have run "<spdk_folder>/scripts/setup.sh", unbinding your drives from the kernel.
|
|
|
|
|
2017-07-13 19:08:15 -04:00
|
|
|
|
2018-11-12 13:48:31 +08:00
|
|
|
core_mask=0x1
|
2018-11-15 15:46:18 -07:00
|
|
|
A bitmask representing which core(s) to use for nvme-cli operations.
|
2018-11-12 13:48:31 +08:00
|
|
|
Defaults to core 0.
|
2017-07-13 19:08:15 -04:00
|
|
|
|
|
|
|
mem_size=512
|
2018-11-15 15:46:18 -07:00
|
|
|
The amount of reserved hugepage memory to use for nvme-cli (in MB).
|
|
|
|
Defaults to 512MB.
|
2017-07-13 19:08:15 -04:00
|
|
|
|
2018-11-15 15:46:18 -07:00
|
|
|
shm_id=0
|
|
|
|
Indicates the shared memory ID for the spdk application with which your NVMe drives are associated,
|
|
|
|
and should be adjusted accordingly.
|
|
|
|
Defaults to 0.
|
2017-07-13 19:08:15 -04:00
|
|
|
~~~
|
|
|
|
|
|
|
|
7. Run the "./nvme list" command to get the domain:bus:device.function for each found NVMe SSD.
|
|
|
|
|
|
|
|
8. Run the other nvme commands with domain:bus:device.function instead of "/dev/nvmeX" for the specified device.
|
|
|
|
~~~{.sh}
|
|
|
|
Example: ./nvme smart-log 0000:01:00.0
|
|
|
|
~~~
|
|
|
|
|
2018-01-12 02:45:39 -05:00
|
|
|
9. Run the "./nvme intel" commands for Intel specific commands against Intel NVMe SSD.
|
|
|
|
~~~{.sh}
|
|
|
|
Example: ./nvme intel internal-log 0000:08:00.0
|
|
|
|
~~~
|
|
|
|
|
|
|
|
10. Execute "<spdk_folder>/scripts/setup.sh reset" with the "root" account and update "spdk=0" in spdk.conf to
|
2017-07-13 19:08:15 -04:00
|
|
|
use the kernel driver if wanted.
|
|
|
|
|
|
|
|
## Use scenarios
|
|
|
|
|
|
|
|
### Run as the only SPDK application on the system
|
|
|
|
1. Modify the spdk to 1 in spdk.conf. If the system has fewer cores or less memory, update the spdk.conf accordingly.
|
|
|
|
|
|
|
|
### Run together with other running SPDK applications on shared NVMe SSDs
|
|
|
|
1. For the other running SPDK application, start with the parameter like "-i 1" to have the same "shm_id".
|
|
|
|
|
|
|
|
2. Use the default spdk.conf setting where "shm_id=1" to start the nvme-cli.
|
|
|
|
|
|
|
|
3. If other SPDK applications run with different shm_id parameter, update the "spdk.conf" accordingly.
|
|
|
|
|
|
|
|
### Run with other running SPDK applications on non-shared NVMe SSDs
|
|
|
|
1. Properly configure the other running SPDK applications.
|
|
|
|
~~~{.sh}
|
|
|
|
a. Only access the NVMe SSDs it wants.
|
|
|
|
b. Allocate a fixed number of memory instead of all available memory.
|
|
|
|
~~~
|
|
|
|
|
|
|
|
2. Properly configure the spdk.conf setting for nvme-cli.
|
|
|
|
~~~{.sh}
|
|
|
|
a. Not access the NVMe SSDs from other SPDK applications.
|
|
|
|
b. Change the mem_size to a proper size.
|
|
|
|
~~~
|
|
|
|
|
|
|
|
## Note
|
2018-01-12 02:45:39 -05:00
|
|
|
1. To run the newly built nvme-cli, either explicitly run as "./nvme" or added it into the $PATH to avoid
|
|
|
|
invoke other already installed version.
|
|
|
|
|
|
|
|
2. To run the newly built nvme-cli with SPDK support in arbitrary directory, copy "spdk.conf" to that
|
|
|
|
directory from the nvme cli folder and update the configuration as suggested.
|