`
braveCS
  • 浏览: 73994 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

rabbitmq的配置,federation,api(官网文档搬运,仅记录)

 
阅读更多

Configuration

default built-in settings+3种配置方法: 修改配置后续重启生效,配置文件可以create/edit

1)environment variables:配置端口ports,配置文件路径filelocations,服务名称NODENAME.(override the defaults built in to the RabbitMQ startup scripts,taken from the shell, 可以配置在/etc/rabbitmq/rabbitmq-env.conf文件里)。

 

RabbitMQ environment variable names have the prefix RABBITMQ_. A typical variable calledRABBITMQ_var_name is set as follows:

  • a shell environment variable called RABBITMQ_var_name is used if this is defined;
  • otherwise, a variable called var_name is used if this is set in the rabbitmq-env.conf file;
  • otherwise, a system-specified default value is used.

 

如果在/rabbitmq-env.conf文件里,Use the standard environment variable names (but drop the RABBITMQ_ prefix) e.g.

 

#example rabbitmq-env.conf file entries
#Rename the node
NODENAME=bunny@myhost
#Config file location and new filename bunnies.config
CONFIG_FILE=/etc/rabbitmq/testdir/bunnies

 

2)a configuration file:defines [server component(RabbitMQ core application, Erlang services and RabbitMQ plugins)] settings for permissions, limits and clusters, and also plugin settings.  标准的erlang配置文件,例子:

 

  [
    {mnesia, [{dump_log_write_threshold, 1000}]},
    {rabbit, [{tcp_listeners, [5673]}]}
  ].

 

This example will alter the dump_log_write_threshold for mnesia (increasing from the default of 100), and alter the port RabbitMQ listens on from 5672 to 5673.

3)runtime parameters and policies:defines cluster-wide settings which can change at run time

Distributed RabbitMQ brokers

AMQP and the other messaging protocols supported by RabbitMQ via plug-ins (e.g. STOMP), are (of course) inherently distributed - it is quite common for applications from multiple machines to connect to a single broker, even across the internet.

RabbitMQ broker分布式的方法:1)clustering, 2)federation, 3)using the shovel

Note that you do not need to pick a single approach - you can connect clusters together with federation, or the shovel, or both.

Clustering

Clustering connects multiple machines together to form a single logical broker. Communication is via Erlang message-passing.
1)all nodes in the cluster must have the same Erlang cookie;
2)The network links between machines in a cluster must be reliable; 
3)all machines in the cluster must run the same versions of RabbitMQ and Erlang.
Virtual hosts, exchanges, users, and permissions are automatically mirrored across all nodes in a cluster. Queues may be located on a single node, or mirrored across multiple nodes. A client connecting to any node in a cluster can see all queues in the cluster, even if they are not located on that node.

Typically you would use clustering for high availability and increased throughput, with machines in a single location.

Federation

Federation allows an exchange or queue on one broker to receive messages published to an exchange or queue on another (the brokers may be individual machines, or clusters). Communication is via AMQP (with optional SSL), so for two exchanges or queues to federate they must be granted appropriate users and permissions.

Federated exchanges are connected with one way point-to-point links. By default, messages will only be forwarded over a federation link once, but this can be increased to allow for more complex routing topologies. Some messages may not be forwarded over the link; if a message would not be routed to a queue after reaching the federated exchange, it will not be forwarded in the first place.

Federated queues are similarly connected with one way point-to-point links. Messages will be moved between federated queues an arbitrary number of times to follow the consumers.

Typically you would use federation to link brokers across the internet for pub/sub messaging and work queueing.

The Shovel

Connecting brokers with the shovel is conceptually similar to connecting them with federation. However, the shovel works at a lower level.

Whereas federation aims to provide opinionated distribution of exchanges and queues, the shovel simply consumes messages from a queue on one broker, and forwards them to an exchange on another.

Typically you would use the shovel to link brokers across the internet when you need more control than federation provides.

Dynamic shovels can also be useful for moving messages around in an ad-hoc manner on a single broker.

Summary

Federation / Shovel Clustering
Brokers are logically separate and may have different owners. A cluster forms a single logical broker.
Brokers can run different versions of RabbitMQ and Erlang. Nodes must run the same version of RabbitMQ, and frequently Erlang.
Brokers can be connected via unreliable WAN links. Communication is via AMQP (optionally secured by SSL), requiring appropriate users and permissions to be set up. Brokers must be connected via reliable LAN links. Communication is via Erlang internode messaging, requiring a shared Erlang cookie.
Brokers can be connected in whatever topology you arrange. Links can be one- or two-way. All nodes connect to all other nodes in both directions.
Chooses Availability and Partition Tolerance from the CAP theorem. Chooses Consistency and Availability (or optionally Consistency and Partition Tolerance) from the CAP theorem.
Some exchanges in a broker may be federated while some may be local. Clustering is all-or-nothing.
A client connecting to any broker can only see queues in that broker. A client connecting to any node can see queues on all nodes.
 

Federation



 
upstream的rmq和federated的rmq都要装federated-plugin
rabbitmq-plugins enable rabbitmq_federation
rabbitmq-plugins enable rabbitmq_federation_management
使用webUI操作,要装managment-plugin
rabbitmq-plugins enable rabbitmq_management


 
  • Upstreams - 定义如何连接到upstream的rmq上
  • Upstream sets - upstream的集合,默认一个all集合(包含所有定义好的upstream)
  • Policies - 定义的一批配置,  整批的配置可以按pattern apply to给具体的rmq组件(exchange,queue,connections....),这里是把配置好的federation upstream配置应用到哪个exchange
    参数:
    1)uri:The AMQP URI(s) for the upstream. 必填. 
     
    2)prefetch-count:The maximum number of unacknowledged messages copied over a link at any one time. Default is 1000.
    3)reconnect-delay:The duration (in seconds) to wait before reconnecting to the broker after being disconnected. Default is 1.3)ack-mode:Determines how the link should acknowledge messages.        on-confirm (the default):messages are acknowledged to the upstream broker after they have been confirmed downstream. This handles network errors and broker failures without losing messages, and is the slowest option.       on-publish:messages are acknowledged to the upstream broker after they have been published downstream. This handles network errors without losing messages, but may lose messages in the event of broker failures.       no-ack:message acknowledgements are not used. This is the fastest option, but may lose messages in the event of network or broker failures.4)trust-user-id:Determines how federation should interact with the validated user-id feature. If set to true, federation will pass through any validated user-id from the upstream, even though it cannot validate it itself. If set to false or not set, it will clear any validated user-id it encounters. You should only set this to true if you trust the upstream server (and by extension, all its upstreams) not to forge user-ids.

     

    5)exchange:The name of the upstream exchange. Default is to use the same name as the federated exchange.6)max-hops:The maximum number of federation links that a message published to a federated exchange can traverse before it is discarded. Default is 1. Note that even if max-hops is set to a value greater than 1, messages will never visit the same node twice due to travelling in a loop. However, messages may still be duplicated if it is possible for them to travel from the source to the destination via multiple routes.7)expires:The expiry time (in milliseconds) after which an upstream queue for a federated exchange may be deleted, if a connection to the upstream broker is lost. The default is 'none', meaning the queue should never expire.This setting controls how long the upstream queue will last before it is eligible for deletion if the connection is lost.This value is used to set the "x-expires" argument for the upstream queue.8)message-ttl:The expiry time for messages in the upstream queue for a federated exchange (see expires), in milliseconds. Default is 'none', meaning messages should never expire. This does not apply to federated queues.This value is used to set the "x-message-ttl" argument for the upstream queue.9)ha-policy:Determines the "x-ha-policy" argument for the upstream queue for a federated exchange (seeexpires). This is only of interest when connecting to old brokers which determine queue HA mode using this argument. Default is 'none', meaning the queue is not HA. 

     

    常用命令

    开机启动:chkconfig rabbitmq-server on

    开关服务:/sbin/rabbitmq-server start

    ·                         rabbitmqctl stop 

    ·     查看状态:rabbitmqctl status 

    插件 :rabbitmq-plugin list
  •  

     

     

    组件

     

    Producer

     

    Connection

      ConnectionFactory factory = new ConnectionFactory();

      factory.setHost("localhost");

      Connection connection = factory.newConnection(); è创建2个线程,一个心跳线程发送心跳帧,一个接收帧读主线程(特殊帧则由channel0处理,不是则使用channelManage根据帧的channlid获得channel,在channel进行handleFrame),如果是非心跳帧则发送给channel

    connection 封装socket connection,负责protocol version negotiation and authentication

    1)用一个channel channel0Server进行协议参数

     

    特点:

    1)使用完必须关闭

    2)线程池

    Consumer threads  are automatically allocated in a new ExecutorService thread pool by default.

    If greater control is required supply an ExecutorService on the newConnection() method, so that this pool of threads is used instead. Here is an example where a larger thread pool is supplied than is normally allocated:

    ExecutorService es = Executors.newFixedThreadPool(20);

    Connection conn = factory.newConnection(es);

    When the connection is closed a default ExecutorService will be shutdown(), but a user-suppliedExecutorService (like es above) will not be shutdown(). Clients that supply a custom ExecutorService must ensure it is shutdown eventually (by calling its shutdown() method), or else the pool’s threads may prevent JVM termination.

    The same executor service may be shared between multiple connections, or serially re-used on re-connection but it cannot be used after it is shutdown().

    适用场景:if there is evidence that there is a severe bottleneck in the processing of Consumer callbacks. If there are no Consumer callbacks executed, or very few, the default allocation is more than sufficient. The overhead is initially minimal and the total thread resources allocated are bounded, even if a burst of consumer activity may occasionally occur.

    3Address array

     

    Channel

    Channel channel = connection.createChannel();

    属性:

    1)标识名:the name of the queue

    2durabletrue if we are declaring a durable queue (the queue will survive a server restart)

    3exclusivetrue if we are declaring an exclusive queue (restricted to this connection)

    4autoDeletetrue if we are declaring an autodelete queue (server will delete it when no longer in use)

    5)其他参数

    6)线程安全,但不提倡共享:Channel instances are safe for use by multiple threads. Requests into a Channel are serialized, with only one thread being able to run a command on the Channel at a time. Even so, applications should prefer using a Channel per thread instead of sharing the same Channel across multiple threads.

    Connection channelManagechannelManagemapchannelNchannelN里面是使用socket tcp层与rmq通信发送通信帧,阻塞的。

    Channel里的方法都加synchronized

    行为:

    1basicPulishpublish a message

    exchange the exchange to publish the message to

    routingKey the routing key

    props other properties for the message - routing headers etc

    body the message body

    2basicConsumeStart a non-nolocal, non-exclusive consumer, with a server-generated consumerTag.

    queue the name of the queue

    autoAck true if the server should consider messages acknowledged once delivered; false if the server should expect explicit acknowledgements

    callback an interface to the consumer object

    3basicQosRequest a specific prefetchCount "quality of service" settings for this channel

      每次给一个customer <=n个消息,一般搭配显示ack

     

    Exchanger

    An exchange receives messages from producers and pushes them to queues.

    The exchange must know exactly what to do with a message it receives.

    Should it be appended to a particular queue? Should it be appended to many queues?

    Or should it get discarded.

    The rules for that are defined by the exchange type.

     

    属性:

    1)标识名:

    2)类型:

     

    类型:

    1directa message goes to the queues whose binding key exactly matches the routing key of the message.

    2topica message sent with a particular routing key will be delivered to all the queues that are bound with a matching binding key.

    * (star) can substitute for exactly one word.

    # (hash) can substitute for zero or more words.

     

    3headers

    4fanoutbroadcasts all the messages it receives to all the queues it knows

     

    默认已有的exchangesrabbitmqctl list exchanges

    Amq.direct

    Direct

    没有指定exchange时,默认使用的exchange

    Amq.fanout

    Fanout

     

    Amq.headers

    Headers

     

    Amq.match

    Headers

     

    Amq.rabbitmq.log

    Topic

     

    Amq.rabbitmq.trace

    Topic

     

    Amq.topic

    topic

     

     

    Queue

    特点:

    1)无界:not bound by any limits

    2)幂等:only be created if it doesn't exist already  [幂等性是指一次和多次请求某一个资源应该具有同样的副作用]

    3)消息存放格式:byte array

    4)使用完需要关闭

    5RabbitMQ doesn't allow redefine an existing queue with different parameters and will return an error to any program that tries to do that.

    6)临时队列

    In the Java client, when we supply no parameters to queueDeclare() we create a non-durable, exclusive, autodelete queue with a generated nameString queueName = channel.queueDeclare().getQueue();

    At that point queueName contains a random queue name. For example it may look likeamq.gen-JzTY20BRgKO-HjmUJj0wLg.

     

    绑定Bindings

    need to tell the exchange to send messages to our queue.

    That relationship between exchange and a queue is called a binding.

    显示目前的bingdingsrabbitmqctl list_bindings

     

     

    属性:

    1 bindingKey must be a list of words, delimited by dots. up to the limit of 255 bytes

     

    规则:

    1The messages will be lost if no queue is bound to the exchange yet.if no consumer is listening yet we can safely discard the message.

    2It is perfectly legal to bind multiple queues with the same binding key.

     

     

    Consumer

    QueueingConsumer
    1buffer the messages pushed to us by the server.
    2)是[a callback in the form of an object] that will buffer the messages until we're ready to use them
    3an implementation of Consumer with straightforward blocking semantics.阻塞的,nextDelivery是阻塞的
     
    QueueingConsumer.Delivery
    Encapsulates an arbitrary message - simple "bean" holder structure.
    有:
    1body
    2envelope
    deliveryTag - the delivery tag
    redeliver - true if this is a redelivery following a failed ack
    exchange - the exchange used for the current operation
    routingKey - the associated routing key
    3properties
     
    4)用户标识:When calling the API methods relating to Consumers, individual subscriptions are always referred to by their consumer tags. Distinct Consumers on the same Channel must have distinct consumer tags.
     
    The easiest way to implement a Consumer is to subclass the convenience class DefaultConsumer. An object of this subclass can be passed on a basicConsume call to set up the subscription:
    boolean autoAck = false;
    channel.basicConsume(queueName, autoAck, "myConsumerTag",
         new DefaultConsumer(channel) {
             @Override
             public void handleDelivery(String consumerTag,
                                        Envelope envelope,
                                        AMQP.BasicProperties properties,
                                        byte[] body)
                 throws IOException
             {
                 String routingKey = envelope.getRoutingKey();
                 String contentType = properties.contentType;
                 long deliveryTag = envelope.getDeliveryTag();
                 // (process the message components here ...)
                 channel.basicAck(deliveryTag, false);
             }
         });
    most conveniently done in the handleDelivery method, as illustrated.
     handleShutdownSignal is called when channels and connections close,
    handleConsumeOk is passed the consumer tag before any other callbacks to that Consumer are called.
     handleCancelOk \ handleCancel methods to be notified of explicit and implicit cancellations, respectively.
    You can explicitly cancel a particular Consumer with  channel.basicCancel(consumerTag);
    Callbacks to Consumers are dispatched on a thread separate from the thread managed by the Connection. This means that Consumers can safely call blocking methods on the Connection or Channel, such as queueDeclare, txCommit, basicCancel or basicPublish.
    Each Channel has its own dispatch thread. For the most common use case of one Consumer per Channel, this means Consumers do not hold up other Consumers. If you have multiple Consumers per Channel be aware that a long-running Consumer may hold up dispatch of callbacks to other Consumers on that Channel.
     
    Consumer不能在同一个channel上同时定义一个queue和订阅另一个queue
     
     Message

    Appid

     

    classId

     

    className

     

    clusterId

     

    contentEncoding

     

    ContentType

    Used to describe the mime-type of the encoding.

    correlationId

    Useful to correlate RPC responses with requests

    is set to a unique value for every request

    deliveryMode

    Marks a message as persistent (with a value of 2) or transient (any other value)

    Expiration

     

    heades

     

    messageId

     

    Priority

     

    replyTo

    Commonly used to name a callback queue

    timestamp

     

    Type

     

    userId

     

     

     

    Routing_key

     

    Immediate

    不能立刻投递到哦消费者,返回失败

    Mandatory

    不能路由到队列,返回失败

     

     

    MessageProperties

     

    Content-type

    deliveryMode

    Priority

    BASIC

    Application/octet-stream

    1:nonpersistent

    0

    MINIMAL_BASIC

     

     

     

    MINIMAL_PERSISTENT_BASIC

     

    2:persistent

     

    PERSISTENT_BASIC

    Application/octet-stream

    2:persistent

    0

    PERSISTENT_TEXT_PLAIN

    Text/plain

    2:persistent

    0

    TEXT_PLAIN

    Text/plain

    1:nonpersistent

    0

     

    vhost 

     

    机制

    线程相关

    Consumer threads  are automatically allocated in a new ExecutorService thread pool by default.

     

    Callbacks to Consumers are dispatched on a thread separate from the thread managed by the Connection. This means that Consumers can safely call blocking methods on the Connection or Channel, such as queueDeclare, txCommit, basicCancel or basicPublish.

     

    Each Channel has its own dispatch thread. For the most common use case of one Consumer per Channel, this means Consumers do not hold up other Consumers. If you have multiple Consumers per Channel be aware that a long-running Consumer may hold up dispatch of callbacks to other Consumers on that Channel.

     

     

    轮询调度

    默认地RabbitMQ will send each message to the next consumer, in sequence. On average every consumer will get the same number of messages. This way of distributing messages is called round-robin.

     

    Message acknowledgment

    An ack(nowledgement) is sent back from the consumer to tell RabbitMQ that a particular message has been received, processed and that RabbitMQ is free to delete it.

     

    If a consumer dies without sending an ack, RabbitMQ will understand that a message wasn't processed fully and will redeliver it to another consumer. That way you can be sure that no message is lost, even if the workers occasionally die.

     

    There aren't any message timeouts; RabbitMQ will redeliver the message only when the worker connection dies. It's fine even if processing a message takes a very, very long time.

     

    Message acknowledgments are turned on by default. In previous examples we explicitly turned them off via the autoAck=true flag. It's time to remove this flag and send a proper acknowledgment from the worker, once we're done with a task.

  • Message durability

    When RabbitMQ quits or crashes it will forget the queues and messages unless you tell it not to. Two things are required to make sure that messages aren't lost: we need to mark both the queue and messages as durable.

     

    Exchange

    Queue

    Route

    Runtime_parameters

    User

    User_permission

    Vhost

     

    RabbitMQ支持消息的持久化,也就是数据写在磁盘上。消息队列持久化包括3个部分:
    1exchange持久化,在声明时指定durable => 1
    2queue持久化,在声明时指定durable => 1
    3)消息持久化,在投递时指定delivery_mode => 21是非持久化)

    如果exchangequeue都是持久化的,那么它们之间的binding也是持久化的。如果exchangequeue两者之间有一个持久化,一个非持久化,就不允许建立绑定。

     

     

     

     

    启动时的日志

    ${node}.log中记录

    Starting RabbitMQ 3.1.3 on Erlang R16B01

    Copyright (C) 2007-2013 VMware, Inc.

    Licensed under the MPL.  See http://www.rabbitmq.com/

    node

    rabbit@LBDZ-02201559

     

    home dir

    C:\WINDOWS

     

    config file(s)

    (none)

     

    cookie hash

    EN9Dcl/uRBFsY0r2iJhaQQ==

     

    log

    ~/Application Data/RabbitMQ/log/${node}.log

     

    sasl log

    ~/Application Data/RabbitMQ/log/${node}-sasl.log

     

    database dir

    ~/Application Data/RabbitMQ/log/${node}-mnesia

     

    Limiting to approx 8092 file handles (7280 sockets)

     

    Only 2048MB of 3071MB memory usable due to limited address space.

     

    Memory limit set to 819MB of 3071MB total.

     

    Disk free limit set to 1000MB

    如果没有达到1G,则refusing to accept messages。参数:disk_free_limit

    Adding vhost '/'

     

    Creating user 'guest'

     

    Setting user tags for user 'guest' to [administrator]

     

    Setting permissions for 'guest' in '/' to '.*', '.*', '.*'

     

    msg_store_transient: using rabbit_msg_store_ets_index to provide index

     

    msg_store_persistent: using rabbit_msg_store_ets_index to provide index

     

    msg_store_persistent: rebuilding indices from scratch

     

    started TCP Listener on 0.0.0.0:5672

     

    Server startup complete; 0 plugins started.

     

     

  • 大小: 12.9 KB
  • 大小: 36.1 KB
分享到:
评论

相关推荐

    RabbitMQ-HTTP API 接口列表

    这资料适用于学习,希望对大家的学习有点帮助。

    rabbitmq配置文件 rabbitmq.config

    rabbitmq配置文件,用于rabbitmq管理

    RabbitMQ API文档

    RabbitMQ 3.5.6是其一个稳定版本,这个版本的API文档对于开发者来说是至关重要的资源,可以帮助他们有效地利用RabbitMQ进行应用程序的开发。 首先,我们要理解AMQP协议。AMQP是一种异步消息传递协议,它的设计目标...

    Django+celery+rabbitmq配置文档

    ### Django+Celery+RabbitMQ配置文档 #### 一、环境搭建与配置 ##### 1.1 系统环境 - **操作系统**: Ubuntu 14.04 - **开发工具**: PyCharm 5.0 - **虚拟环境**: 使用虚拟环境隔离项目依赖,避免环境冲突。 #####...

    rabbitmq安装配置部署文档

    rabbitmq安装配置部署文档 RabbitMQ是一种流行的消息队列服务器,广泛应用于各种分布式系统中。在本文档中,我们将详细介绍RabbitMQ的安装、配置和部署步骤。 一、RabbitMQ安装 在安装RabbitMQ之前,需要先安装...

    Rabbitmq 默认配置文件模板

    **RabbitMQ 默认配置文件模板详解** RabbitMQ是一款开源的消息队列系统,基于AMQP(Advanced Message Queuing Protocol)协议实现,广泛应用于分布式系统中,用于解耦应用程序,提高系统的可扩展性和容错性。在...

    获取Rabbitmq的httpApi.rar

    在使用RabbitMQ的HTTP API时,务必查阅官方文档以获取最新的API规范和安全注意事项。 总结来说,通过C#调用RabbitMQ的HTTP API,我们可以轻松地进行监控、管理和操作RabbitMQ服务器的资源。这包括但不限于获取队列...

    rabbitmq对外http api调用demo

    包含通过http方式调用rabbitmq对外接口,如查看队列的有效性、获取交换机等信息 包含通过http方式调用rabbitmq对外接口,如查看队列的有效性、获取交换机等信息 包含通过http方式调用rabbitmq对外接口,如查看队列的...

    RabbitMQ API

    RabbitMQ API RabbitMQ API

    rabbitmq 3.9.3 配置文件

    rabbitmq 3.9.3 配置文件

    rabbitMQ配置笔记

    **RabbitMQ配置详解** RabbitMQ是一款基于AMQP(Advanced Message Queuing Protocol)协议的开源消息中间件,被广泛应用于分布式系统中的消息传递。它提供了高可用性、可靠性和可扩展性,使得应用程序能够通过解耦...

    RabbitMQ快速入门及API介绍(401M)

    RabbitMQ快速入门及API介绍(401M) QQ截图 20191220230107.png?x-oss-process=style/pnp8 (42.73KB, 下载次数:227) 下载附件 2019-12-2023 :01 上传【课程介绍】:第一章 : RabbitMQ介绍:消息中间件概念、RabbitMQ...

    rabbitmq.pptx(官方文档)

    - 当通过包管理器安装的版本较低或缺少某些功能时,可以考虑从官方网站下载最新版本。 - 访问官方文档获取安装指南: [http://www.rabbitmq.com/install-generic-unix.html]...

    rabbitMQ的api及规范说明书.doc

    【RabbitMQ API及规范说明书】 RabbitMQ是一款基于AMQP(Advanced Message Queuing Protocol)的应用,它是一个开放源代码的消息代理和队列服务器,用于在分布式系统中进行消息传递。RabbitMQ由Erlang编程语言开发...

    RabbitMQ安装文档

    ### RabbitMQ 安装与配置知识点详解 #### 一、消息队列(MQ)概念解析 消息队列(Message Queue, MQ)是一种应用间通信的方法,它允许应用通过发送消息来进行异步通信,而不必直接相互调用。消息队列中的消息可以被一...

    RabbitMQ技术帮助文档

    ### RabbitMQ 技术帮助文档知识点详解 #### 一、RabbitMQ 概述 RabbitMQ 是一种基于 AMQP(高级消息队列协议)的消息中间件,它提供了一个健壮的消息传递系统,用于在分布式系统中处理消息的发布、订阅和路由。...

    rabbitmq部署包及部署文档

    2. **下载与安装**:从RabbitMQ官网获取最新版本的RabbitMQ服务器软件包,然后按照官方指南进行安装。 3. **启动与停止服务**:安装完成后,可以通过命令行工具启动和停止RabbitMQ服务。 4. **管理控制台**:...

    RabbitMQ配置及其使用(java)

    1. 引言 在软件开发中,消息队列(Message Queue,MQ)扮演着重要的角色,它通过引入异步处理机制,提升了系统的响应速度和整体吞吐量。...正确配置和使用RabbitMQ,能够有效优化系统架构,提高系统的稳定性和效率。

    RabbitMQ中文文档.pdf

    RabbitMQ中文文档 RabbitMQ是一个消息代理,它可以为应用程序提供一个通用的消息发送和接收平台,并且保证消息在传输过程中的安全。RabbitMQ提供了多种技术可以让你在性能和可靠性之间进行权衡。这些技术包括持久性...

Global site tag (gtag.js) - Google Analytics