基于 Docker 镜像部署 go 项目
依赖知识
Go 交叉编译基础
Docker 基础
Dockerfile 自定义镜像基础
docker-compose 编排文件编写基础
一、依赖环境
Docker
二、编写一个 GoLang web 程序
我这里就写一个最简单的 hello world 程序吧,监听端口是 80 端口。
新建一个 main.go 文件,内容如下:
package main
import (
"fmt"
"log"
"net/http"
)
func sayHello(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "hello world")
}
func main() {
http.HandleFunc("/", sayHello)//注册URI路径与相应的处理函数
log.Println("【默认项目】服务启动成功 监听端口 80")
er := http.ListenAndServe("0.0.0.0:80", nil)
if er != nil {
log.Fatal("ListenAndServe: ", er)
}
}
三、编译成 linux 下的程序包
我是在 mac 上开发的,需要用到 go 的交叉编译,如果对交叉编译不熟悉的,可以查下文档,或者直接复制我下面的命令进行编译。
我们是要跑在 Docker 里面,基础 golang 这个镜像跑的,所以需要把他编译成兼容 i386 处理器的程序。
sudo env GOOS=linux GOARCH=386 go build main.go
这个编译完成后,本地会多出一个 main 程序,暂时不用管它备用就行。
四、使用 Dockerfile 定制我们 go 程序的镜像
新建一个文件夹,里面新建一个 Dockerfile 文件,再在里面新建 app,script 两个文件。把上一步的 main 程序放到 app 文件夹里面,在 script 里面新建一个 build.sh 脚本文件,文件内容先不管,等下会说。
具体的文件结构是这样。
.
├── Dockerfile
├── app
│ └── main
└── script
└── build.sh
下面就是编写 Dockerfile 文件内容了,内容我先上代码:
FROM golang
MAINTAINER 谦益
WORKDIR /go/src/
COPY . .
EXPOSE 80
CMD ["/bin/bash", "/go/src/script/build.sh"]
这里解释下:
FROM 是集成自哪个镜像,我们是 go 程序官方提供了一个 golang 这样的镜像,我们可以直接使用。
MAINTAINER 是维护这名字。
WORKDIR 工作目录。
COPY 这是一个复制命令,把本地的所有文件复制到工作目录下。
EXPOSE 这是对方开发的端口,我默认是开放 80 端口,这里可根据实际情况修改
CMD 执行一个带参数的命令,我这样写,是为了让镜像启动时去执行 script/build.sh 的脚本,这个脚本里面是写的启动 go 程序的命令。
这里我把内容粘贴出来:
#!/usr/bin/env bash
cd /go/src/app/ && ./main
就这两行。
五、编译我们自己的镜像
这属于 Docker 的知识了,我把命令粘贴出来。
docker build -t go-web .
这个命令执行,如果本地没有 golang 这个镜像的话,他会自己先去官方镜像库拉取这个镜像再编译,我们静静的等他就行。
go-web 这个参数是你最后编译后的镜像名字,可以随意修改,也可以加上版本号比如: go-web:v1。
看到上面这个输出,就说明编译成功了,在你的本地镜像里面就有了一个名为 go-web 的镜像。可以使用 docker images 进行查询:
六、编写 docker-compose.yml 文件
到这里属于我们的最后一步了,如果用我们刚编译的 go-web 来运行我们的 go 程序:
version: '3'
services:
world:
container_name: world
image: go-web
ports:
- "8080:80"
volumes:
- ./app/go/world:/go/src/app:rw
到这里我们的编排文件已经写好了,现在只需要用 docker-compose 来启动我们的编排文件就好,启动命令如下:
docker-compose -f docker-compose.yml up -d world
如果输出下面的提示,说明启动成功了。
Creating world ... done
启动成功后你可以再用
docker ps
来查看下是否启动成功了。
现在访问 127.0.0.1:8080 就能访问我们的 go 程序了。
本作品采用《CC 协议》,转载必须注明作者和本文链接
推荐文章: