前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RocketMQ一次消费性能问题排查【实战笔记】

RocketMQ一次消费性能问题排查【实战笔记】

作者头像
瓜农老梁
发布2020-03-12 18:39:41
9290
发布2020-03-12 18:39:41
举报
文章被收录于专栏:瓜农老梁瓜农老梁

目录

代码语言:javascript
复制
一、需求描述
二、问题分析
    1.tcpdump网络情况
    2.查看消费线程堆栈
    3.消费代码定位
三、后记
一、需求描述

在容器推广中,为了测试容器的性能,需要消息SDK与ECS上在发送和消费的性能对比;在对比消费性能时,发现容器中的消费性能居然是ECS的2倍。容器并发消费的20个线程TPS在3万左右,ECS中20个消费线程TPS在1.5万左右。

问题:配置均采用8C16G,容器中的性能几乎是ECS的两倍,这不科学,事出反常必有妖。

二、问题分析
1.tcpdump网络情况

tcpdump显示在消费的机器存在频繁的域名解析过程;10.x.x.185向DNS服务器100.x.x.136.domain和10.x.x.138.domain请求解析。而10.x.x.185这台机器又是消息发送者的机器IP,测试的发送和消费分别部署在两台机器上。

问题:消费时为何会有消息发送方的IP呢?而且该IP还不断进行域名解析。

2.查看消费线程堆栈
3.消费代码定位

在消费时有通过MessageExt.bornHost.getBornHostNameString获取消费这信息;问题由此引起。

代码语言:javascript
复制
public class MessageExt extends Message {
    private static final long serialVersionUID = 5720810158625748049L;
    private int queueId;
    private int storeSize;
    private long queueOffset;
    private int sysFlag;
    private long bornTimestamp;
    private SocketAddress bornHost;
    private long storeTimestamp;
    private SocketAddress storeHost;
    private String msgId;
    private long commitLogOffset;
    private int bodyCRC;
    private int reconsumeTimes;
    private long preparedTransactionOffset;
}

调用GetBornHostNameString获取HostName时会根据IP反查DNS服务器;

代码语言:javascript
复制
InetSocketAddress inetSocketAddress = (InetSocketAddress)this.bornHost;
return inetSocketAddress.getAddress().getHostName();
三、后记

将getBornHostNameString注释或者直接返回IP,ECS的消费性能基本稳定在3万左右。

备注:感谢公司测试同学魏华和容器专家陶汉辉对性能一遍又一遍的测试和排查。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-03-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 瓜农老梁 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、需求描述
  • 二、问题分析
  • 1.tcpdump网络情况
  • 2.查看消费线程堆栈
  • 3.消费代码定位
  • 三、后记
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档