【Day04】Spring Cloud 升华篇:容器化技术docker和kurbernetes
一、介绍
1、要考虑的问题
- 微服务数量有很多
- 中间件的部署-nacos-server sentinel-server
- 如何部署多个服务和中间件?
2、存在问题---机器上直接解压使用
- 资源利用率的问题(CPU 内存 资源)
- 迁移的问题(centos迁移到Ubuntu等其他服务器上,版本不一致)
- 上述问题在单体架构上不会出现,当面对成百上千的服务时,需要频繁考虑迁移
二、docker介绍
1、概述
不同系统上均安装docker,类似不同机器上的JVM
同一个class文件就可以放在不同的平台上执行
2、docker engine、image和container的关系

通过image创建多个container
image可以使用下载的,或者自己创建的image
下载官方的image:hub.docker.com
3、使用
现寻找image,再根据image创建container
下载:docker pull tomcat 【官方镜像】
启动:docker run -d -name tomcatic tomcat

查看ip地址:ip a
查看端口是否被占用:lsof -i 888
端口映射:-d 8081:8080
4、自己的微服务项目 vent.jar
可以正常运行jar包
java -jar vent.jar

怎么做成image?
- 创建Dockerfile文件
- 内容如下

- 生成命令:docker build -t vent . 使用当前路径下的Dockerfile文件

5、使用
查看:docker images
启动:docker run -d --name vent -p 8000:8080 vent

创建另一个container实例:docker run -d --name vent -p 8001:8080 vent
实现了自己的微服务创建image,并得到container
6、使用
当前image只能放到自己的服务上,别人需要
可以将其放到自己的镜像仓库中

7、 将本地仓库推送到命名空间
为镜像重新命名:docker tag pay-service-image http:xxx

打标签

查看所有容器: docker ps -aq
8、问题
很多镜像的访问量很大,某台机器的资源不够时,可以使用多个机器,均安装好docker-engine
资源就可以更加随意的进行分配
docker集群如何进行操作和管理。
9、解决
可以使用扣吧奶忒四

三、Kubernetes
1、介绍

生产级别的容器编排系统
架构图

k8s创建container,实际上是通过pod,而不是直接操作container

pod的创建通过kubelet
2、k8s集群的搭建
地址/工具或解决

各个组件也都是由pod组成的,pod是k8s创建的最小 单元
3、使用Minikube搭建kurbernete集群
Minikube是搭建单机版k8s集群的小工具
单机版集群(本地单节点):master和worker node在同一个机器上
搭建本地的多个节点的k8s集群:使用kubeadm【笔记】
方式:运行minikube start
根据业务需求进行选择
4、使用
kubetcl get pods
查看命名空间


5、通过yaml文件实现对pod的管理
Deployment--使用的controller manager类型


配置的labels
可以对容器打标签:app tomcat

通过匹配关系对pod进行管理
6、k8s使用service对容器进行负载均衡

通过选择器进行选择
7、查看创建的命名空间


查看虚拟ip

docker里面可以成功访问

外部访问
外网ip:NodePort端口,自动做负载

8、其他的yaml示例

外网ip:NodePort端口,自动做负载

负载均衡算法:根据浏览器ip做会话的返回
9、对自己创建的服务运行在k8s集群中
把镜像拿过来


会调度到不同的机器
可以选择不同的负载均衡算法
10、大促场景
之前:运行多台jar包
现在:随意扩容缩容

实际上扩缩容可以自动完成
评判标准:入口流量/根据k8s资源进行
组件:Horizontal可以根据CPU的利用率对组件自动扩缩容
查看暴露的端口

11、dashboard

三、总结
1、之前的问题
解决服务部署和中间件的部署
面对频繁的迁移,私有云到公有云
可以将二者理解为建立在云平台上的服务器

实现了云原生,可以解决频繁的迁移
2、kurbernetes成为云原生基础设施的支撑
HELM是k8s中的yalm,实现方便的管理

service mesh

CICD:持续整合集成
自己编程后,进行push,jenkins会自动建立docker镜像,并push到docker hub,k8s就可以从docker hub上拉取镜像
3、其他工具
K3S:简化组件,没有k8s那么重(轻量级k8s)

