From d877ac3faecbee5ed64bc23665347d14706663c9 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期二, 24 十二月 2024 16:04:29 +0800 Subject: [PATCH] 操作docker容器 --- se-modules/se-docker/src/main/java/com/se/docker/service/SysDockerService.java | 73 +++++++++++++++++++++++++++++++++++- 1 files changed, 71 insertions(+), 2 deletions(-) diff --git a/se-modules/se-docker/src/main/java/com/se/docker/service/SysDockerService.java b/se-modules/se-docker/src/main/java/com/se/docker/service/SysDockerService.java index d97cab8..4ff3a04 100644 --- a/se-modules/se-docker/src/main/java/com/se/docker/service/SysDockerService.java +++ b/se-modules/se-docker/src/main/java/com/se/docker/service/SysDockerService.java @@ -2,25 +2,94 @@ import com.github.dockerjava.api.DockerClient; import com.github.dockerjava.api.command.*; +import com.github.dockerjava.api.model.Container; import com.github.dockerjava.api.model.PullResponseItem; import com.github.dockerjava.core.DockerClientBuilder; +import com.se.common.core.domain.DockerContainer; +import com.se.docker.utils.DockerUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; + @Service @SuppressWarnings("ALL") public class SysDockerService { - //@Value("${docker.prefix}") - public String localFilePrefix; + @Value("${docker.host}") + private String host; + + @Value("${docker.apiVersion}") + private String apiVersion; + + private static DockerUtils dockerUtils; private static final Logger log = LoggerFactory.getLogger(SysDockerService.class); + public DockerUtils getDockerUtils() { + if (null == dockerUtils) { + dockerUtils = new DockerUtils(host, apiVersion); + } + + return dockerUtils; + } + public String test() throws Exception { + List<String> names = new ArrayList<>(Arrays.asList("se-redis", "se-mysql", "se-system", "se-wgcloud")); + List<DockerContainer> list = getContainers(names); + + String id = list.get(0).getId(); + start(id); + pause(id); + unpause(id); + stop(id); + restart(id); + return "docker: " + System.currentTimeMillis(); } + public List<DockerContainer> getContainers(List<String> names) { + DockerUtils util = getDockerUtils(); + List<Container> containers = util.listContainers(); + + List<DockerContainer> list = new ArrayList<>(); + for (Container container : containers) { + if (null == container.getNames() || 0 == container.getNames().length) continue; + + String containerName = container.getNames()[0]; + for (String name : names) { + if (containerName.contains(name)) { + list.add(new DockerContainer(container.getId(), containerName, container.getState(), container.getImage())); + break; + } + } + } + return list; + } + + public void start(String id) { + getDockerUtils().start(id); + } + + public void restart(String id) { + getDockerUtils().restart(id); + } + + public void stop(String id) { + getDockerUtils().stop(id); + } + + public void pause(String id) { + getDockerUtils().pause(id); + } + + public void unpause(String id) { + getDockerUtils().unpause(id); + } + /** * java DockerClient鎿嶄綔 * https://blog.csdn.net/weixin_45198228/article/details/130060333 -- Gitblit v1.9.3