美文网首页Linux
MySQL容器与各种应用容器的互联互通

MySQL容器与各种应用容器的互联互通

作者: Coding测试 | 来源:发表于2020-04-27 21:31 被阅读0次

记录实现流程图中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测试

相关文章

网友评论

    本文标题:MySQL容器与各种应用容器的互联互通

    本文链接:https://www.haomeiwen.com/subject/ufeaihtx.html