
记录实现流程图中web应用与mysql数据库创建连接设置

docker mysql容器的挂载my.conf配置说明
备注:这种挂载配置文件方式可以解决DB容器被同宿主机下web应用容器访问及其它主机web应用和web应用容器创建连接。(如果不挂载配置文件会走默认配置会导致web应用容器无法与docker容器建立连接并异常抛出信息)
com.zaxxer.hikari.pool.HikariPool.throwPoolInitializationException(HikariPool.java:595) - HikariPool-1 - Exception during pool initialization
- 创建宿主机挂载目录
mkdir $MYSQL_HOME/conf $MYSQL_HOME/data $MYSQL_HOME/logs
- 授权挂载目录可read的权限(特别说明:如果这里不授权启动时会抛出异常无法启动)
chmod 777 $MYSQL_HOME/*
- 自定义my.conf配置文件
- 进入创建文件夹conf下创建my.conf文本
[root@localhost ~]# cd /usr/local/docker_mysql/
[root@localhost docker_mysql]# ll
总用量 4
drwxr-xr-x. 2 root root 21 4月 26 17:01 conf
drwxr-xr-x. 6 polkitd root 4096 4月 27 09:15 data
drwxr-xr-x. 2 root root 6 4月 26 16:59 logs
- my.conf配置内容
[mysqld]
pid-file=/var/run/mysqld/mysqld.pid
socket=/var/run/mysqld/mysqld.sock
datadir=/var/lib/mysql
port = 3306
server_id = 1
#绑定mysql可以接受来自哪些ip地址客户端的访问;使用docker运行mysql服务,并且其他docker容器需要访问mysql的话,需要使用该参数来绑#定其他docker容器也能访问的ip地址,一般docker使用172.17.0.1这个地址,这里把监听地址改为0.0.0.0无IP访问限制(这里是关键)
bind-address = 0.0.0.0
#设置客户端链接时使用的字符编码
init_connect=’SET NAMES utf8’
character_set_server = utf8
[mysql]
default-character-set = utf8
[client]
default-character-set = utf8
[mysql.server]
default-character-set = utf8
-运行挂载目录启动mysql容器
docker run --name mysql -v /usr/local/docker_mysql/conf:/etc/mysql/conf.d -v /usr/local/docker_mysql/data:/var/lib/mysql -v /usr/local/docker_mysql/logs:/var/log/mysql -d -e MYSQL_ROOT_PASSWORD=123456 -e LANG=C.UTF-8 -p 3307:3306 mysql:5.7
通过Dockerfile制作SpringBoot项目镜像
- Dockerfile文本
# 基础镜像是docker仓库的java:8(JDK8)
FROM java:8
# 作者签名
MAINTAINER czy czy725@yeat.net
# 挂载宿主机jar包到镜像 /platform-pay-1.0.0.jar 和 下个指令对应即可,命名并非一定要和jar名一样,为了能够识别
copy user-authority-0.0.1-SNAPSHOT.jar /user-authority-0.0.1-SNAPSHOT.jar
# 执行 java -jar 命令,启动容器跟随启动
CMD java -jar /user-authority-0.0.1-SNAPSHOT.jar
# 设置对外端口为 8081
EXPOSE 7001
- 文件路径
[root@ecs-s6-medium-2-linux-20200416093604 target]# ll
total 46012
-rw-r--r-- 1 root root 476 Apr 26 13:53 Dockerfile
-rw-r--r-- 1 root root 47108500 Apr 26 13:53 user-authority-0.0.1-SNAPSHOT.jar
- 通过docker build命令制作user-authority-0.0.1-SNAPSHOT.jar镜像,镜像名为:testv1.0
docker build -t testv1.0 .
- 查看镜像情况(可以看到已经生成testv1.0的镜像了)
[root@ecs-s6-medium-2-linux-20200416093604 opt]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
testv1.0 latest 7c8009d75877 47 minutes ago 690MB
mysql 5.7 413be204e9c3 3 weeks ago 456MB
centos latest 470671670cac 3 months ago 237MB
java 8 d23bdf5b1b1b 3 years ago 643MB
记录下同一宿主机下:应用容器test-demo与mysql-docker容器创建连接另一种方式--link
备注:虽然网上很多这种创建连接方式,如果只这样做同宿主机下是可以正常创建连接的,但是也会出现另外的情况:其它主机web应用及web应用容器是无法与当前宿主机下的mysql容器创建连接的,抛出异常信息同上(建议mysql容器创建使用存储卷方式挂载my.conf配置文件)
- 启动mysql官方5.7容器(并设置连接密码:123456)
docker run -p 3306:3306 --name mysql-docker -v /etc/mysql/conf:/etc/mysql/conf.d -v /usr/local/docker/mysql/logs:/logs -v /var/lib/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -it mysql:5.7
- 参数说明
# 容器终止运行后自动删除容器文件
# --rm
# 主机端口映射到容器端口
#-p 3306:3306
# 给容器起别名(非常重要,项目中的数据库地址需要和别名一致)
#--name db
# 把主机的配置文件映射到容器的配置文件
#-v /etc/mysql/conf:/etc/mysql/conf.d
# 把主机的日志映射到容器的日志
#-v /usr/local/docker/mysql/logs:/logs
# 把主机的数据映射到容器(每次重启容器不用担心数据被清空了)
#-v /var/lib/mysql:/var/lib/mysql
# 数据库密码
#-e MYSQL_ROOT_PASSWORD=123456
# 后台启动
#-d
# 容器的 Shell 映射到当前的 Shell,然后你在本机窗口输入的命令,就会传入容器。
#-it
# 来自哪一个镜像
#mysql:5.7
- 配置SpringBoot的application-test.yml配置文件(mysql-docker为上一步容器名)
datasource:
platform: mysql
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://mysql-docker:3306/user_authority?Unicode=true&characterEncoding=UTF-8&useSSL=true&serverTimezone=GMT%2b8
username: root
password: 123456
- 启动应用容器test-demo
docker run --rm -p 7002:7001 --name test-demo --link mysql-docker:mysql-docker testv1.0
- 参数说明
#第一个mysql-docker表示mysql容器的别名,第二个mysql-docker表示application-test.yml配置文件里的数据库名称
#-link的格式:
#--link <name or id>:alias
#其中,name和id是源容器的name和id,alias是源容器在link下的别名(eg: --link mysql-docker:db)
-
最终可以通过web访问应用容器(到这里应用容器已经和mysql容器已经建立连接)
-
更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:
Coding测试
网友评论