当前位置: 首页 > news >正文

SpringCloud微服务学习笔记(二)_Docker

文章目录

  • docker
    • 拆封原则
    • docker在linux上的安装
    • 部署mysql
      • 部署mysql命令解读
    • 常见命令
    • 数据卷挂载
    • 以宿主目录自定义挂载
    • Dockerfile语法
    • 自定义镜像
    • 容器网络互联
    • 部署java应用,后端
    • 部署前端
    • DockerCompose(快速部署)

docker

简化环境配置流程
单体架构

  • 架构简单
  • 部署成本低
  • 团队协作成本高
  • 系统发布效率低
  • 系统可用性差
    单体架构适合开发功能相对简单,规模较小的项目

微服务架构

  • 颗粒度小
  • 团队自治
  • 服务自治
  • 但是开发(有些功能是需要跨模块的)和运维的复杂度直线上升

拆封原则

  • 高内聚
  • 低耦合
  • 纵向拆分,按照业务模块拆分
  • 横向拆分,抽取公共服务(比如短信模块\登录模块,在很多模块中都用的到的),提高复用性

docker在linux上的安装

步骤参考
https://b11et3un53m.feishu.cn/wiki/Rfocw7ctXij2RBkShcucLZbrn2d
飞书云文档

部署mysql

绿色软件,下载只需要拷贝流程的软件
一般的软件安装,还需要写入一些动态连接库(DLL),向系统注册表中写入相应的设置项等等
而docker的安装就类似绿色软件的安装,没那么多杂七杂八的步骤

  • 应用镜像,包含应用运行所需的环境\配置\系统函数库
  • 容器,运行镜像时,创建一个隔离环境
  • docker安装,相当从镜像仓库直接安装一个绿色包
  • 镜像仓库,存储和管理镜像的平台,dockerHub

部署mysql命令解读

docker run -d \                //创建并运行一个容器  -d让容器后台运行--name mysql \				//容器起名-p 3306:3306 \				//设置端口映射,一个容器有端口有ip但对外不可访问,可以通过当前宿主机映射访问3306(宿主端口):3306(容器端口)-e TZ=Asia/Shanghai \			//设置配置文件-e MYSQL_ROOT_PASSWORD=123 \	mysql			//运行镜像的名字

常见命令

在这里插入图片描述容器内部可以模拟一整套系统.甚至可以在linux中容器运行容器,无限套娃
镜像和容器的命令操作是不一样的,比如docker rm nginx是删除了容器,但是这个镜像仍然存在在系统上
基础命令

# 启动Docker服务
systemctl start docker# 停止Docker服务
systemctl stop docker# 重启Docker服务
systemctl restart docker# 设置Docker服务开机自启
systemctl enable docker# 查看Docker服务运行状态
systemctl status docker# 查看Docker版本信息
docker version
docker info

镜像命令

# 查看本地所有Docker镜像
docker images# 从Docker Hub搜索镜像
docker search mysql# 拉取Docker镜像
docker pull mysql
docker pull mysql:5.7.40# 删除本地Docker镜像
docker rmi mysql
docker rmi -f mysql:5.7.40

容器命令

# 列出所有运行中的容器
docker ps# 列出所有容器,包括未运行的
docker ps -a# 停止运行中的容器
docker stop container_id# 强制停止容器
docker kill container_id# 启动已停止的容器
docker start container_id# 查看容器的详细信息
docker inspect container_id# 查看容器日志
docker container logs container_id# 进入运行中的容器
docker exec -it container_id /bin/bash# 删除已停止的容器
docker rm container_id
docker rm -f container_id

数据卷命令

# 列出所有数据卷
docker volume ls# 创建新的数据卷
docker volume create volume_name# 删除指定的数据卷
docker volume rm volume_name# 查看数据卷的详细信息
docker volume inspect volume_name

数据卷挂载

是一个虚拟目录,是容器内目录与宿主机目录之间映射的桥梁

docker run -d --name nginx -p 80:80 -v \
> html:/usr/share/nginx/html nginx      //数据卷:容器内目录

数据卷将容器中的nginx的/usr/share/nginx/html映射到宿主机的/var/lib/docker/volumes/html/_data

以宿主目录自定义挂载

docker run -d \--name mysql \-p 3306:3306 \-e TZ=Asia/Shanghai \-e MYSQL_ROOT_PASSWORD=123 \-v ./mysql/data:/var/lib/mysql \          //本地目录:容器内目录-v ./mysql/conf:/etc/mysql/conf.d \-v ./mysql/init:/docker-entrypoint-initdb.d \mysql

Dockerfile语法

自己制作自己项目的docker镜像
从0部署java应用的流程:

  • 准备一个linux系统
  • 安装并配置jdk
  • 上传jar包
  • 运行jar包
    所以镜像制作也应该是这样做
    但是从零开始构建镜像太麻烦了,所以docker官方给我们制作了基础镜像(包含linux运行环境的)
    也有提供基础环境加jdk环境的镜像只需要从此基础上制作java镜像就可以了
    所以镜像的制作是分层制作的
// 基础镜像
FROM openjdk:11.0-jre-buster
// 设定时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
// 拷贝jar包
COPY docker-demo.jar /app.jar
// 入口
ENTRYPOINT ["java", "-jar", "/app.jar"]

所以我们只需要设定与jar包相关的环境变量的镜像,jar包镜像,程序运行入口的镜像

自定义镜像

通过dockerfile构建镜像(在dockerfile同级目录下要有jar包)
docker build -t docker-demo:1.0 /root/demo// /root/demo是jar包和dockerfile的路径

