1 安装MySql数据库
1.1 安装步骤
第一步:在hub.docker.com上搜索mysql镜像
第二步:拉取指定版本的mysql,也可以指定拉取版本,例如:
docker pull mysql:8.0.23
或者也可以在文件所在目录下直接使用本地文件安装:
docker load < 安装文件名
第三步:检查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服务
- 停止redis服务?
docker stop redis01
- 启动redis服务?
docker start redis01
- 重启 redis 服务?
docker restart redis01
3 安装Nginx代理
3.1 安装步骤
第一步:拉取nginx镜像 (从这里hub.docker.com去查找)
docker pull nginx
同样的,也可以使用本地文件安装:
docker load < 文件名全路径
第二步:查看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服务
可以直接在虚拟机中进行访问检测,如图所示:
3.3 停止和nginx服务
- 停止nginx服务
docker stop nginx
2.启动nginx服务
docker start nginx
- 重启nginx服务
docker restart nginx
4 安装Nacos组件
4.1 安装步骤
第一步:拉取nacos(hub.docker.com)
docker pull nacos/nacos-server:1.4.1
第二步: mysql中执行nacos的sql脚本文件
-
将此文件nacos-mysql.sql(这个文件可从code服务器下载)拷贝到mysql容器的宿主机对应的挂载目录(可通过
docker inspect mysql
查看你mysql的挂载目录) -
在linux环境下启动并登录mysql
进入mysql容器(前提是mysql已启动)
docker exec -it mysql bash
登录mysql
mysql -uroot -p
- 通过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.168 \
-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为开机自启)
- MYSQL_SERVICE_HOST=192.168.126.168
填写自己宿主机的IP地址
--restart=always
第四步:检查nacos服务
docker ps
假如启动失败,检查启动日志,例如:
docker container logs nacos
其中,nacos的启动日志在/home/nacos/logs/start.out文件中。
4.2 访问nacos服务
启动nacos,然后在windows中输入http://ip:port/nacos方式进行访问测试
说明,nacos登录时,默认用户名和密码都是nacos.
4.3 Nacos 与 MySQL 通讯分析
4.4 停止和启动nacos服务
- 停止nacos服务
docker stop nacos
- 启动nacos服务
docker start nacos
- 重启nacos服务
docker restart nacos
5 容器互联实践简介
5.1 概述
Docker 中存在多个容器时,容器与容器之间经常需要进行通讯,例如nacos访问mysql,redis集群中各个节点之间的通讯。
5.2 解决方案
Docker 中容器与容器之间进行通讯的解决方案一般有两种:
第一种:两个容器通过宿主机进行通讯(容器中的端口会映射到宿主机上)
第二种:两个容器之间直接通过虚拟网络进行连接,但是需要我们在docker中创建网络。
6 初始化网路
6.1 架构设计
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前3位
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
......