Docker是一個虛擬化容器技術,可以在同一臺物理機上運行多個容器,每個容器與其他容器和主機隔離,同時共享主機的資源。在Docker中,我們可以使用VFIO技術來為容器提供物理設備的訪問。
原理
VFIO(Virtual Function I/O)技術是一種將物理設備映射到虛擬機的技術,它需要支持IOMMU(Input/Output Memory Management Unit)的CPU和配備定義了SR-IOV(Single Root I/O Virtualization)的網卡或其他I/O設備。IOMMU作為攔截設備IO請求的第一道屏障,它可以將設備I/O請求映射到虛擬地址空間中,從而實現對設備的隔離以及對虛擬機監管。
Docker要實現VFIO功能,需要以下步驟:
- 安裝支持VFIO技術的CPU和網卡資源
- 安裝支持IOMMU的核心模塊
- 為物理設備分配VF(Virtual Function)
- 將VF綁定到容器中
實現過程
一、安裝支持VFIO技術的CPU和網卡資源
確認CPU支持Intel VT-d或AMD-Vi技術,網卡需要支持SR-IOV技術,這些需求都是支持VFIO技術的前提。
二、安裝支持IOMMU的核心模塊
在Linux系統中,可以通過modprobe iommu命令來加載IOMMU模塊。對于Ubuntu安裝如下:
sudo apt install -y kmod
sudo modprobe vfio-pci
lsmod|grep vfio
三、為物理設備分配VF
可以通過配置grub或編輯/boot/grub/grub.cfg文件,增加iommu和iommu=pt這兩項參數的方式開啟IOMMU支持。關于SR-IOV技術的vNIC(虛擬網卡),同樣可以進行配置。
四、將VF綁定到容器中
在創建容器時,使用--device參數將VF設備掛載到容器中即可:docker run -it -d --name test --device=/dev/vfio/X test_image
啟動容器后,可以在容器中訪問對應的物理設備,完成對物理設備的隔離與訪問。