13 Docker 镜像安装及容器互联实践

1 安装MySql数据库

1.1 安装步骤

第一步:在hub.docker.com上搜索mysql镜像
13 Docker 镜像安装及容器互联实践_第1张图片第二步:拉取指定版本的mysql,也可以指定拉取版本,例如:

 docker pull mysql:8.0.23

第三步:检查mysql镜像

 docker images

第四步:启动运行mysql镜像 (docker run 用于启动一个容器)

sudo docker run -p 3306:3306 --name mysql \
-v /usr/local/docker/mysql/mysql-files:/var/lib/mysql-files \
-v /usr/local/docker/mysql/conf:/etc/mysql \
-v /usr/local/docker/mysql/logs:/var/log/mysql \
-v /usr/local/docker/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:8.0.23

假如安装过程中失败了,则可通过docker ps -a 查看以前的容器,假如已存在,则通过docker rm 镜像id 删除再重新安装即可。

1.2 登陆mysql服务

第一步:进入容器 (退出容器用exit)

sudo docker exec -it mysql bash

第二步:登陆(默认密码root),一定要先进入mysql容器。

mysql -uroot -proot

1.3 停止和启动mysql服务

停止mysql服务(可选)

docker stop mysql

启动mysql服务

docker start mysql

假如希望查看mysql启动时的日志,可以执行 docker container logs mysql 这个指令。

设置mysql开机自启动(可选)

docker update mysql --restart=always

2 安装Redis数据库

2.1 安装步骤

第一步:下载镜像文件

docker pull redis

第二步:准备配置文件

创建redis配置文件目录

mkdir -p /usr/local/docker/redis01/conf

在配置文件录下创建redis.conf配置文件(这个文件一定要创建,否在我们进行目录挂载时默认生成的是一个目录)

touch /usr/local/docker/redis01/conf/redis.conf

第三步:创建redis实例并启动

sudo docker run -p 6379:6379 --name redis01 \
-v /usr/local/docker/redis01/data:/data \
-v /usr/local/docker/redis01/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf 

第四步:查看正在运行的进程

docker ps

2.2 访问redis服务器

第一步:控制台直接连接redis测试

docker exec -it redis01 bash

第二步:检测redis 版本

redis-server  -v

或者

redis-cli -v

第三步:登录redis(默认不需要密码)

redis-cli

或者直接将上面的两个步骤合为一个步骤执行也可以,指令如下:

docker exec -it redis01 redis-cli

2.3 停止和启动redis服务

  1. 停止redis服务?
docker stop redis01
  1. 启动redis服务?
docker start redis01
  1. 重启 redis 服务?
docker restart redis01

3 安装Nginx代理

3.1 安装步骤

第一步:拉取nginx镜像 (从这里hub.docker.com去查找)

docker pull nginx

第二步:查看images镜像

docker images

第三步:创建数据卷(这个对象会在宿主机直接创建一个目录)

docker volume create nginx-vol

说明:查看数据卷对应的宿主机目录,可以通过如下指令:

docker inspect nginx-vol

第四步:启动nginx服务

docker run --name nginx  -p 80:80 -v nginx-vol:/etc/nginx -d nginx

其中:/etc/nginx 为nginx容器启动时,nginx镜像文件默认的解压目录

说明:假如以后想修改nginx配置,可以直接去nginx-vol数据卷对应的目录去修改.

3.2 访问nginx服务

进行访问检测,如图所示:
13 Docker 镜像安装及容器互联实践_第2张图片

3.3 停止和nginx服务

  1. 停止nginx服务
docker stop nginx

2.启动nginx服务

docker start nginx
  1. 重启nginx服务
docker restart nginx

4 安装Nacos组件

4.1 安装步骤

第一步:拉取nacos(hub.docker.com)

docker pull nacos/nacos-server:1.4.1

第二步: mysql中执行nacos的sql脚本文件

  1. 将此文件nacos-mysql.sql(这个文件可从code服务器下载)拷贝到mysql容器的宿主机对应的挂载目录(可通过docker inspect mysql查看你mysql的挂载目录)

  2. 在linux环境下启动并登录mysql

进入mysql容器(前提是mysql已启动)

