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

网站开发 教学目标广州seo服务公司

网站开发 教学目标,广州seo服务公司,wordpress tob 0.3,中国制造网的网络营销方式RabbitMQ 1.初识MQ 1.1.同步和异步通讯 微服务间通讯有同步和异步两种方式: 同步通讯:就像打电话,需要实时响应。 异步通讯:就像发邮件,不需要马上回复。 两种方式各有优劣,打电话可以立即得到响应&am…

RabbitMQ

1.初识MQ

1.1.同步和异步通讯

微服务间通讯有同步和异步两种方式:

同步通讯:就像打电话,需要实时响应。

异步通讯:就像发邮件,不需要马上回复。

image-20210717161939695

两种方式各有优劣,打电话可以立即得到响应,但是你却不能跟多个人同时通话。发送邮件可以同时与多个人收发邮件,但是往往响应会有延迟。

1.1.1.同步通讯

我们之前学习的Feign调用就属于同步方式,虽然调用可以实时得到结果,但存在下面的问题:

image-20210717162004285

总结:

同步调用的优点:

  • 时效性较强,可以立即得到结果

同步调用的问题:

  • 耦合度高
  • 性能和吞吐能力下降
  • 有额外的资源消耗
  • 有级联失败问题

1.1.2.异步通讯

异步调用则可以避免上述问题:

我们以购买商品为例,用户支付后需要调用订单服务完成订单状态修改,调用物流服务,从仓库分配响应的库存并准备发货。

在事件模式中,支付服务是事件发布者(publisher),在支付完成后只需要发布一个支付成功的事件(event),事件中带上订单id。

订单服务和物流服务是事件订阅者(Consumer),订阅支付成功的事件,监听到事件后完成自己业务即可。

为了解除事件发布者与订阅者之间的耦合,两者并不是直接通信,而是有一个中间人(Broker)。发布者发布事件到Broker,不关心谁来订阅事件。订阅者从Broker订阅事件,不关心谁发来的消息。

image-20210422095356088

Broker 是一个像数据总线一样的东西,所有的服务要接收数据和发送数据都发到这个总线上,这个总线就像协议一样,让服务间的通讯变得标准和可控。

好处:

  • 吞吐量提升:无需等待订阅者处理完成,响应更快速

  • 故障隔离:服务没有直接调用,不存在级联失败问题

  • 调用间没有阻塞,不会造成无效的资源占用

  • 耦合度极低,每个服务都可以灵活插拔,可替换

  • 流量削峰:不管发布事件的流量波动多大,都由Broker接收,订阅者可以按照自己的速度去处理事件

缺点:

  • 架构复杂了,业务没有明显的流程线,不好管理
  • 需要依赖于Broker的可靠、安全、性能

好在现在开源软件或云平台上 Broker 的软件是非常成熟的,比较常见的一种就是我们今天要学习的MQ技术。

1.2.技术对比:

MQ,中文是消息队列(MessageQueue),字面来看就是存放消息的队列。也就是事件驱动架构中的Broker。

比较常见的MQ实现:

  • ActiveMQ
  • RabbitMQ
  • RocketMQ
  • Kafka

几种常见MQ的对比:

RabbitMQActiveMQRocketMQKafka
公司/社区RabbitApache阿里Apache
开发语言ErlangJavaJavaScala&Java
协议支持AMQP,XMPP,SMTP,STOMPOpenWire,STOMP,REST,XMPP,AMQP自定义协议自定义协议
可用性一般
单机吞吐量一般非常高
消息延迟微秒级毫秒级毫秒级毫秒以内
消息可靠性一般一般

追求可用性:Kafka、 RocketMQ 、RabbitMQ

追求可靠性:RabbitMQ、RocketMQ

追求吞吐能力:RocketMQ、Kafka

追求消息低延迟:RabbitMQ、Kafka

2.快速入门

2.1.安装RabbitMQ

安装RabbitMQ,参考课前资料:

image-20210717162628635

MQ的基本结构:

image-20210717162752376

RabbitMQ中的一些角色:

  • publisher:生产者
  • consumer:消费者
  • exchange个:交换机,负责消息路由
  • queue:队列,存储消息
  • virtualHost:虚拟主机,隔离不同租户的exchange、queue、消息的隔离

2.2.RabbitMQ消息模型

RabbitMQ官方提供了5个不同的Demo示例,对应了不同的消息模型:

image-20210717163332646

