五种消息模型简单说明

五种消息模型简单说明

RabbitMQ提供了6种消息模型,但是第6种其实是RPC,并不是MQ,因此不予学习。那么也就剩下5种。但是其实3、4、5这三种都属于订阅模型,只不过进行路由的方式不同。

 我们通过一个demo工程来了解下RabbitMQ的工作方式,导入工程:

 依赖:

java 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.atguigu.rabbitmq</groupId>
    <artifactId>rabbitmq-demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.9.RELEASE</version>
    </parent>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.3.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
    </dependencies>
</project>

 我们抽取一个建立RabbitMQ连接的工具类,方便其他程序获取连接:

java 复制代码
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.Connection;
import java.io.IOException;
public class ConnectionUtil {
    /**
     * 建立与RabbitMQ的连接
     */
    public static Connection getConnection() throws Exception {
        //定义连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        //设置服务地址
        factory.setHost("192.168.137.137");
        //端口
        factory.setPort(5672);
        //设置账号信息,用户名、密码、vhost
        factory.setVirtualHost("/shopping");
        factory.setUsername("zhangsan");
        factory.setPassword("123456");
        // 通过工程获取连接
        Connection connection = factory.newConnection();
        return connection;
    }
    public static void main(String[] args) throws Exception {
        Connection con = ConnectionUtil.getConnection();
        System.out.println(con);
        con.close();
    }
}
相关推荐
2501_941664961 天前
Go高性能日志收集与分布式处理实战分享:大规模日志分析与系统优化经验
rabbitmq
2501_941143731 天前
数字化转型与云计算:未来企业发展的关键驱动力
rabbitmq
2501_941146701 天前
从边缘计算到云计算:未来数字化架构的演变与挑战
rabbitmq
2501_941142931 天前
物联网与边缘计算在高并发互联网系统中的架构优化与工程实践经验分享
rabbitmq
2501_941142931 天前
网络安全与高并发防护架构在互联网系统中的设计优化与工程实践经验分享
rabbitmq
2501_941143731 天前
基于 Node.js 与 TypeScript 构建高并发微服务与实时协作系统实践分享
rabbitmq
2501_941881401 天前
分布式数据库水平扩展与高可用架构在互联网大规模业务系统优化实践经验分享总结
rabbitmq
2501_941144031 天前
基于 Kotlin 与 Spring Boot 构建高并发企业级微服务系统的架构实践分享
rabbitmq
2501_941089191 天前
自动驾驶场景下基于 C++ 构建高性能多传感器融合与实时决策系统的架构设计与工程实践分享
rabbitmq
2501_941800881 天前
区块链与互联网:重塑信任、去中心化的数字时代
rabbitmq