SpringCloud(二)Docker、Spring AMQP、ElasticSearch

文章目录

  • Docker
    • Docker与虚拟机
    • Docker架构
      • 镜像、容器、镜像托管平台
      • Docker架构
      • Docker实践
  • Spring AMQP
    • 简单使用案例
    • 工作队列- WorkQueue
    • 发布订阅服务
      • FanoutExchange
      • DirectExchange
      • TopicExchange
    • 消息转换器
  • ElasticSearch
    • 倒排索引
    • IK分词器
      • IK分词拓展与停用字典
    • 操作索引库
      • mapping映射属性
      • 创建索引库
      • 查询、删除、修改索引库
    • 文档操作
      • 新增、查询、删除文档
      • 修改文档
    • RestClient
      • 使用案例
      • 操作文档案例
    • DSL查询文档

Docker

Docker是一个快速交付应用、运用应用的技术:
1、Docker可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意的Linux操作系统。
2、运用时利用沙箱机制形成隔离容器,各个容器之间互不干扰。
3、启动、移除都可以通过一行命令完成,方便快捷。

Docker要解决的问题:
没有Docker时:
在这里插入图片描述

有Docker时:
在这里插入图片描述
Docker怎么解决不同Linux操作系统的问题呢?
在这里插入图片描述
在这里插入图片描述
总结:
在这里插入图片描述

Docker与虚拟机

  • Docker是将应用程序所依赖的环境库函数、包含操作系统的库函数都打包为一个容器。
  • 虚拟机则是通过Hypervisor技术来模拟硬件系统,使得上层应用感觉运行在一个新的操作系统中。
  • Docker的性能接近原生,硬盘占用一般为MB级,启动时间为秒级,而虚拟机性能则较差,硬盘占用一般为GB,启动时间为分钟级。
  • Docker是一个系统进程;而虚拟机是运行在操作系统中的操作系统。
  • Docker体积小,启动速度快,性能好,虚拟机体积大,启动速度慢,性能一般。

在这里插入图片描述

Docker架构

镜像、容器、镜像托管平台

镜像: Docker将应用程序及其所需要的依赖、环境、配置等文件打包在一起,称为镜像。
**容器:**镜像中的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见。
DockerHub:DockerHub是一个Docker镜像的托管平台,这样的平台称为Docker Register。国内也有类似于DockerHub的公开服务,比如阿里云镜像库等。

Docker架构

在这里插入图片描述

在这里插入图片描述

Docker实践

Spring AMQP

  • AMQP(Advanced Message Queuing Protocol)用于在应用程序之间传递业务消息的开放标准,该协议与语言和平台无关,是一种标准。
  • Spring AMQP是基于AMQP协议定义的一套API规范,提供了模板来发送和接收消息,包含了两部分内容:
    • spring-amqp是基础抽象
    • spring-rabbit是底层的默认实现

简单使用案例

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

工作队列- WorkQueue

在这里插入图片描述

在这里插入图片描述

消息发布者:约每秒发送50条消息

消息接收者:消费者1每秒消费50条,消费者2每秒消费5条。
在这里插入图片描述
结果:
消费者1消费偶数序号的消息,很快就处理完毕,约1秒。

在这里插入图片描述
消费者2消费奇数序号的消息,耗时约5秒才完成。
在这里插入图片描述

消息被平均的分配给了两个消费者,没有考虑消费者的具体消费能力。这是消息队列默认的消息预取机制导致的结果,消费者1和2都预取了25条消息。

通过修改配置文件,更改消息预取配置,预取数设置为1.
在这里插入图片描述
结果:
消费者1消费了大量的消息,能者多劳,在约1秒内,消费掉了所有的消息。

在这里插入图片描述
在这里插入图片描述

发布订阅服务

发布订阅模式与之前的案例区别就是允许将同一个消息发送给多个消费者,实现方式就是加入了exchange(交换机)。
在这里插入图片描述

FanoutExchange

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
交换机绑定完毕后,可以在rabbit mq的前台看到绑定关系:
在这里插入图片描述

消费者:
在这里插入图片描述
发送者向交换机发送消息:
在这里插入图片描述

DirectExchange

DirectExchange通过bindingKey比对,决定是否想队列发送消息。

如果多个队列绑定了相同的key,那么DirectExchange是可以模拟出FanOutExchange的效果的。
在这里插入图片描述

在本次案例中,我们在注解@RabbitListener中声明Exchange、Queue、RoutingKey,因为每次通过@Bean的形式声明绑定关系会比较繁琐。

在这里插入图片描述
直接在消费者端@RabbitListener中声明队列、交换机和绑定关系:
在这里插入图片描述
启动后,在Rabbit前台可以看到交换机和队列均已生成:

在这里插入图片描述
在这里插入图片描述

TopicExchange

TopicExchange与DirectExchange最大的区别在于,Topic 是基于话题匹配,可以使用通配符,匹配BindingKey。
在这里插入图片描述
在这里插入图片描述
TopicExchange与DirectExchange声明的方式基本是一致的:
在这里插入图片描述

消息转换器

在使用SpringAMQP时,发送消息的参数类型为Object,因此可以发送任意类型的消息,但是SpringAMQP默认使用的是JDK自带的序列化方式,序列化效率低。
在这里插入图片描述
使用json序列化之后:
发送一个Map对象:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

ElasticSearch

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

倒排索引

什么是文档和词条?

  • 每一条数据就是一个文档
  • 对文档中的内容进行分词,得到的词语就是词条。

什么是正向索引和倒排索引?

  • 基于文档id创建索引,查询词条时必须先找到文档,而后判断是否包含词条。
  • 对文档内容分词,对词条创建索引,并记录词条所在的文档的信息,查询时先根据词条查询到文档id,而后获取到文档。

在这里插入图片描述
在这里插入图片描述

IK分词器

在这里插入图片描述

IK分词拓展与停用字典

IK分词器基于自有的字典进行分词,然后网络热门词汇都是实时更新的,还有些时候,需要对敏感词进行过滤,这时就需要用到IK分词器的拓展和停用字典。

例如下边的例子中,“白嫖”、“奥利给”等新兴词汇没有被收录IK分词器的词典,因此没有成功被分词。

在这里插入图片描述

在这里插入图片描述

在ElasticSearch的配置文件中设置拓展字典路径:
在这里插入图片描述
在ext.dir添加:
在这里插入图片描述
在stopword.dir添加:
在这里插入图片描述

操作索引库

mapping映射属性

  • mapping映射对文档进行约束,比如字符串类型,分为text(可分词的文本)和keyword(精确值,包含国家名、品牌名、ip等)。

  • mapping映射属性虽然没有数组类型,但是每个类型的字段都允许对应多个值,视为该类型的数组。

  • index:默认为true,即为每个属性字段都添加倒排索引,实际上有些字段是无需索引的,比如ip,那么就可以将其设置为false。

在这里插入图片描述

创建索引库

PUT
在这里插入图片描述

查询、删除、修改索引库

在这里插入图片描述

在这里插入图片描述

文档操作

新增、查询、删除文档

在这里插入图片描述

修改文档

在这里插入图片描述
在这里插入图片描述

RestClient

在这里插入图片描述

使用案例

步骤一导入数据模型:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

将Client作为成员变量,使用@BeforeEach,给Client成员赋值,主要就是连接上ES的服务器ip。

使用@AfterEach,在结束时释放掉Client。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

操作文档案例

文档操作的基本步骤:

  1. 初始化RestHighLevelClient
  2. 创建XxxRequest,XXX是index(新建文档)、Get(查询)、Update(更新)、Delete(删除)
  3. 准备参数(Index和Update时需要)
  4. 发送请求。调用RestHighLevelClient#.xxx()方法,xxx是index、get、update、delete。

在这里插入图片描述
从数据库查询一条酒店信息,并新增文档到ES:
在这里插入图片描述
根据id查询文档:
在这里插入图片描述
根据id修改酒店数据:

在这里插入图片描述
根据id删除文档:
在这里插入图片描述
批量导入酒店数据到ES:
在这里插入图片描述
在这里插入图片描述

DSL查询文档