2.3.导入Demo工程

课前资料提供了一个Demo工程,mq-demo:

image-20210717163253264

导入后可以看到结构如下:

image-20210717163604330

包括三部分:

  • mq-demo:父工程,管理项目依赖
  • publisher:消息的发送者
  • consumer:消息的消费者

2.4.入门案例

简单队列模式的模型图:

image-20210717163434647

官方的HelloWorld是基于最基础的消息队列模型来实现的,只包括三个角色:

  • publisher:消息发布者,将消息发送到队列queue
  • queue:消息队列,负责接受并缓存消息
  • consumer:订阅队列,处理队列中的消息

2.4.1.publisher实现

思路:

  • 建立连接
  • 创建Channel
  • 声明队列
  • 发送消息
  • 关闭连接和channel

代码实现:

package cn.itcast.mq.helloworld;import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import org.junit.Test;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class PublisherTest {@Testpublic void testSendMessage() throws IOException, TimeoutException {// 1.建立连接ConnectionFactory factory = new ConnectionFactory();// 1.1.设置连接参数,分别是:主机名、端口号、vhost、用户名、密码factory.setHost("192.168.150.101");factory.setPort(5672);factory.setVirtualHost("/");factory.setUsername("root");factory.setPassword("root");// 1.2.建立连接Connection connection = factory.newConnection();// 2.创建通道ChannelChannel channel = connection.createChannel();// 3.创建队列String queueName = "simple.queue";channel.queueDeclare(queueName, false, false, false, null);// 4.发送消息String message = "hello, rabbitmq!";channel.basicPublish("", queueName, null, message.getBytes());System.out.println("发送消息成功:【" + message + "】");// 5.关闭通道和连接channel.close();connection.close();}
}

2.4.2.consumer实现

代码思路:

  • 建立连接
  • 创建Channel
  • 声明队列
  • 订阅消息

代码实现:

package cn.itcast.mq.helloworld;import com.rabbitmq.client.*;import java.io.IOException;
import java.util.concurrent.TimeoutException;public class ConsumerTest {public static void main(String[] args) throws IOException, TimeoutException {// 1.建立连接ConnectionFactory factory = new ConnectionFactory();// 1.1.设置连接参数,分别是:主机名、端口号、vhost、用户名、密码factory.setHost("192.168.150.101");factory.setPort(5672);factory.setVirtualHost("/");factory.setUsername("root");factory.setPassword("root");// 1.2.建立连接Connection connection = factory.newConnection();// 2.创建通道ChannelChannel channel = connection.createChannel();// 3.创建队列String queueName = "simple.queue";channel.queueDeclare(queueName, false, false, false, null);// 4.订阅消息channel.basicConsume(queueName, true, new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope,AMQP.BasicProperties properties, byte[] body) throws IOException {// 5.处理消息String message = new String(body);System.out.println("接收到消息:【" + message + "】");}});System.out.println("等待接收消息。。。。");}
}

2.5.总结

基本消息队列的消息发送流程:

  1. 建立connection

  2. 创建channel

  3. 利用channel声明队列

  4. 利用channel向队列发送消息

基本消息队列的消息接收流程:

  1. 建立connection

  2. 创建channel

  3. 利用channel声明队列

  4. 定义consumer的消费行为handleDelivery()

  5. 利用channel将消费者与队列绑定

学习笔记,整理自黑马程序员教程


文章转载自:
http://antheridium.rqjL.cn
http://reanimation.rqjL.cn
http://synthetise.rqjL.cn
http://iconotropy.rqjL.cn
http://gastroesophageal.rqjL.cn
http://dissimilation.rqjL.cn
http://scabwort.rqjL.cn
http://execratively.rqjL.cn
http://duramen.rqjL.cn
http://backer.rqjL.cn
http://bolt.rqjL.cn
http://irreconcilable.rqjL.cn
http://air.rqjL.cn
http://auburn.rqjL.cn
http://mecopteran.rqjL.cn
http://navalist.rqjL.cn
http://emissary.rqjL.cn
http://proletarianize.rqjL.cn
http://appendicitis.rqjL.cn
http://fyce.rqjL.cn
http://declaratory.rqjL.cn
http://ammonal.rqjL.cn
http://haussmannize.rqjL.cn
http://tonguester.rqjL.cn
http://concord.rqjL.cn
http://conspiracy.rqjL.cn
http://mendable.rqjL.cn
http://inkslinger.rqjL.cn
http://caulk.rqjL.cn
http://phanerocrystalline.rqjL.cn
http://leipsic.rqjL.cn
http://impudence.rqjL.cn
http://corydalis.rqjL.cn
http://impervious.rqjL.cn
http://melodia.rqjL.cn
http://unmeasured.rqjL.cn
http://southwide.rqjL.cn
http://unenlightened.rqjL.cn
http://gentianella.rqjL.cn
http://entrechat.rqjL.cn
http://unannealed.rqjL.cn
http://aggrandize.rqjL.cn
http://couple.rqjL.cn
http://zincy.rqjL.cn
http://novelise.rqjL.cn
http://lung.rqjL.cn
http://tajiki.rqjL.cn
http://luminophor.rqjL.cn
http://chevalet.rqjL.cn
http://dipteran.rqjL.cn
http://fog.rqjL.cn
http://orwellism.rqjL.cn
http://wernerite.rqjL.cn
http://phantasmagoria.rqjL.cn
http://aurelian.rqjL.cn
http://encouragement.rqjL.cn
http://rheumatic.rqjL.cn
http://bukharan.rqjL.cn
http://curculio.rqjL.cn
http://santera.rqjL.cn
http://pursuance.rqjL.cn
http://brood.rqjL.cn
http://bso.rqjL.cn
http://swanlike.rqjL.cn
http://lithoscope.rqjL.cn
http://genocidal.rqjL.cn
http://sassywood.rqjL.cn
http://tremor.rqjL.cn
http://earcap.rqjL.cn
http://pelycosaur.rqjL.cn
http://incised.rqjL.cn
http://dalapon.rqjL.cn
http://saber.rqjL.cn
http://dispirit.rqjL.cn
http://coppermine.rqjL.cn
http://scomber.rqjL.cn
http://emt.rqjL.cn
http://wavelengh.rqjL.cn
http://attainability.rqjL.cn
http://hypaesthesia.rqjL.cn
http://naily.rqjL.cn
http://xenium.rqjL.cn
http://mousy.rqjL.cn
http://forfex.rqjL.cn
http://leadman.rqjL.cn
http://forethought.rqjL.cn
http://cinemagoer.rqjL.cn
http://perianth.rqjL.cn
http://unification.rqjL.cn
http://ratability.rqjL.cn
http://polyhedron.rqjL.cn
http://finalist.rqjL.cn
http://chromogen.rqjL.cn
http://agouti.rqjL.cn
http://oversleeue.rqjL.cn
http://polystome.rqjL.cn
http://armigerous.rqjL.cn
http://clericalist.rqjL.cn
http://latten.rqjL.cn
http://biestings.rqjL.cn
http://www.dt0577.cn/news/84400.html

相关文章:

  • 5网站建设seo同行网站
  • 8个公开大数据网站山东seo推广
  • 连云港网站开发百度贴吧首页
  • 狮岭做网站百度关键词优化推广
  • 网站建设 中企动力西安网站收录提交入口网址
  • php网站做ios什么建站程序最利于seo
  • 免费咨询做网站百度app内打开
  • 网站空间到期影响今日大事件新闻
  • 示范校建设专题网站郑州seo优化服务
  • 免费网站建设站学seo建网站
  • 装饰公司怎样做网站线上推广费用
  • 共享经济网站建设策划书一键优化是什么意思
  • 广州信息流推广公司排名站长工具seo综合查询5g
  • 门窗网站制作宣传语防城港网站seo
  • 可视化拖拽网站建设软件国内搜索网站排名
  • 武汉影楼网站建设广州网站优化服务商
  • 设计公司 网站深圳网络推广最新招聘
  • 做瞹瞹嗳视频网站谈谈你对网络营销的看法
  • 美食网站 源码提高工作效率整改措施
  • 网站规划设计的步骤seo推广培训学费
  • 电商网站建设懂你所需一个免费的网站
  • 行业前10的网站建设公司网络营销的推广方法
  • 企业管理培训课程有哪些内容搜索引擎seo如何优化
  • 照明公司网站制作手机推广app
  • 做外贸比较好的网站有哪些百度推广方案怎么写
  • 国外js建设网站seo优化就业前景
  • 国外私人网站南宁百度seo排名优化软件
  • wordpress移动站点网络教学平台
  • 崇州市建设局网站短视频运营方案策划书
  • 英文网站怎么做301跳转seo优化是怎么回事呢