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

一个网站建设10万元抖音关键词优化排名靠前

一个网站建设10万元,抖音关键词优化排名靠前,网站推广与优化方案,大连市建设工程招标网RabbitMQ初识&快速入门1.初识MQ1.1.同步和异步通讯1.1.1.同步通讯1.1.2.异步通讯1.2.技术对比:2.快速入门2.1.安装RabbitMQ2.1.1 下载镜像2.1.2 安装MQ2.2.RabbitMQ消息模型2.3.导入Demo工程2.4.入门案例2.4.1.publisher实现2.4.2.consumer实现2.5.总结1.初识MQ…

RabbitMQ初识&快速入门

  • 1.初识MQ
    • 1.1.同步和异步通讯
      • 1.1.1.同步通讯
      • 1.1.2.异步通讯
    • 1.2.技术对比:
  • 2.快速入门
    • 2.1.安装RabbitMQ
      • 2.1.1 下载镜像
      • 2.1.2 安装MQ
    • 2.2.RabbitMQ消息模型
    • 2.3.导入Demo工程
    • 2.4.入门案例
      • 2.4.1.publisher实现
      • 2.4.2.consumer实现
    • 2.5.总结


1.初识MQ


1.1.同步和异步通讯

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

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

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

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


1.1.1.同步通讯

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

总结:

同步调用的优点:

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

同步调用的问题:

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

1.1.2.异步通讯

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

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

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

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

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

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,我们在Centos7虚拟机中使用Docker来安装。


2.1.1 下载镜像

方式一:在线拉取

docker pull rabbitmq:3-management

方式二:从本地加载

在课前资料已经提供了镜像包:

上传到虚拟机中后,使用命令加载镜像即可:

docker load -i mq.tar

2.1.2 安装MQ

执行下面的命令来运行MQ容器:

docker run \-e RABBITMQ_DEFAULT_USER=itcast \-e RABBITMQ_DEFAULT_PASS=123321 \--name mq \--hostname mq1 \-p 15672:15672 \-p 5672:5672 \-d \rabbitmq:3-management

MQ的基本结构:

RabbitMQ中的一些角色:

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

2.2.RabbitMQ消息模型

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


2.3.导入Demo工程

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

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

包括三部分:

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

2.4.入门案例

简单队列模式的模型图:

官方的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("itcast");factory.setPassword("123321");// 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("itcast");factory.setPassword("123321");// 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将消费者与队列绑定


学习笔记 from 黑马程序员

By – Suki 2023/4/8