DSL(Domain Specific Language),一种特定领域的查询语言,用于构建复杂的查询和聚合操作。

在Elasticsearch中,可用DSL语法来定义查询和过滤条件,以及执行聚合操作。
DSL语法具有JSON格式(敲重点,要考),因此它非常易于阅读和编写。

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

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

相关文章

Dubbo 融合 Nacos 成为注册中心

Nacos 作为 Dubbo 生态系统中重要的注册中心实现,本文将会介绍如何进行 Dubbo 对接 Nacos 注册中心的工作。 预备工作 请确保后台已经启动 Nacos 服务 快速上手 Dubbo 融合 Nacos 成为注册中心的操作步骤非常简单,大致步骤可分为“增加 Maven 依赖”…

与值域有关的问题(非权值线段树)——运用分块:1004T1

区间小于等于某值区间加 显然同时涉及区间和值域&#xff0c;不能用log级ds来做&#xff0c;常见套路就是上分块 这题是个复合题&#xff0c;后面就是个组合数 #include<bits/stdc.h> using namespace std; #define int long long inline int read(){int x0,f1;char c…

创建vue3工程

一、新建工程目录E:\vue\projectCode\npm-demo用Visual Studio Code 打开目录 二、点击新建文件夹按钮&#xff0c;新建vue3-01-core文件夹 三、右键vue3-01-core文件夹点击在集成终端中打开 四、初始化项目&#xff0c;输入npm init 一直敲回车直到创建成功如下图 npm init 五…

国庆加速度!新增功能点锁定功能,敏捷开发新增估算功能,助力项目快速突破!

大家好&#xff0c;CoCode开发云旗下Co-Project V3.6智能项目管理平台正式发布&#xff0c;平台新增功能点锁定功能、敏捷开发模式新增估算板块和两种估算方式。 功能点锁定功能进一步提高了项目估算的灵活性和准确性&#xff0c;有利于提高项目估算效率&#xff1b;而敏捷开发…

JAVA面经整理(8)

一)为什么要有区&#xff0c;段&#xff0c;页&#xff1f; 1)页是内存和磁盘之间交互的基本单位内存中的值修改之后刷到磁盘的时候还是以页为单位的索引结构给程序员提供了高效的索引实现方式&#xff0c;不过索引信息以及数据记录都是记录在文件上面的&#xff0c;确切来说是…

六、互联网技术——数据存储

文章目录 一、存储系统层次结构二、按照重要性分类三、磁盘阵列RAID三、RAID基础四、磁盘阵列分级五、数据备份与恢复六、容灾与灾难恢复 一、存储系统层次结构 常见的三层存储体系结构如下图所示&#xff0c;分为高速缓冲存储器、主存储器和外存储器。 二、按照重要性分类 …

Android自定义Drawable---灵活多变的矩形背景

Android自定义Drawable—灵活多变的矩形背景 在安卓开发中&#xff0c;我们通常需要为不同的按钮设置不同的背景以实现不同的效果&#xff0c;有时还需要这些按钮根据实际情况进行变化。如果采用编写resource中xml文件的形式&#xff0c;就需要重复定义许多只有微小变动的资源…

CSDN Q: “这段代码算是在STC89C52RC51单片机上完成PWM呼吸灯了吗?“

这是 CSDN上的一个问题 这段代码算是在STC89C52RC51单片机上完成PWM呼吸灯了吗&#xff0c;还是说得用上定时器和中断函数#include <regx52.h> 我个人认为: 效果上来说, 是的! 码以 以Time / 100-Time 调 Duty, 而 for i loop成 Period, 加上延时, 实现了 PWM周期, 虽然…

【LeetCode热题100】--34.在排序数组中查找元素的第一个和最后一个位置

34.在排序数组中查找元素的第一个和最后一个位置 二分查找中&#xff0c;寻找 leftIdx 即为在数组中寻找第一个大于等于 target 的下标&#xff0c;寻找 rightIdx 即为在数组中寻找第一个大于 target 的下标&#xff0c;然后将下标减一。进行两次查找 class Solution {public …

43 验证二叉搜索树

