Java中怎么利用UnixSocket调用DockerAPI-成都创新互联网站建设

关于创新互联

多方位宣传企业产品与服务 突出企业形象

公司简介 公司的服务 荣誉资质 新闻动态 联系我们

Java中怎么利用UnixSocket调用DockerAPI

今天就跟大家聊聊有关Java中怎么利用UnixSocket 调用 Docker API,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

创新互联建站专注于福田企业网站建设,自适应网站建设,商城网站定制开发。福田网站建设公司,为福田等地区提供建站服务。全流程按需网站策划,专业设计,全程项目跟踪,创新互联建站专业和态度为您提供的服务

在 Docker 官网查阅 API 调用方式

例如:查询正在运行的容器列表,HTTP 方式如下:

$ curl --unix-socket /var/run/docker.sock http:/v1.24/containers/json
[{
  "Id":"ae63e8b89a26f01f6b4b2c9a7817c31a1b6196acf560f66586fbc8809ffcd772",
  "Names":["/tender_wing"],
  "Image":"bfirsh/reticulate-splines",
  ...
}]

分析 API 请求的过程

在本机执行如下命令

curl -v --unix-socket /var/run/docker.sock http:/v1.24/containers/json

Java中怎么利用UnixSocket 调用 Docker API

Java 模拟调用 API 的代码实现

1、引入 UnixSocket 工具包

        
            com.github.jnr
            jnr-unixsocket
            0.18
        

2、测试代码

    public static void main(String[] args) {
        // 建立 Unix Socket 连接
        File sockFile = new File("/var/run/docker.sock");
        UnixSocketAddress address = new UnixSocketAddress(sockFile);
        UnixSocketChannel channel = UnixSocketChannel.open(address);
        UnixSocket unixSocket = new UnixSocket(channel);

        // 调用 Docker API
        PrintWriter w = new PrintWriter(unixSocket.getOutputStream());
        w.println("GET /v1.24/containers/json HTTP/1.1");
        w.println("Host: http");
        w.println("Accept: */*");
        w.println("");
        w.flush();
        // 关闭 Output,否则会导致下面的 read 操作一直阻塞
        unixSocket.shutdownOutput();

        // 获取返回结果
        System.out.println("---- Docker Response ----");
        BufferedReader br = new BufferedReader(new InputStreamReader(unixSocket.getInputStream()));
        String line;
        while ((line = br.readLine()) != null){
            System.out.println(line);
        }
        unixSocket.close();
    }

看完上述内容,你们对Java中怎么利用UnixSocket 调用 Docker API有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


网站名称:Java中怎么利用UnixSocket调用DockerAPI
转载来源:http://kswsj.cn/article/ggggpc.html

其他资讯