mysql工程连接互通,MySQL容器与各种应用容器的互联互通

0b5fdc6e408a

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

0b5fdc6e408a

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

本地创建mysql的映射目录

mkdir -p /usr/local/mysql/data /usr/local/mysql/logs /usr/local/mysql/conf

在/root/mysql/conf中创建 *.cnf 文件(叫什么都行)

touch my.cnf

自定义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/mysql/conf:/etc/mysql/conf.d -v /usr/local/mysql/data:/var/lib/mysql -v /usr/local/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 :alias

#其中,name和id是源容器的name和id,alias是源容器在link下的别名(eg: --link mysql-docker:db)

最终可以通过web访问应用容器(到这里应用容器已经和mysql容器已经建立连接)

0b5fdc6e408a

java项目依赖环境部署【记录】

前置环境安装

* docker安装

步骤:

1、安装需要的依赖包--命令:sudo yum install -y yum-utils device-mapper-persistent-data lvm2

3、安装 Docker-CE--命令:sudo yum install docker-ce

4、启动docker服务--命令:service docker start

完成以上命令后可以通过docker images查看下载的镜像了

[root@172-0-0-91 data]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

nginx latest 2622e6cca7eb 12 days ago 132MB

mysql 5.7 9cfcce23593a 12 days ago 448MB

* mysql 数据库安装(使用docker镜)

步骤:

1、本地创建mysql的映射目录

mkdir -p /usr/local/mysql/data /usr/local/mysql/logs /usr/local/mysql/conf

2、在/root/mysql/conf中创建 *.cnf 文件(叫什么都行)

touch my.cnf

3、自定义my.conf配置文件

进入创建文件夹conf下创建my.conf文本

[root@localhost ~]# cd /usr/local/mysql/

[root@localhost 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/mysql/conf:/etc/mysql/conf.d -v /usr/local/mysql/data:/var/lib/mysql -v /usr/local/mysql/logs:/var/log/mysql -d -e MYSQL_ROOT_PASSWORD=123456 -e LANG=C.UTF-8 -p 3307:3306 mysql:5.7

此时已完成mysql数据库的安装,可以通过Navicat连接

0b5fdc6e408a

* nginx安装(选择使用linux下安装,版本v1.10.1)

安装nginx前置环境依赖

yum -y install gcc pcre-devel zlib-devel openssl openssl-devel

获取nginx的tar包(nginx-1.10.1.tar.gz)

链接:https://pan.baidu.com/s/1UuITYCFjeZGh7ZRDhc8B4w

提取码:6poq

解压

tar -zxvf nginx-1.9.9.tar.gz

进入nginx目录

cd nginx-1.10.1

配置

./configure --prefix=/usr/local/nginx

依次执行编译

1、make

2、make install

* redis安装(选择使用linux下安装,版本v4.0.8)

解压

tar xzvf redis-4.0.8.tar.gz

安装编译

cd redis-4.0.8

make

cd src

make install PREFIX=/usr/local/redis

移动配置文件到安装目录下

redis.conf配置文件(后台启动、IP限制、密码已改)

链接:https://pan.baidu.com/s/1mdMgm54DRkAXa4fguAZ4Hg

提取码:50dy

下载好配置文件后把配置文件移到etc下

mkdir /usr/local/redis/etc

mv redis.conf /usr/local/redis/etc

将redis加入到开机启动

vi /etc/rc.local

# 在里面添加内容:/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf

# (意思就是开机调用这段开启redis的命令)

7.开启redis(进入/usr/local/redis/bin)执行下列命令启动redis

./redis-server /usr/local/redis/etc/redis.conf

docker镜像的离线下载和上传

#离线打包

docker save -o 文件名.tar 镜像名称

# 上传离线加载

docker load < 文件名.tar

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值