Skip to main content

docker

web前端项目单独打包#

  • 使用 nginx 镜像

my.conf 来源于 gin-vue-adminmy.conf

server {   listen       8080;   server_name localhost;
   #charset koi8-r;   #access_log  logs/host.access.log  main;
   location / {       root /usr/share/nginx/html;       add_header Cache-Control 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0';       try_files $uri $uri/ /index.html;   }
   location /api {       proxy_set_header Host $http_host;       proxy_set_header  X-Real-IP $remote_addr;       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;       proxy_set_header X-Forwarded-Proto $scheme;       rewrite ^/api/(.*)$ /$1 break;  #重写       proxy_pass http://127.0.0.1:8888; # 设置代理服务器的协议和地址    }
   location /api/swagger/index.html {       proxy_pass http://127.0.0.1:8888/swagger/index.html;    }}

Dockerfile 来源于 gin-vue-admindockerfile_web

# 声明镜像来源为node:12.16.1FROM node:12.16.1
# 声明工作目录WORKDIR /gva_web/
# 拷贝整个web项目到当前工作目录COPY . .
# 通过npm下载cnpmRUN npm install -g cnpm --registry=https://registry.npm.taobao.org
# 使用cnpm进行安装依赖RUN cnpm install || npm install
# 使用npm run build命令打包web项目RUN npm run build# ===================================================== 以下为多阶段构建 ==========================================================
# 声明镜像来源为nginx:alpine, alpine 镜像小FROM nginx:alpine
# 镜像编写者及邮箱LABEL MAINTAINER="SliverHorn@sliver_horn@qq.com"
# 从.docker-compose/nginx/conf.d/目录拷贝my.conf到容器内的/etc/nginx/conf.d/my.confCOPY .docker-compose/nginx/conf.d/my.conf /etc/nginx/conf.d/my.conf
# 从第一阶段进行拷贝文件COPY --from=0 /gva_web/dist /usr/share/nginx/html
# 查看/etc/nginx/nginx.conf文件RUN cat /etc/nginx/nginx.conf
# 查看 /etc/nginx/conf.d/my.confRUN cat /etc/nginx/conf.d/my.conf
# 查看 文件是否拷贝成功RUN ls -al /usr/share/nginx/html

server项目单独打包#

Dockerfile 来源于 gin-vue-adminDockerfile

# 声明镜像来源为golang:alpineFROM golang:alpine
# 声明工作目录WORKDIR /go/src/gin-vue-admin
# 拷贝整个server项目到工作目录COPY . .
# go generate 编译前自动执行代码# go env 查看go的环境变量# go build -o server . 打包项目生成文件名为server的二进制文件RUN go generate && go env && go build -o server .
# ==================================================== 以下为多阶段构建 ==========================================================
# 声明镜像来源为alpine:latestFROM alpine:latest
# 镜像编写者及邮箱LABEL MAINTAINER="SliverHorn@sliver_horn@qq.com"
# 声明工作目录WORKDIR /go/src/gin-vue-admin
# 把/go/src/gin-vue-admin整个文件夹的文件到当前工作目录COPY --from=0 /go/src/gin-vue-admin ./
EXPOSE 8888
# 运行打包好的二进制 并用-c 指定config.docker.yaml配置文件ENTRYPOINT ./server -c config.docker.yaml

根据Dockerfile生成Docker镜像#

# -f 指定Dockerfile文件,默认为Dockerfile# -t 镜像名:版本tag# . 一定必须肯定务必加上docker build -t gva-server:1.0 .

运行Docker镜像#

# -d 后台运行# -p 映射端口:内部端口# -name 容器名字# gva-server:1.0为docker build时的-t的参数docker run -d -p 8888:8888 --name gva-server-v1 gva-server:1.0
# -it 以可交互模式运行并进入容器, 使用快捷键Ctrl + p + q即后台运行程序,Ctrl+c为退出容器# -p 映射端口:内部端口# -name 容器名字# gva-server:1.0为docker build时的-t的参数docker run -it -p 8888:8888 --name gva-server-v1 gva-server:1.0