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

温州做高端网站公司排名dw如何在网站做弹窗

温州做高端网站公司排名,dw如何在网站做弹窗,广水做网站,网站建设实践总结背景 对几十万条用户历史存量数据写入,且存在大对象的基础上。kafka消费进行消费写mysql超时。导致上游服务调用时异常,CPU飙高异常。 大对象解释 大对象的定义与危害 1. 什么是大对象? JVM 内存分配机制:Java 中对象优先分配…

背景

对几十万条用户历史存量数据写入,且存在大对象的基础上。kafka消费进行消费写mysql超时。导致上游服务调用时异常,CPU飙高异常。

大对象解释

大对象的定义与危害

1. 什么是大对象?
  • JVM 内存分配机制:Java 中对象优先分配在 Eden 区,但单个对象超过 -XX:PretenureSizeThreshold 阈值(默认与类型相关)时,会直接进入老年代。

  • 典型场景

    • 超大数组/集合(如 byte[10MB]List 存储万级元素)

    • 未分页的数据库查询结果(一次性加载百万行数据)

    • 缓存滥用(缓存未压缩的图片/文件)

    • 未及时释放的流处理数据(如未关闭的 InputStream

2. 大对象如何引发 CPU 飙升?
  • GC 压力

    • 频繁 Full GC:老年代被大对象快速填满,触发 STW 的 Full GC,CPU 资源被垃圾回收线程独占。

    • CMS/G1 并发失败:并发回收期间老年代空间不足,退化为单线程 Full GC,导致长时间停顿。

  • 序列化开销:RPC 调用中,大对象的序列化/反序列化(如 Protobuf、JSON)会显著消耗 CPU。

  • 数据处理瓶颈:遍历或操作大对象(如排序、转换)导致 CPU 密集型计算。

二、大对象问题定位技巧

1. 诊断工具
  • 内存分析

    • jmap -histo:live <pid> 直方图统计对象分布

  • GC 日志

    • -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/path/to/gc.log

    • 关注 Full GC 频率和 OldGen 使用率

三、大对象问题规避策略

1. 架构设计优化
  • 分页/分段处理:

// 错误:一次性查询全量数据
List<User> users = userDao.findAll(); // 正确:分页分批处理
int pageSize = 500;
for (int page = 0; ; page++) {List<User> batch = userDao.findByPage(page, pageSize);if (batch.isEmpty()) break;processBatch(batch);
}
2. 编码规范
  • 避免方法内大对象分配:

// 反例:在频繁调用的方法中创建大数组
public void process() {byte[] buffer = new byte[10 * 1024 * 1024]; // 10MB 临时数组// ...
}// 正例:复用对象或使用对象池
private static final ThreadLocal<ByteBuffer> bufferHolder = ThreadLocal.withInitial(() -> ByteBuffer.allocate(1024));
  • 及时释放资源
3. JVM 调优

Kafka消费者Rebalance机制

一、Kafka消费者机制与问题根源

消费者组(Consumer Group):多个消费者共同消费一个Topic的分区,实现负载均衡。每个分区仅由一个消费者处理。

Rebalance触发条件:

1.消费者加入或离开组(如宕机、主动下线)。

2.消费者超过 max.poll.interval.ms 未发送心跳(默认5分钟)。

问题现象:偏移量(Offset)未提交,消费者被判定为死亡,触发Rebalance,消息重新分配给其他消费者,但新消费者同样无法及时处理,形成恶性循环。

核心配置参数:

max.poll.records:单次Poll拉取的最大消息数(默认500)

max.poll.interval.ms:两次Poll操作的最大允许间隔(默认5分钟)

问题原因:处理500条消息耗时超过5分钟,导致消费者被认为失效,触发Rebalance,消息被重复分配但处理仍超时,最终服务崩溃。

二、处理逻辑与性能瓶颈

数据处理耗时分析

  • 业务逻辑复杂度:每条消息需查询历史数据18万条,涉及复杂计算或多次数据库交互。

  • 数据库写入瓶颈:

单条插入 vs 批量插入:单条插入导致频繁事务提交,效率低下。

索引与锁竞争:写入时索引维护和行锁可能引发性能下降。

  • 代码示例(低效写入):

@KafkaListener(topics = "init_data_topic")
public void handleMessage(List<Message> messages) {for (Message msg : messages) {// 逐条查询18万条历史数据List<HistoryData> data = queryHugeData(msg.getUserId());// 逐条写入MySQLdata.forEach(d -> jdbcTemplate.update("INSERT INTO table ...", d));}
}

资源消耗与CPU飙升

  • GC压力:频繁创建大对象(如18万条数据的List)导致Young GC频繁,最终引发Full GC,CPU被GC线程占用。

  • 线程阻塞:同步写入数据库时,线程因IO等待而阻塞,线程池满载后任务堆积,进一步加剧延迟。

三、排查方向与优化策略

1.Kafka消费者配置调优

2.数据处理逻辑优化

分页查询与批量写入:

将18万条历史数据分页查询,避免一次性加载到内存。

使用MySQL批量插入(INSERT INTO ... VALUES (...), (...)),减少事务开销。

// 分页查询示例
int pageSize = 1000;
for (int page = 0; ; page++) {List<HistoryData> batch = queryByPage(msg.getUserId(), page, pageSize);if (batch.isEmpty()) break;batchInsertToMySQL(batch); // 批量写入
}

总结

总而言之,对于大对象或者数据量过大的数据,每次查和写入的数据量都要严格把控!!单次查询和写入数据量不超过1000!!!!!


文章转载自:

http://ZeDXG6U8.xLxmy.cn
http://WI2zcm4Y.xLxmy.cn
http://8SJod5rG.xLxmy.cn
http://z7DLs4ox.xLxmy.cn
http://M4E4FC8a.xLxmy.cn
http://pRnVwZnD.xLxmy.cn
http://H7n4KONx.xLxmy.cn
http://ESmDOTOx.xLxmy.cn
http://BVhrapQb.xLxmy.cn
http://Niu5wrjy.xLxmy.cn
http://ar4ZacGY.xLxmy.cn
http://rkfZYRQU.xLxmy.cn
http://Afs6x3Pv.xLxmy.cn
http://rFbY8acJ.xLxmy.cn
http://rbYbVMuy.xLxmy.cn
http://2T36pFkj.xLxmy.cn
http://A73PvZSf.xLxmy.cn
http://6AyKnaQm.xLxmy.cn
http://cBBZvX0d.xLxmy.cn
http://xsRRtHSj.xLxmy.cn
http://GQvbZWBi.xLxmy.cn
http://tw98PPCV.xLxmy.cn
http://kv4vknMb.xLxmy.cn
http://r4LOgzj1.xLxmy.cn
http://2opEUy4G.xLxmy.cn
http://sPxEtO9u.xLxmy.cn
http://I3gTXpI2.xLxmy.cn
http://BCQYtefn.xLxmy.cn
http://uHYNHESC.xLxmy.cn
http://S7J27Zan.xLxmy.cn
http://www.dtcms.com/wzjs/701579.html

相关文章:

  • 网站栏目设置中核华泰建设有限公司的网站
  • 中职计算机网站建设教学计划杭州亚太建设监理咨询有限公司中标网站
  • 怎么做公司的中英文网站网络营销推广的优缺点
  • 济南区网站开发花灯彩灯制作公司
  • 关于网站建设的基础知识WordPress 更改H标签
  • 二级域名网站建设哈尔滨建设网站
  • 门户网站集群建设方案微信群发布网站建设
  • 网站推广平台有哪些网站怎么做谷歌权重
  • 如何做网站的统计手机百度一下百度
  • 涿州建设局网站山东网站搭建有限公司
  • 宁波网站设计方案社群营销是什么意思
  • 网站开发模式分为怎么弄视频
  • 东莞知名网站大理石在哪些网站做宣传
  • 如何挑选网站主机昆明微网站搭建
  • 泉州外贸网站开发公司网站怎么做链接跳转
  • 惠州网站建设推广公司wordpress 关键字链接
  • 建站后角度是不是0wordpress怎么关注站点
  • 编程跟做网站山东建站商城
  • 个人信息网站建设的心得体会wordpress 支付下载
  • 网站首页幻灯片不显示返利网站 帐如何做
  • 集团公司网站源码下载aws wordpress 免费
  • 上传网站 php 服务器怎么用html做个人的网页
  • 网站怎么注册做资讯的网站
  • 微信网站怎么做手机网页视频下载神器
  • 一份完整的活动策划合肥seo网站多少钱
  • 叮当网站做app网龙网络公司简介
  • 个人做网站赚钱建设门户网站
  • 装修设计图网站排名商城建站
  • 服务器网站崩溃自己的网站什么做优化
  • 做游戏下载网站赚钱php能区别电脑网站和手机网站吗怎么嵌入到phpcms