文章目录

  • docker部署mysql的数据持久化
  • 需要的知识
  • 需要的工具
  • 服务器配置
  • MySQL配置
  • Springboot项目打jar包
  • 编写Dockerfile文件
  • 访问


docker部署mysql的数据持久化

首先,我起初想着将 mysql 容器中的数据持久化 commit 成为一个新的镜像,但是保存后的新镜像与原镜像大小一样—— 数据没有保存,官方说 commit 操作并不会包含容器内挂载数据卷中的数据变化,所以还是老老实实卷挂载吧

"Mounts": [
            {
                "Type": "volume",
                "Name": "f7653ab2038af841aaca0863e4c84668b3fdf0b1aaee59716adfe68012ab78d7",
                "Source": "/var/lib/docker/volumes/f7653ab2038af841aaca0863e4c84668b3fdf0b1aaee59716adfe68012ab78d7/_data",
                "Destination": "/var/lib/mysql",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ]

使用 docker inspect 查看 mysql 容器,发现默认匿名挂载 /var/lib/mysql ,而此目录确实是数据 mysql 数据目录

基于 docker 部署 mysql 的数据持久化问题 https://www.jianshu.com/p/530d00f97cbf

需要的知识

  • Linux知识
  • Docker

需要的工具

  • FinalShell(或者其他同类工具)连接远程 Linux 服务器
  • Navicat(或者其他同类工具)解析.sql脚本

服务器配置

#查看防火墙状态 firewall-cmd --state 			若为开启通过 systemctl start firewalld.service  开启

[root@dinosaur ~]# firewall-cmd --state
running

#添加对外开放的端口,必要开放的是两个端口,一个80(Http端口),一个3306(mysql),自己按需求开
[root@dinosaur ~]# firewall-cmd --zone=public --add-port=8080/tcp --permanent
[root@dinosaur ~]# firewall-cmd --zone=public --add-port=3306/tcp --permanent


#重新加载防火墙
[root@dinosaur ~]# firewall-cmd --reload

#查看开放的端口
[root@dinosaur ~]# firewall-cmd --list-ports
20/tcp 21/tcp 22/tcp 80/tcp 8888/tcp 39000-40000/tcp 8080/tcp 8080/udp 3306/tcp 3306/udp 9090/tcp 9090/udp

注:如果是阿里云的服务器,需要修改相应的安全组规则(就是阿里云又给我们加了一道墙)

MySQL配置

从 Docker Hub 上拉取 MySQL镜像,我用的是8版本,根据自己的需求选择镜像

#当前没有镜像
[root@dinosaur ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

#拉取镜像
[root@dinosaur ~]# docker pull mysql
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest

#查看已有镜像
[root@dinosaur ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
mysql               latest              8e85dd5c3255        5 days ago          544MB

启动 MySQL 镜像

#	-d	后台运行
#	-p	端口映射
#	-e	环境变量(mysql 密码)
#	--name	容器名称

[root@dinosaur ~]# docker run -d -p 3306:3306 --name mysql01 -e MYSQL_ROOT_PASSWORD=12345xiaoyu mysql:latest
864aee23d5db3d4fc44089b79f6f4fdb9151ea11836def077b138188bd968e48

#docker ps 查看  已经启动成功
[root@dinosaur ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
864aee23d5db        mysql:latest        "docker-entrypoint.s…"   2 minutes ago       Up 2 minutes        0.0.0.0:3306->3306/tcp, 33060/tcp   mysql01

#进入容器查看 ,可以正常登录
[root@dinosaur ~]# docker exec -it 864aee23d5db /bin/bash
root@864aee23d5db:/# mysql -uroot -p12345xiaoyu
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.21 MySQL Community Server - GPL

Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           			  |
+--------------------+
| information_schema   |
| mysql              				  |
| performance_schema |
| sys                						|
+--------------------+
4 rows in set (0.00 sec)
mysql> exit
Bye
root@864aee23d5db:/# exit

本地启动 Navicat 连接服务器的 MySQL 提供数据

docker仓库连接超时 docker连接数据库_后端

建立你想要的数据并且运行sql脚本

docker仓库连接超时 docker连接数据库_后端_02

Springboot项目打jar包

spring:
  datasource:
    username: root
    password: 12345xiaoyu
    url: jdbc:mysql://ip:3306/match
    driver-class-name: com.mysql.cj.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource
    server:
  port: 80

注意打包的时候相应的配置都需要修改,端口也需要根据需要修改,我使用的80端口

然后使用 maven 的 package 打包,最好先 clean 清理一下,让它重新编译

编写Dockerfile文件

FROM openjdk:14									    #从 JDK14 镜像开始构建,这里选择你自己的 JDK 版本就好
	
COPY *.jar /app.jar								    #将当前目录下的jar包拷贝到容器内根目录的app.jar

CMD ["---server.port=80---"]		    #打印一下信息

EXPOSE 80											     #保留80端口

ENTRYPOINT ["java","-jar","/app.jar"]	#启动后执行 java -jar 命令运行 jar 包

将你打好的 jar 包与 Dockerfile 文件上传到 Linux 机器的同一目录

jar包在项目生成的target目录下

#使用docker build来构建镜像
[root@dinosaur match]# docker build -t match:1.0 
Successfully built 3d57aee3424f
Successfully tagged match:1.0

#查看镜像发现已经构建成功
[root@dinosaur match]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
match               1.0                 3d57aee3424f        45 seconds ago      569MB
mysql               latest              8e85dd5c3255        6 days ago          544MB
openjdk             14                  4ff6f9f0fa33        4 weeks ago         523MB

#运行镜像
[root@dinosaur match]# docker run -d --name match01 -p 80:80 match:1.0
99aef74f119fc61129762f3fde78120137b78c3432d488ccc21f344b78b4c398

访问

4ff6f9f0fa33        4 weeks ago         523MB

#运行镜像
[root@dinosaur match]# docker run -d --name match01 -p 80:80 match:1.0
99aef74f119fc61129762f3fde78120137b78c3432d488ccc21f344b78b4c398

### 访问

如果以上配置对了,比如数据库模块没错、连接模块没错,端口方面都没有错误的话,就可以打开浏览器访问了,我这里配置了80端口,直接输入 ip 地址即可