RocketMQ配置

来源:互联网 发布:windows whistler2296 编辑:程序博客网 时间:2024/05/18 23:52

1. 客户端的公共配置类:ClientConfig

参数名默认值说明namesrvAddrNameServer 地址列表,多个NameServer地址用分号隔开clientIp本机IP客户端本机IP地址,某些机器会发送无法识别客户端IP地址的情况,需要应用在代码中强制指定instanceNameDEFAULT客户端实例名称,客户端创建的多个Producer,Consumer实际是公用一个内部实例(这个实例包含网络连接,线程资源等)clientCallbackExecutorThreads4通信层异步回调线程数pollNameServerInterval30000轮询NameServer间隔时间,单位毫秒heartbeatBrokerInterval30000向Broker发送心跳间隔时间,单位毫秒persistConsumerOffsetInterval5000持久化Consumer消费进度间隔时间,单位毫秒

2. Producer配置

参数名默认值说明producerGroupDEFAULT_PRODUCERProducer组名,多个Producer如果属于一个应用,发送同样的消息,则应该将他们归为同一组createTopicKeyTBW102在发送消息时,自动创建服务器不存在的topicdefaultTopicQueueNums4在发送消息时,自动创建服务器不存在的topic,默认创建的队列数sendMsgTimeout10000发送消息超时时间,单位毫秒compressMsgBodyOverHowmuch4096消息Body超过多大开始压缩(Consumer收到消息会自动解压缩),单位字节retryAnotherBrokerWhenNotStoreOKFALSE如果发送消息返回sendResult,但是sendStatus!=SEND_OK,是否重试发送maxMessageSize131072客户端限制的消息大小,超过报错,同时服务端也会限制(默认128k)transactionCheckListener 事务消息会查监听器,如果发送事务消息,必须设置checkThreadPoolMinSize1Broker回查Producer事务状态时,线程池大小checkThreadPoolMaxSize1Broker回查Producer事务状态时,线程池大小checkRequestHoldMax2000Broker回查Producer事务状态时,Produceer本地缓冲请求队列大小

3. PushConsumer配置

参数名默认值说明consumerGroupDEFAULT_CONSUMERConsumer组名,多个Consumer如果属于一个应用,订阅同样的消息,且消费逻辑一致,则应将它们归为同一组messageModelCLUSTERING消息模型,支持一下两种:集群消费,广播消费consumerFromWhereConsumer_FROM_LAST_OFFSETConsumer启动后,默认从什么位置开始消费allocateMessageQueueStrategyAllocateMessage QueueAveragelyRebalance算法实现策略subscription{}订阅关系messageListener 消息监听器offsetStore 消费进度存储consumerThreadMin10消费线程池数量consumerThreadMax20消费线程池数量consumeConsurrentlMaxSpan2000单队列并行消费允许的最大跨度pullThresholdForQueue1000拉消息本地队列缓冲消息最大数Pullinterval0拉消息间隔,由于是长轮询,所以为0,但是如果应用了流控,也可以设置大于0的值,单位毫秒consumeMessageBatchMaxSize1批量消费,一次消费多少条消息pullBatchSize32批量拉消息,一次最多拉多少条

4. PullConsumer配置

参数名默认值说明consumerGroup Consumer组名,多个Consumer如果属于一个应用,订阅同样的消息,且消费逻辑一致,则应将它们归为同一组brokerSuspendMaxTimeMills20000长轮询,Consumer拉消息请求在Broker挂起最长时间,单位毫秒consumerPullTimeout10000非长轮询,拉消息超时时间,单位毫秒consumerTimeoutMillisWhenSuspend30000长轮询,Consumer拉消息请求Broker挂起超过指定时间,客户端认为超时,单位毫秒messageModelBROADCASTING消息类型,支持一下两种:集群消费;广播模式messageQueueListener 监听队列变化offsetStore 消费进度存储registerTopics 注册的topic集合allocateMessageQueueStrategyRebalance 算法实现策略
  1. Broker参数配置
参数名默认值说明listenPort10911Broker对外服务的监听端口namesrvAddrNullNameServer地址brokerIP1本机IP本机ip地址,默认系统自动识别,但是某些多网卡机器会存在识别错误的情况,这种情况下可以人工配置brokerName 本机主机名brokerClusterNameDefaultClusterBroker所属那个集群brokerId0BrokerId,必须是大于等于0的整数,0表示Master, 大于0表示Slave, 一个Master可以挂多个Slave,Master和Slave通过BrokerName来配对storePathCommitLog$HOME/store/commitlogcommitLog存储路径storePathConsumerQueue$HOME/store/consumequeue消费队列存储路径storePathIndex$HOME/store/index消息索引存储队列deleteWhen4删除时间点,默认凌晨4点fileReserverdTime48文件保留时间,默认48小时maxTransferBytesOnMessageInMemory262144单次pull消息(内存)传输的最大字节数maxTransferCountOnMessageInMemory32单次pull消息(内存)传输的最大条数maxTransferBytesOnMessageInDisk65535单次Pull消息(磁盘)传输的最大字节数maxTransferCountOnMessageInDisk8单次pull消息(磁盘)传输的最大条数messageIndexEnableTRUE是否开启消息索引功能messageIndexSafeFALSE是否提供安全的消息索引机制,索引保证不丢brokerRoleASYNC_MASTERBroker的角色:ASYNC_MASTER异步复制Master; SYNC_MASTER同步双写MASTER; SLAVEflushDiskTypeASYNC_FLUSH刷盘方式: ASYNC_FLUSH异步刷盘;SYNC_FLUSH同步刷盘clientFileForciblyEnable
原创粉丝点击