学习路线:
这个方向初期比较容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就会越来越多以下是网络渗透需要学习的内容:
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
13.1 幂等简介
幂等性:用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用,例如用户在下订单时,由于网络卡顿等原因多次点击下单按钮,但最终订单只生成了一个,并不会多次下订单;
消息幂等性:即消息无论被发送多少次,最终只会消费一次。保证消息不会重复被消费多次;
13.1.1 方案
实现消息的幂等性通常有两种方案来解决:全局消息ID、Redis标识,两种方案从原理上讲都是一样的;
- 全局消息ID:发送消息时给消息分配一个全局ID,每次消费消息时判断该ID是否存在过,如果存在过则已经消费过,如果不存在则说明是第一次消费;
- Redis标识:发送消息时,给消息分配一个全局的唯一ID,消费消息时,将id与消息以K-V的形式写入Redis
<id,meessage>
,如果能写入成功代表第一次消费消息,如果写入不成功代表消费已经被消费过了
13.1.2 解决消息幂等性
搭建SpringBoot整合RabbitMQ工程
我们采用的是Redis的setnx命令来解决消息幂等性问题;
application.yml:
spring:
rabbitmq:
host: 192.168.133.151
port: 5672
username: guest
password: guest
virtual-host: /
redis:
host: 127.0.0.1
启动类:
package com.lscl.rabbitmq;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.QueueBuilder;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class);
}
@Bean
public RedisTemplate redisTemplate(RedisTemplate redisTemplate){
// value可见
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
// key可见
redisTemplate.setKeySerializer(new StringRedisSerializer());
return redisTemplate;
}
// 定义测试队列
@Bean
public Queue testQueue(){
return QueueBuilder.durable("test\_queue").build();
}
}
监听器:
package com.lscl.rabbitmq.listener;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
@Component
public class TestListener {
@Autowired
private RedisTemplate redisTemplate;
@RabbitListener(queues = "test\_queue")
public void test\_queue\_confirm(Message message) {
String messageId = message.getMessageProperties().getMessageId();
if (null == messageId) {
System.out.println("消息id为null!");
return;
## 学习路线:
这个方向初期比较容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就会越来越多以下是网络渗透需要学习的内容:
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/bdd2c08a12003b634bcf3aaff78d9f11.png#pic_center)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**