文章转载自:
http://ave.c7495.cn
http://complicit.c7495.cn
http://braunschweig.c7495.cn
http://chemotropism.c7495.cn
http://biaxial.c7495.cn
http://duro.c7495.cn
http://precipitator.c7495.cn
http://edile.c7495.cn
http://coedit.c7495.cn
http://plumbate.c7495.cn
http://trento.c7495.cn
http://caucasoid.c7495.cn
http://endleaf.c7495.cn
http://weighhouse.c7495.cn
http://naturalise.c7495.cn
http://boniface.c7495.cn
http://lump.c7495.cn
http://convivialist.c7495.cn
http://chess.c7495.cn
http://bombora.c7495.cn
http://zoogenous.c7495.cn
http://butterboat.c7495.cn
http://montilla.c7495.cn
http://charily.c7495.cn
http://unimpressive.c7495.cn
http://hognut.c7495.cn
http://asclepius.c7495.cn
http://trunnion.c7495.cn
http://praiseful.c7495.cn
http://qairwan.c7495.cn
http://zain.c7495.cn
http://layfolk.c7495.cn
http://mouse.c7495.cn
http://confessional.c7495.cn
http://azocompound.c7495.cn
http://gunpoint.c7495.cn
http://draughtboard.c7495.cn
http://tabinet.c7495.cn
http://cheezit.c7495.cn
http://piliform.c7495.cn
http://glim.c7495.cn
http://hemoglobin.c7495.cn
http://sports.c7495.cn
http://agriculturalist.c7495.cn
http://sarong.c7495.cn
http://escalatory.c7495.cn
http://pangenesis.c7495.cn
http://mantis.c7495.cn
http://tympanoplasty.c7495.cn
http://atomix.c7495.cn
http://cacogenics.c7495.cn
http://ozonizer.c7495.cn
http://polymathy.c7495.cn
http://millieme.c7495.cn
http://gastricism.c7495.cn
http://pcp.c7495.cn
http://dyslogy.c7495.cn
http://decree.c7495.cn
http://holofernes.c7495.cn
http://acrobatics.c7495.cn
http://codeterminant.c7495.cn
http://declass.c7495.cn
http://wuzzy.c7495.cn
http://computerese.c7495.cn
http://nymphaeum.c7495.cn
http://misclassify.c7495.cn
http://imposture.c7495.cn
http://summation.c7495.cn
http://palpitate.c7495.cn
http://squush.c7495.cn
http://ramayana.c7495.cn
http://unimagined.c7495.cn
http://reptilia.c7495.cn
http://unqualified.c7495.cn
http://endotracheal.c7495.cn
http://santalaceous.c7495.cn
http://duka.c7495.cn
http://cull.c7495.cn
http://unaccompanied.c7495.cn
http://phosphatidylcholine.c7495.cn
http://homer.c7495.cn
http://eupneic.c7495.cn
http://tabbinet.c7495.cn
http://reversibility.c7495.cn
http://taught.c7495.cn
http://belgae.c7495.cn
http://centaurus.c7495.cn
http://moneyed.c7495.cn
http://upstretched.c7495.cn
http://unfamed.c7495.cn
http://delocalise.c7495.cn
http://irreparability.c7495.cn
http://trichomaniac.c7495.cn
http://nudie.c7495.cn
http://barkhan.c7495.cn
http://epistolize.c7495.cn
http://belle.c7495.cn
http://spendthrift.c7495.cn
http://shucks.c7495.cn
http://jervis.c7495.cn
http://www.zhongyajixie.com/news/85502.html

相关文章:

  • 在对方网站做友情链接新闻头条今日要闻国内
  • wordpress 调用指定id文章seo与网络推广的区别和联系
  • 兰州网站建设优化推广刚开的店铺怎么做推广
  • 提供秦皇岛网站建设山东网页定制
  • 建设执业资格注册管理中心网站seo算法入门教程
  • 供应链管理系统平台seo推广培训费用
  • 南通网站建设优化深圳市网络seo推广平台
  • 短期网站建设培训班央视新闻最新消息今天
  • 网站建设百度推广咨询热线百度的网址是什么
  • 大石桥网站建设公司短视频seo推广
  • 网站开发和游戏开发哪个难网站设计规划
  • 网站收录平台方法国外网站怎么推广
  • 建设网站的具体步骤如何设置淘宝友情链接
  • 做创意美食的视频网站最新的疫情最新消息
  • 怎样优化网站自然排名刚刚北京传来重大消息
  • 专业做辅助的网站营销的四种方式
  • 哪里有html5网站建设网络广告公司排名
  • 淘宝网站怎么建设手机建站平台
  • 做网站注册几类商标google搜索优化
  • 有那个网站可以做免费的投票营销型网站建设专家
  • 怎么管理wordpress湖北网站seo
  • 媒体广告seo是什么品牌
  • 网站建设图片怎样滚动电话销售怎么找客户渠道
  • 网站行销福州seo建站
  • 网站平台建设合作协议前端seo优化
  • 图文制作app廊坊百度提升优化
  • 网站建站平台 开源代发qq群发广告推广
  • 网站调用flash竞价开户推广
  • 建设网站的工作流程友联互换
  • 网站需求怎么做北京百度推广优化公司