使用Dockerfile快速构建开发环境
在如今容器技术大行其道的世界里, 想比较知名的中间件、代理、开发框架都有自己的容器镜像.
作者为使用者提供了一个最简单的Dockerfile, 方便大家根据实际使用情况修改与发布公有或私有镜像.
构建本地镜像
如果您还是一个初学者, 在您将cf代码克隆到本地后使用docker build -t cfweb:v1 .
命令将自动下载并基于centos7构建私有镜像.
构建完成后使用docker images
命令可以在本地镜像列表内看到cfweb
版本镜像.
运行本地镜像
- 如果您仅想测试一下cf! 在上述第二步的时候构建本地镜像完成后即可使用docker run命令运行.
docker run -ti -p 8080:8080 cfweb:v1
- 此时您就可以使用
docker ps | grep cfweb
看到刚刚运行的cfweb容器.
进行测试
在您使用curl -v localhost:8080/api
后能得到类似返回后. 则说明您构建到镜像构建完成.
[candy@MacBookPro:~/Documents/core_framework] $ curl -v localhost:8080/api
* Trying ::1...
* TCP_NODELAY set
* Connected to localhost (::1) port 8080 (#0)
> GET /api HTTP/1.1
> Host: localhost:8080
> User-Agent: curl/7.54.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Date: Sun, 24 Mar 2019 09:56:45 GMT
< Allow: GET, POST, HEAD, OPTIONS
< Access-Control-Allow-Origin: *
< Access-Control-Allow-Methods: GET, POST, HEAD, OPTIONS
< server: Candy Server/1.0
< Connection: close
< Transfer-Encoding: identity
< Content-Length: 51
< Content-Type: application/json
< Cache-Control: no-cache, no-store, must-revalidate
< Cache-Control: no-cache
<
* Closing connection 0
{"code":200,"message":"This is GET method request"}
[candy@MacBookPro:~/Documents/core_framework]
使用docker-compose实现接入层(代理)服务(业务)分离
当大家使用Docker在构建生产环境的时候, 一般会在开发框架前端使用代理软件(7层或4层)进行业务隔离与划分.
实际开发框架的时候基本上都会建立一套约定的http preix path, 例如: /api/login
, /api/products
.
有了这些(或更详细)约定的前缀, 可以很清晰的划分出接口的作用/同时也方便项目的维护.事实上作者当初在自己的业务中也考虑到这点, 以下是一种最基础的7层Proxy方案:
cfadmin.io/api -> cf httpd api
(cfadmin.io) nginx ->
cfadmin.io/ws -> cf http websocket
docker-compose编排文件使用nginx作为前端接入层, 将cf容器link到代理内部. 这样做的好处在于:
消除语言/框架之间的隔离, 方便使用者清晰的组合实际业务.
更加方便的管理自己的服务器, 也是Devops的最佳选择.
为构建高性能、可扩展的架构打下基础.
注意: 以上具体配置文件与docker-compose编排文件都可在docker
目录下找到.