前言
这篇文章主要针对MacBook用户,并且实验的环境也是MacOS。Windows上应该也可以正常地进行,但是我没有测试过,有兴趣的童鞋可以试试。
这篇文章针对有一定Docker基础的童鞋,如果你还不懂Docker的一些基础命令,或者操作方式,那么你需要先预习一下。
先说说为什么需要用Docker来定制一个Golang开发环境。首先如果你有用过Vagrant,那么你一定知道,这种基于容器开发的好处。首先你不需要在本机安装太多的类似MySQL、PHP、JAVA等软件,这样会让你的电脑变得非常的乱,而且并不是特别好管理。而如果你用了Docker或者Vagrant,你可以很轻松的搭建你需要的环境。并且这一切都是在容器或者虚拟机中。
这篇文章不讲Vagrant,我们讲Docker。在开始之前,我们要知道什么是Docker、Docker-Compose。
Docker:是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
Docker-Compose:是Docker的服务编排工具,主要用来构建基于Docker的复杂应用,Compose 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景。
下载&安装 Docker
- 选择“Get Docker Community Edition” 下载即可
- 安装完后,正常状态下,你就可以看到状态栏多了一个像河豚一样的图标。这里不详讲。
更改Docker镜像源
- 你懂的,改成国内的源。方法很多,我是直接注册Daocloud
- 然后你打开这个URL https://www.daocloud.io/mirror 就可以获取你的加速地址。
- 填入Registry mirrors就行了。接着Restrat就OK了。
构建一个基础Docker-Compose
我们需要构建一个基础的容器组合,例如我们每个应用都需要用到nginx、mysql、redis,那么我们在这个基础镜像里面添加这几个服务,然后启动,启动后基础的Docker-Compose会创建一个network,我们后续将所有要开发的项目都和这个network连通,那么他们之间就可以互相访问了。
- 首先我们需要创建一个docker-compose.yml,内容如下
version: '2.1' services: mysql: image: mariadb:latest container_name: mysql_service volumes: - ./data/mysql/data:/var/lib/mysql ports: - 3306:3306 environment: - MYSQL_ROOT_PASSWORD=root redis: image: redis:alpine ports: - 6379:6379 volumes: - ./data/redis/data:/data nginx-lb: build: services/nginx/ ports: - 80:80 command: > nginx -g "daemon off;"
- 然后在docker-compose.yml同目录下创建service/nginx文件夹。也可以用terminal 执行 mkdir -p service/nginx 来创建
- 在nginx 文件夹里面新建default.conf Dockerfile两个文件
- default.conf 这个文件是为了后续的web项目可以通过container_name来访问
server { listen 80 default_server; resolver 127.0.0.11 valid=10s; location / { proxy_pass http://$host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
- Dockerfile 不多说,有docker基础的都能看懂
FROM nginx:latest MAINTAINER HundredLee <hundred9411@gmail.com> RUN apt-get update && apt-get install -y curl unzip COPY default.conf /etc/nginx/conf.d/default.conf EXPOSE 80
-
那么现在我们可以在docker-compose.yml所在的目录下执行docker-compose build && docker-compose up -d
-
如果你执行上述命令,得到的和图片的结果一致,那么你的基础docker-compose已经构建并成功启动。
- 接下来我们查看network的名称,执行 docker network list
- godockerdev-default 就是我们这个docker-compose的网络。一般来说,他是根据你这个项目名来决定的,你可以自定义,否则他便会按照你的文件夹名来命名。
独立项目的Docker-Compose
- 好了,万事俱备,我们已经建设好了基础的容器组合,接下来我们要创建一个beego项目作为本次的测试项目。
- 首先我们创建一个beego项目,我们通过bee工具来创建
- 执行go get github.com/beego/bee就可以了。
- 然后创建项目,执行bee new BeegoD
- 酱紫就创建成功了,那么我们进入BeegoD文件夹。
-
接着创建两个文件,分别是:
- Dockerfile
- docker-compose.yml
- Dockerfile
FROM library/golang # Godep for vendoring RUN go get github.com/beego/bee ENV APP_DIR $GOPATH/src/BeegoD RUN mkdir -p $APP_DIR # Set the entrypoint ENTRYPOINT (cd $APP_DIR && bee run > debug_log.log 2>&1) #ADD . $APP_DIR EXPOSE 80
- docker-compose.yml
- 将该beego项目加入godockerdev_default网络中,使得服务间可以互相访问通信。
version: '2.1' services: service: container_name: beegod.dev build: context: . expose: - 80/tcp networks: - godockerdev_default - local volumes: - .:/go/src/BeegoD networks: godockerdev_default: external: name: godockerdev_default local: internal: true
- 在docker-compose.yml中,container_name 将是你在本机中可以访问的域名。当然你比如添加进/etc/hosts中。像这样127.0.0.1 beegod.dev
- 然后在项目中执行docker-compose build && docker-compose up -d ,成功后,就可以访问beegod.dev了。
- 在BeegoD文件夹下面有一个debug_log.log,这里面会实时写入beego应用当前的状态,报错等。可以在terminal中执行tail -f debug_log.log来实时查看
- 像酱紫。。。。
- 然后就搞定了。不懂的,不清晰的,可以留言说一下。我都会回复。谢谢