当前位置: 首页 > news >正文

dockerSDK-Go语言实现

前情提要

本文基于开发一个在线代码运行平台的项目需求上,所以需要挂载目录以达到获得执行文件的目的。

步骤1

首先在docker-compose 文件中,当前容器一定要跟宿主机的套接字进行挂载

version: '3.8'  
  
services:  
  code-runner-api:  
    build:  
      context: .  
      dockerfile: builds/api/Dockerfile  
    volumes:  
      - /var/run/docker.sock:/var/run/docker.sock  
    environment:  
      - APP_ENV=production  
      - DOCKER_HOST=unix:///var/run/docker.sock  
    ports:  
      - ""  

步骤二

创建docker客户端

type dockerContainerClient struct {  
    ctx context.Context  
    cli *client.Client  
}  
  
// NewDockerClient 
func NewDockerClient(ctx context.Context) (*dockerContainerClient, error) {  
    cli, err := client.NewClientWithOpts(  
       client.WithHost("unix:///var/run/docker.sock"),  
       client.WithAPIVersionNegotiation(), // 自动协商API版本  
    )  
    if err != nil {  
       log.Println("domain.client.entity.NewDockerClient() NewClientWithOpts err=", err)  
       return nil, fmt.Errorf("创建Docker客户端失败: %v", err)  
    }  
    return &dockerContainerClient{ctx: ctx, cli: cli}, nil  
}  
  

创建容器示例

// CreateContainer 创建指定容器  
func (client *dockerContainerClient) createContainer(image string, language string) (container.CreateResponse, error) {  
    config := &container.Config{  
       Image:      image,  
       User:       "root",  
       WorkingDir: "/app",  
       Cmd:        []string{"sleep", "infinity"}, // 修改启动命令为 sleep 无限循环  
       Env: []string{  
          "GO111MODULE=on",  
          "GOPROXY=https://goproxy.cn,direct",  
       },  
    }  
  
    hostConfig := &container.HostConfig{  
       ReadonlyRootfs: false,  
       CapDrop:        []string{"ALL"},  
       NetworkMode:    "none", // 关闭容器网络连接  
       Resources: container.Resources{  
          Memory:     512 * 1024 * 1024,  
          MemorySwap: 512 * 1024 * 1024,  
          CPUQuota:   100000,  
          CPUPeriod:  100000,  
          CPUCount:   1,  
       },  
       Binds: []string{fmt.Sprintf("/tmp/%s:/app", language)}, // 挂载到容器的/app目录  
    }  
  
    fmt.Printf("创建容器配置:\n")  
    fmt.Printf("镜像:%s\n", image)  
    fmt.Printf("工作目录:%s\n", config.WorkingDir)  
    fmt.Printf("挂载路径:%s\n", hostConfig.Binds[0])  
  
    resp, err := client.cli.ContainerCreate(  
       client.ctx,  
       config,  
       hostConfig,  
       nil,  
       nil,  
       "",  
    )  
    if err != nil {  
       log.Println("domain.client.entity.createContainer() ContainerCreate err=", err)  
       return container.CreateResponse{}, fmt.Errorf("容器创建失败: %v", err)  
    }  
    return resp, nil  
}

注意

1.如果想营造安全的沙箱环境一定要记得关闭容器的网络

2.注意挂载的路径,最好在代码中打印检查一下传入的参数

相关文章:

  • dfs刷题排列问题 + 子集问题 + 组和问题总结
  • 【Java SE】单例设计模式
  • TNNLS 2024 | 基于残差超密集网络的高光谱图像空间光谱融合方法
  • 【Java基础】在Java中,一个线程的大小(即线程所占用的内存)是多少
  • 关于FastAPI框架的面试题及答案解析
  • 如何在 Flutter 中使用 WebRTC
  • 从零开始学3PC:分布式事务的进阶方案
  • HarmonyOS第23天:应用性能优化,解锁流畅体验密码
  • 当下主流 AI 模型对比:ChatGPT、DeepSeek、Grok 及其他前沿技术
  • 51单片机笔记
  • 【Leetcode 每日一题】2680. 最大或值
  • 组合总和
  • 理解 Node.js 中的 process`对象与常用操作
  • 系统思考—链接组织效能提升与问题解决
  • VideoHelper 油猴脚本,重塑你的视频观看体验
  • 51c~C++合集1
  • 【CSS文字渐变动画】
  • 无人机点对点技术要点分析!
  • xwiki自定义认证实现单点登录
  • XSS介绍通关XSS-Labs靶场
  • 夜读丨母亲的手擀面
  • “子宫内膜异位症”相关论文男性患者样本超六成?福建省人民医院发布情况说明
  • 德国联邦议院6日下午将举行总理选举第二轮投票
  • 消费者在天猫一旗舰店换手机电池疑遭套路致手机损坏,平台已介入
  • 伊朗港口爆炸事故遇难人数最终确定为57人
  • 旧宫新语|瑞琦:再探《古玩图》——清宫艺术品的前世与今生