【Day04】Spring Cloud 升华篇:容器化技术docker和kurbernetes的更多相关文章
- 新一代Java程序员必学的Docker容器化技术基础篇
Docker概述 **本人博客网站 **IT小神 www.itxiaoshen.com Docker文档官网 Docker是一个用于开发.发布和运行应用程序的开放平台.Docker使您能够将应用程序与 ...
- Spring Cloud第二篇 | 使用并认识Eureka注册中心
本文是Spring Cloud专栏的第二篇文章,了解前一篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 一.Sprin ...
- Spring Cloud第九篇 | 分布式服务跟踪Sleuth
本文是Spring Cloud专栏的第九篇文章,了解前八篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring Cl ...
- Docker容器化技术(下)
Docker容器化技术(下) 一.Dockerfile基础命令 1.1.FROM - 基于基准镜像 FROM centos #制作基准镜像(基于centos) FROM scratch #不依赖任何基 ...
- Docker容器化技术(上)
目录 Docker容器化技术 一.介绍 二.Docker的发展 三.Docker安装 四.阿里云Docker镜像加速 五.Docker的基本概念 六.命令 七.Docker宿主机与容器通信 八.容器内 ...
- 几种常见的微服务架构方案——ZeroC IceGrid、Spring Cloud、基于消息队列、Docker Swarm
微服务架构是当前很热门的一个概念,它不是凭空产生的,是技术发展的必然结果.虽然微服务架构没有公认的技术标准和规范草案,但业界已经有一些很有影响力的开源微服务架构平台,架构师可以根据公司的技术实力并结合 ...
- 【转帖】使用容器化和 Docker 实现 DevOps 的基础知识
使用容器化和 Docker 实现 DevOps 的基础知识 https://www.kubernetes.org.cn/6730.html 2020-02-24 15:20 灵雀云 分类:容器 阅读( ...
- [第八篇]——Docker 容器使用之Spring Cloud直播商城 b2b2c电子商务技术总结
Docker 客户端 docker 客户端非常简单 ,我们可以直接输入 docker 命令来查看到 Docker 客户端的所有命令选项. xxx@xxx:~# docker 可以通过命令 docke ...
- [第九篇]——Docker 镜像使用之Spring Cloud直播商城 b2b2c电子商务技术总结
Docker 镜像使用 当运行容器时,使用的镜像如果在本地中不存在,docker 就会自动从 docker 镜像仓库中下载,默认是从 Docker Hub 公共镜像源下载. 下面我们来学习: 1.管理 ...
- [第七篇]——Docker Hello World之Spring Cloud直播商城 b2b2c电子商务技术总结
Docker Hello World Docker 允许你在容器内运行应用程序, 使用 docker run 命令来在容器内运行一个应用程序. 输出Hello world xxx@xxx:~$ do ...
随机推荐
- KubePi主界面添加镜像仓库并授权给集群,供创建Deployment时选择镜像使用
1.添加kubeoperator自带的nexus仓库 2.添加harbor 3.把添加的镜像仓库授权给集群 4.关于镜像仓库secrets的有关说明 5.实际效果 6.从添加授权的镜像仓库创建工作负载 ...
- fastdfs-zyc管理FastDFS的web界面
俩压缩包根据大小重命名以下,按图片所示 把1_fastdfs-zyc.7z重命名为fastdfs-zyc.7z.001 把2_fastdfs-zyc.7z重命名为fastdfs-zyc.7z.002 ...
- Springboot配置文件参数使用docker-compose实现动态配置
文章总结; Springboot配置文件中的一些参数可以写成变量的形式,具体变量的值可以从docker-compose.yml文件中设置来获取 在yml文件中,通过${Envirment_variab ...
- Query String Query和Sumple Query String
- 苹果手机安装郑好办手机app后给绿城通公交卡充值的步骤
1.苹果手机,需要带有NFC功能 苹果XS手机该功能默认是开启的,不用额外的其他操作 苹果11该功能需要设置开启才行.步骤:设置--通用--NFC,然后开启 2,公交卡 如下这种的公交卡可以充值: 如 ...
- oracle中的行转列,列转行
行转列:源表: 方法1:case when select y,sum(case when q=1 then amt end) q1,sum(case when q=2 then amt end) q2 ...
- 分布式存储系统之Ceph集群RBD基础使用
前文我们了解了Ceph集群cephx认证和授权相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/16748149.html:今天我们来聊一聊ceph集群的 ...
- 华为路由器RIP路由协议配置命令
RIP路由协议配置 rip 创建开启协议进程 network + ip 对指定网段接口使能RIP功能IP地址是与路由器直连的网段 debugging rip 1 查看RIP定期更新情况 termina ...
- 怎么在线预览.doc,.docx,.ofd,.pdf,.wps,.cad文件以及Office文档的在线解析方式。
前言 Office文件在线预览是目前移动化办公的一种新趋势.Office在线预览指的是Office系列的文件在线查看而不依附域客户端的存在.在浏览器或者浏览器控件中可以预览查看Word.PDF.Exc ...
- LcdTools如何实现PX01设置不同的画面不同的背光亮度
背光驱动分两种原理:恒压模式和恒流模式.恒压背光顾名思义提供恒定电压即可,这种屏正常来讲自带背光驱动电路,只需提供背光工作电压.背光使能和背光调光占空比控制.恒流背光指屏的背光只有纯灯串,需外部提供相 ...