容器网络互联

因为每一个容器都有一个ip地址,然后就可以通过网桥连接不同的容器,在一个容器的内部就可以访问另一个容器
网桥的概念还是不懂,要了解一下

# 1.用基本命令,寻找Networks.bridge.IPAddress属性
docker inspect mysql
# 也可以使用format过滤结果
docker inspect --format='{{range .NetworkSettings.Networks}}{{println .IPAddress}}{{end}}' mysql
# 得到IP地址如下:
172.17.0.2# 2.然后通过命令进入dd容器
docker exec -it dd bash# 3.在容器内,通过ping命令测试网络
ping 172.17.0.2
# 结果
PING 172.17.0.2 (172.17.0.2) 56(84) bytes of data.
64 bytes from 172.17.0.2: icmp_seq=1 ttl=64 time=0.053 ms
64 bytes from 172.17.0.2: icmp_seq=2 ttl=64 time=0.059 ms
64 bytes from 172.17.0.2: icmp_seq=3 ttl=64 time=0.058 ms

但是ip地址容易变化,所以还是要通过名称去访问

# 1.首先通过命令创建一个网络
docker network create hmall# 2.然后查看网络
docker network ls
# 结果:
NETWORK ID     NAME      DRIVER    SCOPE
639bc44d0a87   bridge    bridge    local
403f16ec62a2   hmall     bridge    local
0dc0f72a0fbb   host      host      local
cd8d3e8df47b   none      null      local
# 其中,除了hmall以外,其它都是默认的网络# 3.让dd和mysql都加入该网络,注意,在加入网络时可以通过--alias给容器起别名
# 这样该网络内的其它容器可以用别名互相访问!
# 3.1.mysql容器,指定别名为db,另外每一个容器都有一个别名是容器名
docker network connect hmall mysql --alias db
# 3.2.db容器,也就是我们的java项目
docker network connect hmall dd# 4.进入dd容器,尝试利用别名访问db
# 4.1.进入容器
docker exec -it dd bash
# 4.2.用db别名访问
ping db
# 结果
PING db (172.18.0.2) 56(84) bytes of data.
64 bytes from mysql.hmall (172.18.0.2): icmp_seq=1 ttl=64 time=0.070 ms
64 bytes from mysql.hmall (172.18.0.2): icmp_seq=2 ttl=64 time=0.056 ms
# 4.3.用容器名访问
ping mysql
# 结果:
PING mysql (172.18.0.2) 56(84) bytes of data.
64 bytes from mysql.hmall (172.18.0.2): icmp_seq=1 ttl=64 time=0.044 ms
64 bytes from mysql.hmall (172.18.0.2): icmp_seq=2 ttl=64 time=0.054 ms

常用网络命令

创建网络
docker network create <network_name>
列出网络
docker network ls
查看网络详情
docker network inspect <network_name>
连接容器到网络
docker network connect <network_name> <container_name>
断开容器与网络的连接
docker network disconnect <network_name> <container_name>
删除网络
docker network rm <network_name>

部署java应用,后端

# 1.构建项目镜像,不指定tag,则默认为latest
docker build -t hmall .# 2.查看镜像
docker images
# 结果
REPOSITORY    TAG       IMAGE ID       CREATED          SIZE
hmall         latest    0bb07b2c34b9   43 seconds ago   362MB
docker-demo   1.0       49743484da68   24 hours ago     327MB
nginx         latest    605c77e624dd   16 months ago    141MB
mysql         latest    3218b38490ce   17 months ago    516MB# 3.创建并运行容器,并通过--network将其加入hmall网络,这样才能通过容器名访问mysql
docker run -d --name hmall --network hmall -p 8080:8080 hmall

部署前端

docker run -d \--name nginx \-p 18080:18080 \-p 18081:18081 \-v /root/nginx/html:/usr/share/nginx/html \-v /root/nginx/nginx.conf:/etc/nginx/nginx.conf \--network hmall \nginx

DockerCompose(快速部署)


http://www.mrgr.cn/news/79204.html

相关文章:

  • bash 判断内存利用率是否高于60%
  • qt QCommandLineParser详解
  • Fastapi教程:使用aioredis异步访问redis
  • OpenSSH和OpenSSL升级
  • MySQL其一,概念学习,可视化软件安装以及增删改查语句
  • 跨域 Cookie 共享
  • uniapp远程摄像头流界面上显示
  • Nginx 负载均衡和反向代理
  • Elasticsearch 的存储与查询
  • linux 系列服务器 高并发下ulimit优化文档
  • composer简单入门
  • 【Linux系统】Android系统是如何基于Linux内核构建出来的
  • 【Linux】重定向、管道符、通配符、转义字符、环境变量
  • 【NLP6、损失函数 ① 均方差损失函数】
  • Android 使用TabLayout + ViewPager2 实现标签页的视图切换
  • 【Android】EventBus的使用及源码分析
  • 技术栈6:Docker入门 Linux入门指令
  • 【5G】5G技术组件 5G Technology Components
  • 【C++】入门【六】
  • 数字IC前端学习笔记:脉动阵列的设计方法学(以串行FIR滤波器为例)
  • 优傲协作机器人 Remote TCP Toolpath URCap(操作记录)
  • L17.【LeetCode笔记】另一棵树的子树
  • 【OpenDRIVE_Python】使用python脚本输出OpenDRIVE数据中含有隧道tunnel的道路ID和隧道信息
  • SCP命令实现Linux中的文件传输
  • Qt Quick 开发基础 + 实战(持续更新中…)
  • Vue3 Ts 如何获取组件的类型