之前有次接到了腾讯小姐姐的电话,问我有没有兴趣参加蓝鲸devops的面试,在寒风中进行了45分钟的电话面之后,让我周末把笔试题做了,第一次笔试竟然在家做?有点意思啊,然后周末因为一些个人家庭原因思考了下没有参与后续的面试,但这道腾讯笔试题却花了一个下午简单做了下。
题目
设计并实现一个简单的存储资源分配系统实现一个服务,该服务可以接收用户端请求,为用户申请 MySQL 与 Redis 两类资源。分配给用户的资源实例必须是真实、可以连接使用的。用户可以通过接口查看分配给自己的资源配置信息。- 服务以 HTTP REST API 的方式提供接口,部分示例接口:- 申请一个新的 MySQL/Redis 资源实例- 查看某个实例的配置信息- MySQL、Redis 服务可以在服务端用 Docker 容器启动,也可以使用其他方式- 分配出的不同实例之间需要避免端口等资源冲突- 资源的连接、鉴权等信息应该随机生成,部分必须的信息- MySQL 连接地址、数据库名称、用户号、密码- Redis 连接地址、密码加分项:- 完整的项目架构图、项目安装、使用以及 README 文档- MySQL 与 Redis 实例支持不同的个性化配置,比如:- Redis 可以由用户设置数据最大占用空间- MySQL 可以由用户设置数据库字符集
其实本质上还是一个CRUD的操作, 主要也就看下平日里用的框架熟悉程度,因为我不太用gin,一般用的是自己半造轮子的一个http框架,个人觉得很好用,所以基本的鉴权,审计功能都有。分享一下~
https://github.com/zyxpaomian/go-http-framev2
然后正好也复习/学习了下docker 的sdk用法,官网的demo是真的少:https://docs.docker.com/engine/api/sdk/
基本逻辑就是传个resourcetype,如果是mysql 则创建mysql的container,然后通过container的env配置进行密码的指定, 配合command可以进行一些特殊化配置,或者直接通过-v 挂有特殊配置的配置文件等,方法很多,另外端口冲突的问题可以找个etcd存一下,利用etcd的分布式锁的特性也顺便解决了批量申请导致的冲突问题。其实最简单的还是直接使用go_client 申请K8S的资源,可惜开发机器上的minikube正好被我铲了。以后有机会再说吧。
写了个初版, 后续有时间在写下
https://github.com/zyxpaomian/tx-interview