rocketmq console控制台Q&A

q:为什么主备昨天的统计数据不一致?


clipboard.png

A:获取昨天的统计数据是一个定时任务。每天零点执行。两台机器的执行不可能极其一致,总会差一点。

org/apache/rocketmq/broker/BrokerController.java:257

final long initialDelay = UtilAll.computNextMorningTimeMillis() - System.currentTimeMillis();

final long period = 1000 * 60 * 60 * 24;

this.scheduledExecutorService.scheduleAtFixedRate(new Runnable() {

@Override

public void run() {

try {

BrokerController.this.getBrokerStats().record();

} catch (Throwable e) {

log.error("schedule record error.", e);

}

}

}, initialDelay, period, TimeUnit.MILLISECONDS);

Q,这个图的tps表示什么?和cluster页面的tps为什么对不上?

clipboard.png

org/apache/rocketmq/store/stats/BrokerStats.java:40

public void record() {

this.msgPutTotalYesterdayMorning = this.msgPutTotalTodayMorning;

this.msgGetTotalYesterdayMorning = this.msgGetTotalTodayMorning;

this.msgPutTotalTodayMorning =

this.defaultMessageStore.getStoreStatsService().getPutMessageTimesTotal();

this.msgGetTotalTodayMorning =

this.defaultMessageStore.getStoreStatsService().getGetMessageTransferedMsgCount().get();

log.info("yesterday put message total: {}", msgPutTotalTodayMorning - msgPutTotalYesterdayMorning);

log.info("yesterday get message total: {}", msgGetTotalTodayMorning - msgGetTotalYesterdayMorning);

}

./mqadmin brokerStatus -b ip:port

[rocketmq@hrmq01 bin]$ ./mqadmin brokerStatus -b 10.138.225.31:10922

Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=128m; support was removed in 8.0

Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=128m; support was removed in 8.0

bootTimestamp : 1512464004666

brokerVersion : 232

brokerVersionDesc : V4_1_0_SNAPSHOT

commitLogDirCapacity : Total : 777.7 GiB, Free : 654.3 GiB.

commitLogDiskRatio : 0.15872792096573887

commitLogMaxOffset : 497108611246

commitLogMinOffset : 367219703808

consumeQueueDiskRatio : 0.15872792096573887

dispatchBehindBytes : 0

dispatchMaxBuffer : 0

earliestMessageTimeStamp : 1512159654174

getFoundTps : 416.35836416358364 413.23223064744604 401.3675276346905

getMessageEntireTimeMax : 62

getMissTps : 158.7841215878412 152.12065661194902 143.54373971979516

getTotalTps : 575.1424857514248 565.3528872593951 544.9112673544856

getTransferedTps : 2447.4552544745525 2435.2970585784515 2427.7681769020146

msgGetTotalTodayMorning : 19869118

msgGetTotalTodayNow : 64490048

msgGetTotalYesterdayMorning : 0

msgPutTotalTodayMorning : 19665538

msgPutTotalTodayNow : 63615258

msgPutTotalYesterdayMorning : 0

pageCacheLockTimeMills : 0

pullThreadPoolQueueCapacity : 100000

pullThreadPoolQueueHeadWaitTimeMills: 0

pullThreadPoolQueueSize : 0

putMessageAverageSize : 1723.2784922761768

putMessageDistributeTime : [<=0ms]:21325 [0~10ms]:11891 [10~50ms]:100 [50~100ms]:0 [100~200ms]:0 [200~500ms]:0 [500ms~1s]:0 [1~2s]:0 [2~3s]:0 [3~4s]:0 [4~5s]:0 [5~10s]:0 [10s~]:0

putMessageEntireTimeMax : 4136

putMessageSizeTotal : 109626805892

putMessageTimesTotal : 63615258

putTps : 1120.18798120188 1151.6040329972504 1381.3062338662237

remainHowManyDataToFlush : 5.5 KiB

remainTransientStoreBufferNumbs : 2147483647

runtime : [ 0 days, 21 hours, 51 minutes, 38 seconds ]

sendThreadPoolQueueCapacity : 10000

sendThreadPoolQueueHeadWaitTimeMills: 0

sendThreadPoolQueueSize : 0

startAcceptSendRequestTimeStamp : 0

其中这个趋势图,反应的是getTotalTps。

后面的值分别代表 10秒钟,1分钟,10分钟的tps

TotalTps = FoundTps + MissTps

FoundTps和MissTps是由getMessageTimesTotalFound和getMessageTimesTotalMiss计算而来。

getMessageTimesTotalFound和getMessageTimesTotalMiss是原子变量,用来计数,

在com.alibaba.rocketmq.store.DefaultMessageStore#getMessage方法中,找到则Found+1,

否则Miss+1。

StoreStatsService是内部统计服务类 ,这些数值的统计都在这里。

是一个线程类。

public void run() {

log.info(this.getServiceName() + " service started");

while (!this.isStoped()) {

try {

this.waitForRunning(FrequencyOfSampling);

this.sampling();

this.printTps();

}

catch (Exception e) {

log.warn(this.getServiceName() + " service has exception. ", e);

}

}

log.info(this.getServiceName() + " service end");

}

FrequencyOfSampling值是1000ms。相当于一个定时任务。每秒采样一次。

关于waitForRunning方法的实现,

有兴趣的可以看源码深入研究,不跑题了,看采样方法。

this.getTimesFoundList.add(new CallSnapshot(System.currentTimeMillis(),

this.getMessageTimesTotalFound.get()));

if (this.getTimesFoundList.size() > (MAX_RECORDS_OF_SAMPLING + 1)) {

this.getTimesFoundList.removeFirst();

}

就是将次数和时间戳构造一个对象,加到list中。只存600条(10分钟),超时的,从头删除。

private String getGetFoundTps(int time) {

String result = "";

this.lockSampling.lock();

try {

CallSnapshot last = this.getTimesFoundList.getLast();

if (this.getTimesFoundList.size() > time) {

CallSnapshot lastBefore =

this.getTimesFoundList.get(this.getTimesFoundList.size() - (time + 1));

result += CallSnapshot.getTPS(lastBefore, last);

}

} finally {

this.lockSampling.unlock();

}

return result;

}

也比较容易看懂,就是拿到最新的snapshot,和要查询的时间段之前的那个snapshot做一下差值。

所以,回答下问题,这个趋势图表示pull消息的tps。

cluster页面取的两个值是putTps和getTransferedTps

因为每一次pull都是批量拉取消息。一次成功的pull将FoundTps +1。否则MissTps+1。

而getTransferedTps是每一条消息,都会+1。

代码见com.alibaba.rocketmq.store.DefaultMessageStore#getMessage

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容