如何在golang的容器中获取磁盘设备信息?

时间:2019-08-11 02:20:49

标签: docker

我想在Docker容器中获取Go或C ++语言的主机的所有磁盘设备。还需要更多信息,例如可用空间。我应该怎么办?或者这有可能吗?

1 个答案:

答案 0 :(得分:1)

Go或C ++没有什么特别的要求。您可以使用任何相关代码或库来检查Linux系统设备的磁盘空间或可用空间,因为docker容器提供的环境(通常是Linux环境)。

Docker解决方案

docker run --privileged <image> <program>将在容器中填充/dev文件系统,该文件系统包含与您的系统相关的设备文件,并允许容器访问这些设备。

用户解决方案

您将必须告诉您的用户,例如在DockerHub文档中或在错误消息中使用

--privileged标志

运行映像时,否则它将无法访问系统设备。

您应该从一些知识渊博的用户那里获得一些审查或犬儒主义。

赞:为什么需要它?

详细信息

根据Luc Juggery's blog on Medium

  

使用--privileged标志

     

使用--privileged标志运行容器可以为容器提供所有功能,还可以访问主机的设备(/ dev>文件夹下的所有内容)...

但是,他通过从无业游民运行docker使初学者感到困惑。

他还警告我们:

  

如果在运行容器时使用--privileged标志,请确保您知道自己在做什么。

我完全同意。 使用--privileged授予容器修改主机的权限。

从运行docker的Linux主机上更容易看到发生了什么。

示例1:

我们将从Linux主机启动一个ubuntu容器( --privileged),然后运行sfdisk查看磁盘分区,并运行ls -l /dev/s*查看磁盘设备。它不起作用,因为容器没有以这种方式访问​​主机的特权。容器的环境无法以任何方式扫描主机上的磁盘。

paul@somewhere:~$ docker run -it ubuntu /bin/bash
root@175db156cb32:/# sfdisk --list
(blank output)
root@175db156cb32:/# ls -l /dev/sd*
ls: cannot access '/dev/sd*': No such file or directory

示例2:

现在我们运行docker run --privileged

paul@somewhere:~$ docker run --privileged -it ubuntu /bin/bash
root@c62b42161444:/# sfdisk --list
Disk /dev/sda: 223.6 GiB, 240057409536 bytes, 468862128 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: gpt
Disk identifier: EE70993B-4640-4899-B142-18B89DD16CB8

Device         Start       End   Sectors   Size Type
/dev/sda1       2048    923647    921600   450M Windows recovery environment
/dev/sda2     923648   1128447    204800   100M EFI System
/dev/sda3    1128448   1161215     32768    16M Microsoft reserved
/dev/sda4    1161216 467810878 466649663 222.5G Microsoft basic data
/dev/sda5  467812352 468858879   1046528   511M Windows recovery environment


Disk /dev/sdb: 2.7 TiB, 3000592982016 bytes, 5860533168 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 4096 bytes
Disklabel type: gpt
Disk identifier: 2F514662-72A3-4126-9868-40CEB6ADA416

Device      Start        End    Sectors  Size Type
/dev/sdb1      34     262177     262144  128M Microsoft reserved
/dev/sdb2  264192 5860532223 5860268032  2.7T Microsoft basic data

Partition 1 does not start on physical sector boundary.


Disk /dev/sdc: 232.9 GiB, 250059350016 bytes, 488397168 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: 0x299c6114

Device     Boot     Start       End   Sectors   Size Id Type
/dev/sdc1  *         2048  89843711  89841664  42.9G 83 Linux
/dev/sdc2        89843712 480468991 390625280 186.3G 83 Linux
/dev/sdc3       480471038 488396799   7925762   3.8G  5 Extended
/dev/sdc5       480471040 488396799   7925760   3.8G 82 Linux swap / Solaris
root@c62b42161444:/# ls -l /dev/sd*
brw-rw---- 1 root disk 8,  0 Aug 11 02:43 /dev/sda
brw-rw---- 1 root disk 8,  1 Aug 11 02:43 /dev/sda1
brw-rw---- 1 root disk 8,  2 Aug 11 02:43 /dev/sda2
brw-rw---- 1 root disk 8,  3 Aug 11 02:43 /dev/sda3
brw-rw---- 1 root disk 8,  4 Aug 11 02:43 /dev/sda4
brw-rw---- 1 root disk 8,  5 Aug 11 02:43 /dev/sda5
brw-rw---- 1 root disk 8, 16 Aug 11 02:43 /dev/sdb
brw-rw---- 1 root disk 8, 17 Aug 11 02:43 /dev/sdb1
brw-rw---- 1 root disk 8, 18 Aug 11 02:43 /dev/sdb2
brw-rw---- 1 root disk 8, 32 Aug 11 02:43 /dev/sdc
brw-rw---- 1 root disk 8, 33 Aug 11 02:43 /dev/sdc1
brw-rw---- 1 root disk 8, 34 Aug 11 02:43 /dev/sdc2
brw-rw---- 1 root disk 8, 35 Aug 11 02:43 /dev/sdc3
brw-rw---- 1 root disk 8, 37 Aug 11 02:43 /dev/sdc5
root@c62b42161444:/# exit

和docker容器被允许访问主机设备。