验证二叉搜索树 理解题意&#xff1a;验证搜索二叉树&#xff1a;中序遍历是升序题解1 递归&#xff08;学习学习&#xff01;&#xff09;题解2 中序遍历&#xff08;保持升序&#xff09; 给你一个二叉树的根节点 root &#xff0c;判断其是否是一个 有效的二叉搜索树。 有…

Flutter项目安装到Android手机一直显示在assembledebug

问题 Flutter项目安装到Android手机一直显示在assembledebug 原因 网络不好&#xff0c;gradle依赖下载不下来 解决方案 修改如下的文件 gradle-wrapper.properties 使用腾讯提供的gradle镜像下载 distributionUrlhttps://mirrors.cloud.tencent.com/gradle/gradle-7.5…

mac openssl 版本到底怎么回事 已解决

在mac 安装node多版本的时候&#xff0c;有可能把原有的 openssl1.1 版本 直接要再一次升级了&#xff0c;无奈的 php环境 编译器是 openssl 1.1 还是 3.0 &#xff0c;今天来个底朝天的找问题。 brew search openssl 有安装 三个版本。 但是错误提示 是第二个版本。 brew …

十月四日作业

1、服务器 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTcpServer> //服务器头文件 #include <QTcpSocket> //客户端头文件 #include <QList> //链表容器 #include <…

git 提交代码,解决分支冲突,合并分支

克隆代码 git clone 仓库地址 克隆指定分支 git clone -b 分支名称 仓库地址 上传到分支上 1.克隆代码&#xff1a;git clone 仓库地址 注意&#xff1a;克隆仓库&#xff0c;会自动连接远程仓库的 2.修改代码完毕 3.git init 4.创建分支&#xff1a;git branch 分支名称 5…

Spring — 三级缓存和 循环依赖

置顶 学习专栏&#xff1a;【Java后端面试题】 1.Java面试题—基础知识、面向对象、【容器】、IO & 【设计模式】、泛型 & 异常 & 反射 & 注解、快速排序2.Java面试题—并发基础、【同步 & 互斥】、JUC & 并发容器、【线程池】、异步编程、【Lambda表达…

传输层协议—TCP协议

传输层协议—TCP协议 文章目录 传输层协议—TCP协议TCP协议段格式四位首部长度TCP协议如何根据目的端口号将数据传输给指定进程&#xff1f;32位序列号和32位确认序列号可靠性问题 TCP报头标志位16位紧急指针16位检验和确认应答机制超时重传机制再谈三次握手四次挥手 连接管理机…

什么是数学建模(mooc笔记)

什么是数学建模 前提&#xff1a;我们数学建模国赛计划选择C题&#xff0c;故希望老师的教学中侧重与C题相关性大的模型及其思想进行培训。之后的学习内容中希望涉及以下知识点&#xff1a; logistic回归相关知识点。如&#xff1a;用法、适用、限制范围等。精学数学建模中常…

常见的锁策略

目录 一.乐观锁 vs 悲观锁 二.轻量级锁 vs 重量级锁 三.自旋锁 vs 挂起等待锁 四.互斥锁 vs 读写锁 五.可重入锁 vs不可重入锁 一.乐观锁 vs 悲观锁 悲观锁 : 总是假设最坏的情况&#xff0c;每次去拿数据的时候都认为别人会修改&#xff0c;所以每次在拿数据的时候都会上锁…

448. 找到所有数组中消失的数字

题目描述 给你一个含 n 个整数的数组 nums &#xff0c;其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字&#xff0c;并以数组的形式返回结果。 示例 1&#xff1a; 输入&#xff1a;nums [4,3,2,7,8,2,3,1] 输出&#xff1a;[5,6…

php单独使用think-rom数据库 | thinkphp手动关闭数据库连接

背景&#xff08;think-orm2.0.61&#xff09; 由于需要长时间运行一个php脚本&#xff0c;而运行过程并不是需要一直与数据库交互&#xff0c;但thinkphp主要是为web站点开发的框架&#xff0c;而站点一般都是数据获取完则进程结束&#xff0c;所以thinkphp没提供手动关闭数据…