SpringCloud微服务 【实用篇】| Docker启示录

news2024/12/24 9:45:07

目录

一:Docker启示录

1. Docker启示录

2. Docker和虚拟机的区别

3. Docker架构

4. Centos7安装Docker

4.1. 卸载

4.2. 安装docker

4.3. 启动docker

4.4. 配置镜像加速


前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家,感兴趣的同学可以进行学习人工智能学习

一:Docker启示录

学习完前面的微服务,我们发现一个很麻烦的问题:那就是服务的部署,微服务很多,部署起来很麻烦!今天就学习一下Docker来解决一下这个微服务部署问题

1. Docker启示录

项目部署的问题

大型项目组件较多,运行环境也较为复杂,部署时会碰到一些问题: 依赖关系复杂,容易出现兼容性问题; 开发、测试、生产环境有差异!

各种微服务的前端部分依赖于Node、JS,服务端需要数据库MySQL,缓存系统Redis,异步通信MQ等。这些都需要部署到服务器上(Linux操作系统上);每个应用都需要依赖和函数库,但是每个应用的依赖和函数库又有所差异(依赖关系复杂就容易产生兼容)。搞定了开发环境,后面还有测试、生产环境(环境对应的操作系统环境还可能不同:Centos、Ubuntu

Docker怎么解决依赖的兼容问题?

既然每个应用都有自己的依赖和函数库,那么Docker就可以把应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包!并且将每个应用放到一个隔离容器去运行,避免互相干扰

Docker怎么解决不同环境的操作系统?

不同环境的操作系统不同(Linux和Ubuntu的本身函数库不同),Docker如何解决?我们先来了解下操作系统结构:

所有的Linux操作系统都可以分为两层:Linux内核(都是相同的)、系统应用(区别在于上层的应用不同)。内核负责与计算机的硬件进行沟通,提供操作硬件的指令 。系统应用封装内核指令为函数,便于程序员调用;用户程序基于系统函数库实现功能。程序调用函数库---》函数库调用内核指令---》指定调用计算机硬件,从而实现应用的执行。

Ubuntu和CentOS都是基于Linux内核,只是系统应用不同,提供的函数库有所差异;所以根据Ubuntu环境的打包程序,放到Centos上有可能运行不了!

Docker将用户程序与所需要调用的系统(比如Ubuntu和Centos)函数库一起打包。Docker运行到不同操作系统时,直接基于打包的库函数,借助于操作系统的Linux内核来运行

1. Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?

①Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像;

②Docker应用运行在容器中,使用沙箱机制,相互隔离 ;

2. Docker如何解决开发、测试、生产环境有差异的问题

①Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行;

总结:Docker是一个快速交付应用、运行应用的技术

①可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统 ;

②运行时利用沙箱机制形成隔离容器,各个应用互不干扰 ;

③启动、移除都可以通过一行命令完成,方便快捷;

2. Docker和虚拟机的区别

Docker与虚拟机

Docker实现原理:Docker让一个应用在不同的Linux环境上运行是通过,会把应用及其依赖函数库,甚至于操作系统的函数库也一起打包。这样当应用运行时可以直接调用本地函数库,然后与操作系统的内核进行交互,这样就不需要关心什么样的系统,就可以实现跨系统的运行!(直接调用操作系统的内核,性能比较好

虚拟机实现原理:使用Hypervisor技术在一个操作系统上装另一个操作系统,模拟出计算机的各种的硬件,在模拟的计算机上就可以安装任意的操作系统,然后就可以安装应用、依赖等。在一个系统装另外一个系统,所以当应用执行时应用会以为自己在一个真是的电脑上运行:会去先调用内置的操作系统---》与Hypevisor交互---》把信息传给外部真实的操作系统----》外部操作系统再去调用计算机硬件。(层层传递,性能比较差

, 

两者的对比

 Docker和虚拟机的差异:

①docker是一个系统进程;虚拟机是在操作系统中的操作系统 ;

②docker体积小、启动速度快、性能好;虚拟机体积大、启动速度慢、性能一般;

3. Docker架构

镜像和容器

镜像(Image):Docker将应用程序及其所需的依赖、函数库、环境、配置等文件打包在一起,称为镜像。

容器(Container)镜像中的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见。

对于MySQL就是一个镜像,里面含有很多文件组成了MySQL本身,所以可以说镜像就是硬盘中的文件MySQL跑起来的进程就是容器,只不过在Docker里面容器还要做隔离!对于容器不能把自己的东西写到镜像当中(造成镜像污染),可以基于容器创建全新的镜像,镜像都是只读的!对于一个容器怎么写数据呢?容器写数据可以拷贝一份文件到自己独立的容器当中

DockerHub(镜像共享)

 怎么把镜像共享给别人使用呢?这就需要DockerHub(镜像托管)和GitHub很像!

DockerHub:DockerHub是一个Docker镜像的托管平台;这样的平台称为Docker Registry(镜像服务器)。 国内也有类似于DockerHub 的公开服务,比如 网易云镜像服务、阿里云镜像库等。

程序员可以利用Docker提供的命令进行镜像的构建,例如:MySQL、Nginx镜像;然后把这些镜像上传到DockerHub服务器上(会公开比较危险);也可以搭建一个私有云。

Docker架构

怎么利用Docker完成镜像的构建和拉取、运行容器呢?这就需要了解Docker的架构了!

Docker是一个CS架构的程序,由两部分组成:

服务端(server):Docker守护进程,负责处理Docker指令,管理镜像、构建容器等 ;

客户端(client):通过命令(本地)RestAPI请求(远程)向Docker服务端发送指令;可以在本地或远程向服务端发送指令

例如: 通过本地构建一个镜像,使用docker build命令,这个命令到达DockerServer以后会被守护进程docker daemon,利用提供的数据构建一个镜像!还可以去DockerRegister使用docker pull命令经过DockerServer端去拉取镜像!然后就可以运行镜像,创建容器,此时就需要docker run命令,它会告诉DockerServer的守护进程docker daemon去完成容器的创建;最终完成部署!

镜像: 将应用程序及其依赖、环境、配置打包在一起(可以看成系统文件);

容器:镜像运行起来就是容器,一个镜像可以运行多个容器(可以看成运行的进程);

总结Docker结构:

服务端:接收命令或远程请求,操作镜像或容器; 

客户端:发送命令或者请求到Docker服务端 ;

DockerHub:一个镜像托管的服务器,类似的还有阿里云镜像服务,统称为DockerRegistry;

4. Centos7安装Docker

企业部署一般都是采用Linux操作系统,而其中又数CentOS发行版占比最多,因此我们在CentOS下安装Docker。Docker 分为 CE 和 EE 两大版本。CE 即社区版(免费,支持周期 7 个月),EE 即企业版,强调安全,付费使用,支持周期 24 个月。

注:Docker CE 支持 64 位版本 CentOS 7,并且要求内核版本不低于 3.10,CentOS 7 满足最低内核的要求,所以我们在CentOS 7安装Docker。

4.1. 卸载

如果之前安装过旧版本的Docker,可以使用下面命令卸载:

注:反斜杠\ 表示命令的拼接!

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-selinux \
                  docker-engine-selinux \
                  docker-engine \
                  docker-ce

4.2. 安装docker

首先需要大家虚拟机联网,安装yum工具 (下载工具)

yum install -y yum-utils \
           device-mapper-persistent-data \
           lvm2 --skip-broken

然后更新本地镜像源(默认是连接国外的,容易断还慢)

# 设置docker镜像源为阿里云
yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
sed -i 's/download.docker.com/mirrors.aliyun.com\/docker-ce/g' /etc/yum.repos.d/docker-ce.repo

yum makecache fast

安装docker社区版

yum install -y docker-ce

4.3. 启动docker

Docker应用需要用到各种端口,逐一去修改防火墙设置。非常麻烦,因此建议大家直接关闭防火墙!启动docker前,一定要关闭防火墙后!!

# 关闭防火墙
systemctl stop firewalld
# 禁止开机启动防火墙
systemctl disable firewalld
# 查看防火墙的状态
systemctl status firewalld

通过命令启动docker

systemctl status docker  # 查看当前docker的状态
systemctl start docker  # 启动docker服务
systemctl stop docker  # 停止docker服务
systemctl restart docker  # 重启docker服务

然后输入命令,可以查看docker版本(启动成功才可以查看到版本号)

docker -v

4.4. 配置镜像加速

docker官方镜像仓库网速较差,我们需要设置国内镜像服务;参考阿里云的镜像加速文档:

https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器;在daemon.json中配置阿里云的镜像地址!

# 创建一个路径
sudo mkdir -p /etc/docker
# 把阿里云的地址追加到daemon.json文件
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://6aqbcoj9.mirror.aliyuncs.com"]
}
EOF # 表示终止
# 重新加载上面的文件
sudo systemctl daemon-reload
# 重启docker
sudo systemctl restart docker

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1307068.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HarmonyOS4.0从零开始的开发教程11Video组件的使用

HarmonyOS&#xff08;九&#xff09;Video组件的使用 概述 在手机、平板或是智慧屏这些终端设备上&#xff0c;媒体功能可以算作是我们最常用的场景之一。无论是实现音频的播放、录制、采集&#xff0c;还是视频的播放、切换、循环&#xff0c;亦或是相机的预览、拍照等功能…

06_W5500_DHCP

1.DHCP协议介绍&#xff1a; DHCP&#xff08;Dynamic Host Configuration Protocol&#xff09;是一种用于自动分配IP地址和其他网络配置信息的协议。它允许网络中的设备&#xff08;如计算机、手机、打印机等&#xff09;在连接到网络时自动获取IP地址、子网掩码、默认网关、…

数据入表 | 详解数据资产会计核算与企业应对

从2015年《促进大数据发展行动纲要》到2022年《数据20条》到2023年8月份出台了《企业数据资源相关会计处理暂行规定》&#xff0c;可见国家层面对数据的重视和探索如何进一步挖掘数据价值&#xff0c;发挥数据的应用潜力。一石激起千层浪&#xff0c;面对如此重要的规定&#x…

C++1114新标准——统一初始化(Uniform Initialization)、Initializer_list(初始化列表)、explicit

系列文章目录 C11&14新标准——Variadic templates&#xff08;数量不定的模板参数&#xff09; C11&14新标准——Uniform Initialization&#xff08;统一初始化&#xff09;、Initializer_list&#xff08;初始化列表&#xff09;、explicit 文章目录 系列文章目录1…

python+pytest接口自动化(12)-自动化用例编写思路 (使用pytest编写一个测试脚本)

经过之前的学习铺垫&#xff0c;我们尝试着利用pytest框架编写一条接口自动化测试用例&#xff0c;来厘清接口自动化用例编写的思路。 我们在百度搜索天气查询&#xff0c;会出现如下图所示结果&#xff1a; 接下来&#xff0c;我们以该天气查询接口为例&#xff0c;编写接口测…

【Java 基础】32 定时调度

文章目录 Timer 类创建 Timer注意事项 ScheduledExecutorService 接口创建 ScheduledExecutorService注意事项 选择合适的定时调度方式Timer 的适用场景ScheduledExecutorService 的适用场景 总结 在软件开发中&#xff0c;定时任务是一种常见的需求&#xff0c;用于周期性地执…

了解振弦采集仪:工程质量控制的得力助手

了解振弦采集仪&#xff1a;工程质量控制的得力助手 振弦采集仪是一种专门用于工程质量控制的仪器设备&#xff0c;它可以帮助工程师监测和评估结构物的振动性能。它的工作原理是通过将传感器固定在结构物上的振弦上&#xff0c;然后测量振弦的振动频率、振动幅度等参数&#…

GPTs prompts灵感库:创意无限,专业级创作指南,打造吸睛之作的秘诀

GPTs prompts灵感库&#xff1a;创意无限&#xff0c;专业级创作指南&#xff0c;打造吸睛之作的秘诀 优质prompt展示 1.1 极简翻译 中英文转换 你是一个极简翻译工具&#xff0c;请在对话中遵循以下规则&#xff1a; - Prohibit repeating or paraphrasing any user instru…

mysql更新某个字段=这个字段+字符串

当我们像c#中用拼接执行sql语句时&#xff0c;如下&#xff1a; UPDATE abpusers set UserNameqyUserName where UserNameqy-wh 会出现以下错误&#xff1a; 在mysql中通过concat函数来实现 UPDATE abpusers set UserNameCONCAT(qy_,UserName) where UserNameqy-wh

Unity中实现ShaderToy卡通火(总结篇)

文章目录 前言一、把卡通火修改为后处理效果1、在Shader属性面板定义属性接收帧缓存纹理2、在片元着色器对其纹理采样后&#xff0c;与卡通火相加输出请添加图片描述 二、我们自定义卡通火1、修改 _CUTOFF 使卡通火显示在屏幕两侧2、使火附近屏幕偏红色 前言 在之前的文章中&a…

PP材料粘接ABS材料使用UV胶的好处?

跟随着现阶段材料的不断发展更迭&#xff0c;PP材料应用越来越广&#xff0c;生产效率要求越来越高&#xff0c;为了加快生产&#xff0c;提高效率&#xff0c;PP材料的粘接上使用UV胶粘接PP&#xff08;聚丙烯&#xff09;和ABS&#xff08;丙烯腈-丁二烯-苯乙烯共聚物&#x…

AI日报:人工智能与新材料的发现

文章目录 总览人工智能正在革命性地发现新的或更强的材料&#xff0c;这将改变制造业。更坚韧的合金问题研究解决方案 新材料人工智能存在的挑战方法探索 日本的研究人员正在使用人工智能制造更强的金属合金或发现新材料&#xff0c;并彻底改变制造过程 总览 日本的研究人员开…

解决使用pnpm安装时Sharp模块报错的方法

在使用pnpm进行项目依赖安装的过程中&#xff0c;有时候会遇到Sharp模块报错的情况。Sharp是一个用于处理图像的Node.js模块&#xff0c;但它的安装可能会因为各种原因而失败&#xff0c;导致项目无法正常启动。本文将介绍这个问题的方法。 问题描述 解决方法 在命令行分别输…

【Zerotier】自建PLANET服务器内网地址连接

之前已经完成了【Zerotier】通过docker自建PLANET服务器&#xff0c;但是遇到一个问题&#xff0c;因为各种原因&#xff0c;内网里面的ZeroTier Client无法通过PLANET服务器的公网地址连接&#xff0c;愁怀了这下。在经过多方测试验证后&#xff0c;可以采取重新生成一个PLANE…

MYSQL练题笔记-子查询-电影评分

一、题目相关内容 1&#xff09;相关的表 2&#xff09;题目 3&#xff09;帮助理解题目的示例&#xff0c;提供返回结果的格式 二、自己初步的理解 1.字典序是指从前到后比较两个字符串大小的方法。 首先比较第1个字符&#xff0c;如果不同则第1个字符较小的字符串更小&…

Linux install manual 1Panel

前言 1Panel 是一个现代化、开源的 Linux 服务器运维管理面板。1Panel 的功能和优势包括: 快速建站:深度集成 Wordpress 和 Halo,域名绑定、SSL 证书配置等一键搞定;高效管理:通过 Web 端轻松管理 Linux 服务器,包括主机监控、文件管理、数据库管理、容器管理等;安全可…

CentOS 7.x操作系统的ECS云服务器上搭建WordPress网站

WordPress是使用PHP语言开发的博客平台&#xff0c;在支持PHP和MySQL数据库的服务器上&#xff0c;您可以用WordPress架设自己的网站&#xff0c;也可以用作内容管理系统&#xff08;CMS&#xff09;。本教程介绍如何在CentOS 7.x操作系统的ECS实例上搭建WordPress网站。 背景…

指针浅谈(四)

在指针浅谈(三)中http://t.csdnimg.cn/wYgJG我们知道了数组名是什么&#xff0c;任何用指针访问数组&#xff0c;一维数组传参的本质是什么&#xff0c;这一次我们来学习二级指针&#xff0c;指针数组&#xff0c;以及如何用指针数组模拟二维数组。 1.二级指针 指针变量也是变…

数据爬虫:获取申万一级行业数据

目录 1. 获取访问接口 2. 链接网址 3. 链接名单 免责声明&#xff1a;本文由作者参考相关资料&#xff0c;并结合自身实践和思考独立完成&#xff0c;对全文内容的准确性、完整性或可靠性不作任何保证。同时&#xff0c;文中提及的数据仅作为举例使用&#xff0c;不构成推荐…

1-4、JDK目录结构

语雀原文链接 文章目录 1、目录结构2、JDK中rt.jar、tools.jar和dt.jar作用3、bin目录部分说明&#xff08;基本工具&#xff09; 1、目录结构 bin目录&#xff1a;包含一些用于开发Java程序的工具&#xff0c;例如&#xff1a;编译工具(javac.exe)、运行工具 (java.exe) 、打…