/tx-interview

docker 管理平台demo,某次腾讯的笔试题

Primary LanguageGo

docker 管理 demo


对docker资源进行管理,腾讯蓝鲸的某面试题:

设计并实现一个简单的存储资源分配系统实现一个服务,该服务可以接收用户端请求,为用户申请 MySQL 与 Redis 两类资源。分配给用户的资源实例必须是真实、可以连接使用的。用户可以通过接口查看分配给自己的资源配置信息。- 服务以 HTTP REST API 的方式提供接口,部分示例接口:- 申请一个新的 MySQL/Redis 资源实例- 查看某个实例的配置信息- MySQL、Redis 服务可以在服务端用 Docker 容器启动,也可以使用其他方式- 分配出的不同实例之间需要避免端口等资源冲突- 资源的连接、鉴权等信息应该随机生成,部分必须的信息- MySQL 连接地址、数据库名称、用户号、密码- Redis 连接地址、密码加分项:- 完整的项目架构图、项目安装、使用以及 README 文档- MySQL 与 Redis 实例支持不同的个性化配置,比如:- Redis 可以由用户设置数据最大占用空间- MySQL 可以由用户设置数据库字符集

安装

go env -w GOPROXY=https://goproxy.cn,https://goproxy.io,direct
go env -w GO111MODULE=on

# 运行
make run 

# 编译
make compile

主要目录结构

  • common 基本库,如日志,mysql 驱动, 字符转换,配置加载等
  • controller 控制层,控制agent基本的逻辑代码位置,如查看所有image 创建容器等等
  • dao dao层,数据层
  • http mux+http封装的http 层,接口封装
  • structs 统一的结构体位置

相关接口:

查看镜像

curl -X GET http://127.0.0.1:8080/v1/api/user/getallimage -H "Auth-Token: f6b76e8e-313f-4b9f-937f-35b7e28e1c71"

创建docker容器 containertype 指的是申请资源的类型, 目前仅支持mysql/redis

curl -X POST http://127.0.0.1:8080/v1/api/user/containercreate -H  "Content-Type: application/json" -d '{"containertype":"mysql"}'

待完成:

  • 端口占用目前是临时使用map + lock的方式进行避免重复分配的,且每次重启服务会清零,后续需要找个地方存一下,或者直接通过etcd的分布式锁的方式避免重复分配/分配冲突
  • redis 相关代码
  • 用户自定义配置,可以将docker env 再单独拎出来传参