Проверка статуса Docker Desktop с использованием JSON-формата
На предыдущем шаге мы проверили статус Docker-демона, используя стандартный формат вывода команды docker info
. Хотя стандартный формат удобен для чтения человеком, он не идеален для программной обработки. На этом шаге мы научимся получать информацию о Docker в JSON-формате, который гораздо лучше подходит для скриптов и автоматизации.
Для получения вывода в JSON-формате мы можем использовать флаг --format
с командой docker info
и указать формат как json
.
Выполните следующую команду в терминале:
docker info --format '{{json .}}'
Разберём эту команду:
docker info
: Основная команда для получения системной информации Docker
--format '{{json .}}'
: Этот флаг указывает Docker форматировать вывод. Значение '{{json .}}'
использует синтаксис Go-шаблонов. .
представляет всю структуру данных, возвращаемую docker info
, а {{json .}}
форматирует эту структуру как JSON-строку.
После выполнения команды вы увидите ту же информацию, что и ранее, но теперь она будет представлена в виде единого валидного JSON-объекта. Вывод будет выглядеть примерно так (точное содержимое зависит от вашего окружения Docker):
{
"ID": "...",
"Containers": 0,
"ContainersRunning": 0,
"ContainersPaused": 0,
"ContainersStopped": 0,
"Images": 0,
"Driver": "overlay2",
"SystemStatus": null,
"Plugins": {
"Volume": ["local"],
"Network": ["bridge", "host", "ipvlan", "macvlan", "null", "overlay"],
"Authorization": null,
"Log": [
"awslogs",
"fluentd",
"gcplogs",
"gelf",
"journald",
"json-file",
"local",
"logentries",
"splunk",
"syslog"
]
},
"MemoryLimit": true,
"SwapLimit": true,
"KernelMemory": true,
"CpuCfsPeriod": true,
"CpuCfsQuota": true,
"CpuShares": true,
"CpuSet": true,
"PidsLimit": true,
"OomKillDisable": true,
"IPv4Forwarding": true,
"BridgeNfIptables": true,
"BridgeNfIp6tables": true,
"Debug": false,
"NFd": -1,
"OomScoreAdj": -1,
"Goroutines": -1,
"SystemTime": "...",
"LoggingDriver": "json-file",
"CgroupDriver": "cgroupfs",
"CgroupVersion": "1",
"NEventsListener": -1,
"KernelVersion": "...",
"OperatingSystem": "...",
"OSType": "linux",
"Architecture": "x86_64",
"IndexServerAddress": "https://index.docker.io/v1/",
"RegistryConfig": {
"AllowNondistributableArtifactsAfterDate": "2020-12-25T00:00:00Z",
"InsecureRegistryCIDRs": ["127.0.0.0/8"],
"IndexConfigs": {
"docker.io": {
"Name": "docker.io",
"Mirrors": [],
"Secure": true,
"Official": true
}
},
"Mirrors": []
},
"NCPU": -1,
"MemTotal": -1,
"GenericResources": null,
"DockerRootDir": "/var/lib/docker",
"HttpProxy": "",
"HttpsProxy": "",
"NoProxy": "",
"ExperimentalBuild": false,
"LiveRestoreEnabled": false,
"Runtimes": { "runc": { "path": "runc" } },
"DefaultRuntime": "runc",
"Swarm": {
"NodeID": "",
"LocalNodeState": "inactive",
"ControlAvailable": false,
"Error": "",
"RemoteManagers": null
},
"ContainerdCommit": { "ID": "...", "Expected": "..." },
"RuncCommit": { "ID": "...", "Expected": "..." },
"InitCommit": { "ID": "...", "Expected": "..." },
"SecurityOptions": ["apparmor", "seccomp"],
"ProductLicense": "",
"DefaultAddressPools": null,
"Warnings": null
}
Этот JSON-вывод может быть легко обработан скриптовыми языками или другими инструментами, что делает его очень полезным для автоматизации задач, связанных с Docker.