Docker 容器 + 自定义桥接网络(lfd-net)单机部署理发店系统

一、理发店系统技术栈

bash 复制代码
本项目采用前后端分离架构:
层级	技术	                        部署方式	        端口
前端	Vue 2.7 + Element UI	        Nginx 静态托管	80 (容器内) → 8082 (宿主机)
后端	Spring Boot 2.7 + MyBatis	    Java 应用	    8081(容器内) → 8081 (宿主机)
通信协议	HTTP + JSON	RESTful API	-

核心特点:
    前端只负责页面渲染和用户交互
    后端只提供 API 接口,不关心页面展示
    两者通过 HTTP 请求通信,数据格式为 JSON

二、部署方案

bash 复制代码
维度	      你的方案	                            说明
容器化	     ✅ Docker	                            前端、后端、MySQL 都跑在容器里
网络模式	      Docker 自定义桥接网络(lfd-net)	    容器间通过容器名通信
数据持久化	  Docker 卷(Volume)	                MySQL 数据持久化
编排方式	      手动 docker run	                    未使用 Compose,手动管理
部署范围	      单机本地部署	                        所有容器在同一台服务器

三、详细部署步骤

数据库部署

1、获取mysql容器

bash 复制代码
docker pull mysql:8.0

2、启动mysql容器并创建数据库

bash 复制代码
docker run -d   --name mysql   --network lfd-net   -e MYSQL_DATABASE=LFD   -e MYSQL_USER=LFD   -e MYSQL_PASSWORD=设置LFD密码   -e MYSQL_ROOT_PASSWORD=设置root密码   -p 3306:3306   mysql:8.0

-e 是 Docker 中最常用的参数之一,几乎所有镜像都支持通过环境变量来配置行为。
其中 -e MYSQL_ROOT_PASSWORD参数是试着root 密码,这个必须设置。
MySQL 容器启动时会自动执行一系列初始化脚本,MYSQL_USER 和 MYSQL_PASSWORD 创建的普通用户,会被自动授予 MYSQL_DATABASE 指定数据库的所有权限。所以 LFD 用户自动就是 LFD 数据库的拥有者,不需要额外配置。

3、连接数据库

因为容器数据库3306端口已映射服务器端口,直接通过DBeaver连接虚拟机的3306和数据库名字即可,然后导入

8.0以上数据库链接需要设置驱动属性:

4、数据库导入

后端部署

1、把Dockerfile和后端的jar包放在服务器

bash 复制代码
#把Dockerfile和后端的jar包放在服务器
[root@localhost houduan]# pwd && ll
/home/lfd/houduan
总计 92900
-rw-r--r-- 1 root root 47558918  6月 8日 17:14 barbershop-backend-1.0.0.jar
-rwxr-xr-x 1 root root      900  6月 2日 16:28 Dockerfile

2、通过Dockerfile 创建后端镜像

bash 复制代码
#通过Dockerfile 创建镜像
[root@localhost houduan]# cat Dockerfile 
FROM openjdk:17-jdk-slim

#镜像维护者/负责人
LABEL maintainer="barbershop"
#镜像描述
LABEL description="Barbershop Backend Service"

#如果没有会自动创建
WORKDIR /app

COPY barbershop-backend-1.0.0.jar app.jar

RUN mkdir -p /uploads/login_bg /uploads/xiaoguotu \
    && apt-get update \
    && apt-get install -y \
        tzdata \
        iputils-ping \     
        net-tools \         
        curl \            
        # 系统工具
        procps \           
        coreutils \        
        grep \           
    && rm -rf /var/lib/apt/lists/* \
    && ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
    && echo "Asia/Shanghai" > /etc/timezone

# 创建软链接(ifconfig 通常已包含在 net-tools 中)
# 确保常用命令在 PATH 中(默认已包含)

EXPOSE 8081

ENV JAVA_OPTS="-Xms256m -Xmx512m -XX:+UseG1GC -Djava.security.egd=file:/dev/./urandom"

ENTRYPOINT ["sh", "-c", "exec java $JAVA_OPTS -jar app.jar"]

3、创建理发店后端镜像

bash 复制代码
#创建理发店后端镜像
docker build -t lfd:1.0 .

4、根据镜像启动理发店后端容器

bash 复制代码
#根据镜像启动理发店后端容器
docker run -d --name lfd --network lfd-net -p 8081:8081 lfd:1.0

前端部署

1、把Dockerfile(前后端各一个Dockerfile)和前端的jar包放在服务器

bash 复制代码
[root@localhost qianduan]# pwd && ll
/home/lfd/qianduan
drwxr-xr-x 5 root root   73  6月 4日 15:57 dist #前端包
-rw-r--r-- 1 root root  346  6月 4日 16:55 Dockerfile
-rw-r--r-- 1 root root 1244  6月 4日 16:45 nginx.conf #nginx配置文件

2、Dockerfile文件内容

bash 复制代码
[root@localhost qianduan]# cat Dockerfile 
# 使用轻量级 Nginx 镜像
FROM nginx:alpine                   
# 将前端构建产物复制到 Nginx 默认目录
COPY dist/ /usr/share/nginx/html/   
# 使用自定义 Nginx 配置
COPY nginx.conf /etc/nginx/conf.d/default.conf  
# 暴露 80 端口
EXPOSE 80                           
# 启动 Nginx
CMD ["nginx", "-g", "daemon off;"]  

3、nginx.conf的文件内容

bash 复制代码
[root@localhost qianduan]# cat nginx.conf 
server {
    listen 80;
    server_name localhost;

    root /usr/share/nginx/html;
    index index.html;

    # 前端路由重写(Vue Router history模式)
    location / {
        try_files $uri $uri/ /index.html;
    }

    # API 代理到后端容器
    location /api/ {
        proxy_pass http://lfd:8081/api/;
        proxy_set_header Host $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;
        proxy_connect_timeout 60s;
        proxy_send_timeout 60s;
        proxy_read_timeout 60s;
    }

    # 文件上传代理
    location /files/ {
        proxy_pass http://lfd:8081/files/;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

    # 图片资源代理
    location /uploads/ {
        proxy_pass http://lfd:8081/uploads/;
        proxy_set_header Host $host;
    }

    # Gzip 压缩
    gzip on;
    gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
    gzip_min_length 1k;
    gzip_comp_level 5;
}

4、通过Dockerfile 创建后端镜像

bash 复制代码
docker build -t lfdqd:1.0 .

5、根据镜像启动理发店前端容器

bash 复制代码
docker run -d --name lfdqd --network lfd-net -p 8082:80 lfdqd:1.0