docker exec -it mysql bash

登录mysql

mysql -uroot -p
  1. 通过source指令运行容器目录下的sql文件
source  /etc/mysql/nacos-mysql.sql  #这里的/etc/mysql为容器中的一个目录(要选择你自己挂载的目录)

例如:

第三步:创建并启动nacos容器(拷贝下面内容时,账号和密码要用自己宿主机ip,自己数据库的账号密码)

docker run  \
-e TZ="Asia/Shanghai" \
-e MODE=standalone \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_DATABASE_NUM=1 \
-e MYSQL_SERVICE_HOST=192.168.126.129 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=root \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-p 8848:8848 \
--name nacos \
--restart=always \
-d nacos/nacos-server:1.4.1

参数说明

  • 单节点模式
    MODE=standalone
  • 数据库地址
    MYSQL_SERVICE_HOST
  • 数据库用户名
    MYSQL_SERVICE_USER
  • 数据库密码
    MYSQL_SERVICE_PASSWORD
  • 需连接的数据库名称
    MYSQL_SERVICE_DB_NAME
  • 端口映射
    -p 8848:8848
  • 任意时候重启容器,开机就能自动启动容器(需设置docker为开机自启)
--restart=always

第四步:检查nacos服务

docker ps

假如启动失败,检查启动日志,例如:

docker container logs nacos

其中,nacos的启动日志在/home/nacos/logs/start.out文件中。

4.2 访问nacos服务

启动nacos,然后在windows中输入http://ip:port/nacos方式进行访问测试
13 Docker 镜像安装及容器互联实践_第3张图片
说明,nacos登录时,默认用户名和密码都是nacos.

4.3 Nacos 与 MySQL 通讯分析

13 Docker 镜像安装及容器互联实践_第4张图片

4.4 停止和启动nacos服务

  1. 停止nacos服务
docker stop nacos
  1. 启动nacos服务
docker start nacos
  1. 重启nacos服务
docker restart nacos

5 容器互联实践简介

5.1 概述

Docker 中存在多个容器时,容器与容器之间经常需要进行通讯,例如nacos访问mysql,redis集群中各个节点之间的通讯。

5.2 解决方案

Docker 中容器与容器之间进行通讯的解决方案一般有两种:
第一种:两个容器通过宿主机进行通讯(容器中的端口会映射到宿主机上)
第二种:两个容器之间直接通过虚拟网络进行连接,但是需要我们在docker中创建网络。

6 初始化网路

6.1 架构设计

13 Docker 镜像安装及容器互联实践_第5张图片

6.2 新建网络

例如:创建名字为t-net的网络

docker network create -d bridge t-net  #t-net为自己起的网络名称

其中,-d driver,网络类型,默认 bridge。
说明,创建好这个网络以后,在网络上添加容器,容器就可以通讯了

6.3 查看网络信息

列出所属有网络

docker network ls

查看网络信息

docker inspect 67d #67d 为创建的网络id

7 实现容器互联

7.1 创建容器

打开终端,基于centos:7这个镜像启动容器,并加入到t-net这个网络

docker run -it --name app1 --network t-net centos:7

新开终端执行,基于centos:7这个镜像再启动容器,同时也加入到t-net网络

docker run -it --name app2 --network t-net centos:7

7.2 测试网络互通

在两个终端中分别执行:

ping app1
ping app2

显示如下:

[root@35569c623c4c /]# ping app1
PING app1 (172.18.0.2) 56(84) bytes of data.
64 bytes from 35569c623c4c (172.18.0.2): icmp_seq=1 ttl=64 time=0.577 ms
64 bytes from 35569c623c4c (172.18.0.2): icmp_seq=2 ttl=64 time=0.061 ms
64 bytes from 35569c623c4c (172.18.0.2): icmp_seq=3 ttl=64 time=0.066 ms
......

8 总结(summary)

8.1 重难点分析

  • 容器互联方案
  • 创建网络方式
  • 应用网络

8.2 FAQ分析

  • 什么是容器互联?
  • 为什么需要创建网络?
  • 如何创建网络?
  • 如何应用网络?
  • 如何测试网络是否是通的?

你可能感兴趣的:(第四阶段,docker,容器,mysql)