【Go语言实战】 (12) Docker 部署 Gin+MySQL+Redis 项目

网友投稿 462 2022-10-22

【Go语言实战】 (12) Docker 部署 Gin+MySQL+Redis 项目

目录

​​写在前面​​​​1. 安装docker​​​​2. 镜像启动​​

​​2.1 MySQL​​

​​2.1.1 拉取​​​​2.1.2 启动​​

​​2.2 Redis​​

​​2.2.1 拉取​​​​2.2.2 启动​​

​​3. Dockerfile​​​​4. docker-compose.yml​​​​最后​​

写在前面

今天我们用 docker 部署我们的商城项目,主要有项目Mall、MySQL、Redis。 基于​​CentOS 7​​系统

​​项目地址​​

​安装docker

更新源

yum update

安装docker

yum install docker

启动docker

systemctl start docker

查看是否启动成功

systemctl status docker

查看所有的镜像

docker images

查看所有的容器状态

docker ps -a

2. 镜像启动

2.1 MySQL

2.1.1 拉取

docker pull mysql:tag

我这里的​​tag​​​是mysql 的 ​​8.0​​ 版本,如果不指定就默认是最新版本

​​docker images​​ 查看镜像

2.1.2 启动

启动mysql容器要保证宿主机的3306没有被占用,或者你也可以用其他端口进行映射,我这里把宿主机的3306端口停了,所以就用3306端口进行映射了。

docker run --name mysql -v /var/lib/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -p 3306:3306 -d mysql:8.0

说明一下这些参数

--name mysql 表示将这个容器命名为mysql-v /var/lib/mysql:/var/lib/mysql 表示将宿主机的 /var/lib/mysql 卷映射到容器里的 /var/lib/mysql 卷中,这里是为了我们能够把这个数据保存在宿主机中,防止容器删掉就没了。-e MYSQL_ROOT_PASSWORD=root 表示MySQL的密码我这里设置了root-p 3306:3306将宿主机的3306端口映射到容器的3306端口-d 后台运行mysql:8.0 使用mysql:8.0这个镜像

2.2 Redis

2.2.1 拉取

docker pull redis

这里我们没有指定版本,所以是 ​​latest​​ 最新版本

2.2.2 启动

docker run --name redis -v /usr/local/redis:/usr/local/redis -p 6379:6379 -d redis:latest

3. Dockerfile

首先以​​golang1.16​​为基础镜像设置系统环境和代理指定工作区​​app​​复制项目并且进行项目的编译将编译好的 main 和 conf 复制到镜像中 (也可以进行映射)再基于busybox镜像进行构建多一层终端暴露3000端口最后./main运行

FROM golang:1.16 as builderENV GO111MODULE=on \ GOPROXY=/appCOPY . .RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-w -s" -o mainRUN mkdir publish \ && cp main publish \ && cp -r conf publishFROM busybox:1.28.4WORKDIR /appCOPY --from=builder /app/publish .# 指定运行时环境变量ENV GIN_MODE=releaseEXPOSE 3000ENTRYPOINT ["./main"]

将我们的项目git下来

然后我们再进行项目的配置文件的编写config.ini

这里注意要填宿主机的ip地址,因为docker是进程隔离的状态,所以我们不能填127.0.0.1!并且要确保这几个端口的安全组已经开了!

然后我们就可以进行docker build了

docker build -t mall:tag .

我这里tag指定的是1.0,如果不指定的话就是latest了

检查每一个step有没有对应的序列号出来,全都有就是成功了。

我们跑一下

docker run --name mall -p 3000:3000 -d mall:1.0

发现没跑起来,所以就

docker logs NAMES

查看日志,发现mysql忘记创建数据库了

我们docker exec进入mysql中进行数据库表的创建

然后重启一下我们的容器

因为我们的mall容器的id是a开头的,所以直接a也可以代表这个容器!

全部都up起来就好了

我们postman测试一下

有响应即可!

4. docker-compose.yml

当我们有多个容器需要启动的时候,我们可以用docker-compose.yml进行容器的管理

version: '2'services: civil: build: ./ image: mall:2.0 container_name: mall restart: always environment: MYSQL_DSN: "root:root@tcp/mall_db?charset=utf8&parseTime=True&loc=Local" ports: - 3000:3000 depends_on: - mysql - redis mysql: container_name: mysql image: mysql:8.0 restart: always environment: MYSQL_ROOT_PASSWORD: root MYSQL_DATABASE: mall_db volumes: - /var/lib/mysql:/var/lib/mysql ports: - 3306:3306 redis: container_name: redis image: redis:latest restart: always volumes: - /usr/local/redis:/usr/local/redis ports: - 6379:6379

使用

docker-compose -f docker-compose.yml up -d

都启动成功了

再进行测试

成功即可!

最后

在此非常感谢运维大佬 ​​愿许浪尽天涯​​ 的帮助,帮我排查了镜像的问题!

Dockerfile文件我本来是写FROM scratch的,但是好像没有执行成功,才换成了busybox镜像

大家有什么问题也可以问这位运维大佬! ​​愿许浪尽天涯​​

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:[云原生专题-9]:容器 - Docker的启动与关闭:run、stop
下一篇:Java线程池流程编排运用实战源码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~