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

长春建设工程信息网站网站开发工程师要求

长春建设工程信息网站,网站开发工程师要求,网站搜索系统,如何做网校网站文章目录 1、MaxwellListener2、MxwObject1. 使用Maxwell捕获MySQL变更2. 将Maxwell的输出连接到消息系统3. 从消息系统读取数据并同步到Redis注意事项 1、MaxwellListener package com.atguigu.tingshu.album.listener;import com.alibaba.fastjson.JSON; import org.apache.…

文章目录

  • 1、MaxwellListener
  • 2、MxwObject
      • 1. 使用Maxwell捕获MySQL变更
      • 2. 将Maxwell的输出连接到消息系统
      • 3. 从消息系统读取数据并同步到Redis
      • 注意事项

1、MaxwellListener

package com.atguigu.tingshu.album.listener;import com.alibaba.fastjson.JSON;
import org.apache.commons.lang3.StringUtils;
import org.springframework.kafka.annotation.KafkaListener;
import org.springframework.stereotype.Component;@Component
public class MaxwellListener {@KafkaListener(topics = "maxwell")public void syncData(String json){if (StringUtils.isBlank(json)){return;}// 反序列化MxwObject mxwObject = JSON.parseObject(json, MxwObject.class);// TODO:一大堆判断 同步数据到redis或者es}
}

2、MxwObject

{"database": "tingshu_album","table": "base_category1","type": "delete","ts": 1726744396,"xid": 11623,"commit": true,"data": {"id": 17,"name": "xxx","order_num": 0,"create_time": "2024-09-19 11:06:10","update_time": "2024-09-19 11:09:51","is_deleted": 0}
}
package com.atguigu.tingshu.album.listener;import lombok.Data;@Data
public class MxwObject {private String database;private String table;private String type;private String data; // json字符串 根据Database和table决定反序列化为什么类型
}

在这里插入图片描述
Maxwell 是一个用于MySQL数据库变更数据捕获Change Data Capture,简称CDC)的工具,它可以将MySQL的binlog事件转换成JSON格式,并发送到消息系统中,如Kafka、RabbitMQ等。虽然Maxwell本身不直接支持将数据同步到Redis,但你可以通过一些方法间接实现这一功能。以下是一个基本的实现思路:

1. 使用Maxwell捕获MySQL变更

首先,确保你已经正确安装并配置了Maxwell。Maxwell通过读取MySQL的binlog来捕获数据变更。你需要在MySQL服务器上配置binlog,并确保Maxwell有权限读取这些日志。

2. 将Maxwell的输出连接到消息系统

Maxwell可以将捕获的变更事件发送到消息队列系统,如Kafka。你需要在Maxwell的配置文件中指定输出目标为消息队列。例如,配置为Kafka的示例配置片段如下:

{"output": "kafka","kafka": {"brokers": "localhost:9092","producer_topic": "maxwell"}
}

3. 从消息系统读取数据并同步到Redis

接下来,你需要一个消费者程序来监听消息队列(如Kafka),读取Maxwell发送的变更事件,并将这些事件同步到Redis。这个消费者程序可以用Java编写,使用相应的消息队列客户端库(如Kafka的Java客户端)来读取消息,并使用Jedis或Lettuce等Redis客户端库来与Redis交互。

以下是一个简化的Java伪代码示例,说明如何实现这个过程:

import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import io.lettuce.core.RedisClient;
import io.lettuce.core.api.StatefulRedisConnection;
import io.lettuce.core.api.sync.RedisCommands;public class MaxwellConsumerToRedis {public static void main(String[] args) {// 配置并创建Kafka消费者KafkaConsumer<String, String> consumer = new KafkaConsumer<>(properties);consumer.subscribe(Collections.singletonList("maxwell"));// 创建Redis客户端RedisClient redisClient = RedisClient.create("redis://localhost:6379");StatefulRedisConnection<String, String> connection = redisClient.connect();RedisCommands<String, String> syncCommands = connection.sync();try {while (true) {// 从Kafka读取记录ConsumerRecords<String, String> records = consumer.poll(100);for (ConsumerRecord<String, String> record : records) {// 处理每条记录,例如将变更数据保存到RedisString变更数据 = record.value();// 假设变更数据是JSON格式,并且包含键和值String key = ...; // 从变更数据中提取键String value = ...; // 从变更数据中提取值syncCommands.set(key, value);}}} finally {consumer.close();connection.close();redisClient.shutdown();}}
}

注意事项

  • 确保正确处理异常和错误情况,例如网络问题或消息队列服务不可用。
  • 考虑使用适当的错误处理和重试机制,以确保数据的可靠性。
  • 根据你的需求,可能需要对变更数据进行解析和转换,以适应Redis的数据模型。
  • 在生产环境中,建议使用更健壮的架构设计,例如使用消息队列的消费者组、分区处理等。

通过上述步骤,你可以将Maxwell捕获的MySQL变更数据同步到Redis中。这个过程需要编写和配置一些Java代码,但一旦完成,它将能够实时地将数据库变更反映到Redis中。

http://www.yayakq.cn/news/810335/

相关文章:

  • 做网站要用到哪些技术阿里巴巴官方网站
  • 单页式网站 seowordpress recent posts
  • php网站后台程序网站开发协议书 英文版
  • 河南省监理协会官方网站建设天津定制网站建设商店设计
  • 深圳企业培训百度上做优化
  • 外贸网站优化谷歌关键词排名信用公示信息系统官网
  • 网站商城微信支付宝支付宝支付接口国外服装图案设计网站
  • 求个没封的w站2022wordPress图片查看插件
  • 做视频网站 带宽多少才合适网站建设规划书300字
  • 网站建设加盟模式北京网站设计学习
  • 什么是网站的权重做啥网站好
  • 网站打开慢深圳网站程序开发
  • 安徽网站推广公司注册城乡规划师通过率
  • 如何让网站打不开 解析江苏建设工程有限公司简介
  • 网站建设性能分析推广怎么做
  • 网站平台建设工作汇报做网站哪家网站好
  • 静态企业网站模板网站建设实践考试试题
  • 类似酷家乐做庭院的网站wordpress做个游戏
  • 廊坊网站建设兼职网站如何提升用户体验
  • 做一个付费网站多少钱郑州同济医院妇科怎么样
  • 做网站 长观看床做视频网站
  • 泰和县建设局网站能浏览的海外网站
  • 冷库 东莞网站建设网站制作计划书模板
  • 网站制作与网页设计注册公司和建网站
  • 培训网站方案应用公园免费版下载
  • 网站开发与设计实训实训报告html网站支付链接怎么做的
  • 国际网站哪里做设计说明万能模板100字
  • 成都网站开发公司有哪些百度seo运营工作内容
  • 朝阳市网站制作宁波快速建站公司
  • 济南建设工程业绩公示的网站新郑做网站