TWind 的黑马点评随笔

TWind 的黑马点评随笔

​ 目前是把黑马点评的技术部分完全做完了,不能说吃得饱饱,也算个半饱吧。

​ 黑马点评严格来说不算项目,因为它给的前端过于垃圾,内容又重在Redis,所以称之为Redis练习貌似跟贴切。

​ 尽管如此,这个项目仍然非常适合新手入门,亮点尤其在带你一步步解决抢优惠卷带来的一系列线程问题展开,从表层到深入,非常不错。

​ 但是,对于异步编程,集群,分布式等内容建议还是移步spring cloud,这个是专业的,黑马点评更多注重于Redis的运用(后面的关于签到,位置,推文这些建议还是别看了,这已经脱离了初衷)

​ 后面应该会写一些关于Redis消息队列的文章


坑合集

复制代码
### 坑1

首当其冲的是黑马的构思前端,登录时无法选中阅读协议!!!

解决办法是到nginx里面的前端代码手动修改,把login.html里面的

java 复制代码
login(){
if( ! this.radio){
 this.$message.error("请先确认阅读用户协议!");
 return
}

惊叹号去掉!

坑2

紧随其后的是redis序列化器

你大可直接用黑马视频用的自带的stringRedisTemplate,但是你这样做的话就得在使用Map互转Bean时尽享那一串的构思修复代码

这里建议直接一步到位,用Jackson2JsonRedisSerializer作为所有的序列化反序列化器

java 复制代码
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){
log.info("开始创建redis模板对象...");

ObjectMapper objectMapper = new ObjectMapper();
objectMapper.registerModule(new JavaTimeModule());  // 注册 JavaTimeModule 处理 LocalDateTime
objectMapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);  // 禁用时间戳格式

Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer =
      new Jackson2JsonRedisSerializer<>(Object.class);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);

RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
return redisTemplate;
}

**redisTemplate.setKeySerializer(new StringRedisSerializer());**这里不用jackson的原因是用了key会乱码(虽然不影响就是了)

注意!要用的话要用一套(dubug了好久),redis默认的是string类的序列化器!远古java版本的LocalDateTime有兼容性问题!

坑3

你可能在传参数到Lua脚本时发现Lua接受到的始终为nil,这是因为我们用的是:

java 复制代码
@Autowired
private RedisTemplat redisTemplate;

序列化出了问题:Lua脚本不知道传进去的数据是什么类型!(Redis是知道的但它没给Lua说),得手动指定:

java 复制代码
@Autowired
private RedisTemplate<String,String> redisTemplate;

这样就完美解决

坑4

严格来说不算坑,是自己学艺不精...

同时看到了一篇错误的CSDN博客...

就是

java 复制代码
stringRedisTemplate.opsForStream().read

它对应的是消费者组操作中的XREADGROUP ,是既可以访问消息队列也可以访问pending-list队列的!

取决于其ID

所以stringRedisTemplate.opsForStream().pending的意义在哪呢


总结

完结撒花 🎉 🎉 🎉

接下来就是写几篇博客巩固一下...

相关推荐
菜鸟小九11 分钟前
SSM(MybatisPlus)
java·开发语言·spring boot·后端
不爱编程的小九九13 分钟前
小九源码-springboot051-智能推荐旅游平台
java·spring boot·后端
期待のcode25 分钟前
MyBatis框架—延迟加载与多级缓存
java·数据库·后端·缓存·mybatis
老华带你飞32 分钟前
小区服务|基于Java+vue的小区服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·小区服务管理系统
华仔啊39 分钟前
Spring 配置混乱?搞懂这两个核心组件,问题真能少一半
java·后端·spring
喂完待续1 小时前
【序列晋升】45 Spring Data Elasticsearch 实战:3 个核心方案破解索引管理与复杂查询痛点,告别低效开发
java·后端·spring·big data·spring data·序列晋升
郑重其事,鹏程万里1 小时前
commons-exec
java
龙茶清欢1 小时前
具有实际开发参考意义的 MyBatis-Plus BaseEntity 基类示例
java·spring boot·spring cloud·mybatis
神龙斗士2401 小时前
Java 数组的定义与使用
java·开发语言·数据结构·算法
计算机学姐1 小时前
基于微信小程序的扶贫助农系统【2026最新】
java·vue.js·spring boot·mysql·微信小程序·小程序·mybatis