Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
37cf2a7c
R
Rocketmq
项目概览
Apache RocketMQ
/
Rocketmq
上一次同步 大约 3 年
通知
270
Star
16139
Fork
68
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rocketmq
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
37cf2a7c
编写于
12月 06, 2017
作者:
Y
yukon
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[ROCKETMQ-324] Expose an interface for client to specify the async call back executor
上级
8c303104
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
91 addition
and
1 deletion
+91
-1
client/src/main/java/org/apache/rocketmq/client/impl/producer/DefaultMQProducerImpl.java
.../rocketmq/client/impl/producer/DefaultMQProducerImpl.java
+4
-0
client/src/main/java/org/apache/rocketmq/client/producer/DefaultMQProducer.java
...rg/apache/rocketmq/client/producer/DefaultMQProducer.java
+12
-0
client/src/test/java/org/apache/rocketmq/client/producer/DefaultMQProducerTest.java
...pache/rocketmq/client/producer/DefaultMQProducerTest.java
+19
-0
remoting/src/main/java/org/apache/rocketmq/remoting/RemotingClient.java
...ain/java/org/apache/rocketmq/remoting/RemotingClient.java
+2
-0
remoting/src/main/java/org/apache/rocketmq/remoting/netty/NettyRemotingClient.java
...g/apache/rocketmq/remoting/netty/NettyRemotingClient.java
+11
-1
remoting/src/test/java/org/apache/rocketmq/remoting/netty/NettyRemotingClientTest.java
...ache/rocketmq/remoting/netty/NettyRemotingClientTest.java
+43
-0
未找到文件。
client/src/main/java/org/apache/rocketmq/client/impl/producer/DefaultMQProducerImpl.java
浏览文件 @
37cf2a7c
...
...
@@ -1060,6 +1060,10 @@ public class DefaultMQProducerImpl implements MQProducerInner {
this
.
defaultMQProducer
.
getSendMsgTimeout
());
}
public
void
setCallbackExecutor
(
final
ExecutorService
callbackExecutor
)
{
this
.
mQClientFactory
.
getMQClientAPIImpl
().
getRemotingClient
().
setCallbackExecutor
(
callbackExecutor
);
}
public
SendResult
send
(
Message
msg
,
long
timeout
)
throws
MQClientException
,
RemotingException
,
MQBrokerException
,
InterruptedException
{
return
this
.
sendDefaultImpl
(
msg
,
CommunicationMode
.
SYNC
,
null
,
timeout
);
...
...
client/src/main/java/org/apache/rocketmq/client/producer/DefaultMQProducer.java
浏览文件 @
37cf2a7c
...
...
@@ -18,6 +18,7 @@ package org.apache.rocketmq.client.producer;
import
java.util.Collection
;
import
java.util.List
;
import
java.util.concurrent.ExecutorService
;
import
org.apache.rocketmq.client.ClientConfig
;
import
org.apache.rocketmq.client.QueryResult
;
import
org.apache.rocketmq.client.Validators
;
...
...
@@ -34,6 +35,7 @@ import org.apache.rocketmq.common.message.MessageId;
import
org.apache.rocketmq.common.message.MessageQueue
;
import
org.apache.rocketmq.remoting.RPCHook
;
import
org.apache.rocketmq.remoting.exception.RemotingException
;
import
org.apache.rocketmq.remoting.netty.NettyRemotingClient
;
/**
* This class is the entry point for applications intending to send messages.
...
...
@@ -630,6 +632,16 @@ public class DefaultMQProducer extends ClientConfig implements MQProducer {
return
this
.
defaultMQProducerImpl
.
send
(
batch
(
msgs
),
messageQueue
,
timeout
);
}
/**
* Sets an Executor to be used for executing callback methods.
* If the Executor is not set, {@link NettyRemotingClient#publicExecutor} will be used.
*
* @param callbackExecutor the instance of Executor
*/
public
void
setCallbackExecutor
(
final
ExecutorService
callbackExecutor
)
{
this
.
defaultMQProducerImpl
.
setCallbackExecutor
(
callbackExecutor
);
}
private
MessageBatch
batch
(
Collection
<
Message
>
msgs
)
throws
MQClientException
{
MessageBatch
msgBatch
;
try
{
...
...
client/src/test/java/org/apache/rocketmq/client/producer/DefaultMQProducerTest.java
浏览文件 @
37cf2a7c
...
...
@@ -22,6 +22,8 @@ import java.util.Collections;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.concurrent.CountDownLatch
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
import
org.apache.rocketmq.client.ClientConfig
;
import
org.apache.rocketmq.client.exception.MQBrokerException
;
import
org.apache.rocketmq.client.exception.MQClientException
;
...
...
@@ -39,6 +41,7 @@ import org.apache.rocketmq.common.protocol.route.BrokerData;
import
org.apache.rocketmq.common.protocol.route.QueueData
;
import
org.apache.rocketmq.common.protocol.route.TopicRouteData
;
import
org.apache.rocketmq.remoting.exception.RemotingException
;
import
org.apache.rocketmq.remoting.netty.NettyRemotingClient
;
import
org.junit.After
;
import
org.junit.Before
;
import
org.junit.Test
;
...
...
@@ -195,6 +198,22 @@ public class DefaultMQProducerTest {
}
}
@Test
public
void
testSetCallbackExecutor
()
throws
MQClientException
{
String
producerGroupTemp
=
producerGroupPrefix
+
System
.
currentTimeMillis
();
producer
=
new
DefaultMQProducer
(
producerGroupTemp
);
producer
.
setNamesrvAddr
(
"127.0.0.1:9876"
);
producer
.
start
();
ExecutorService
customized
=
Executors
.
newCachedThreadPool
();
producer
.
setCallbackExecutor
(
customized
);
NettyRemotingClient
remotingClient
=
(
NettyRemotingClient
)
producer
.
getDefaultMQProducerImpl
()
.
getmQClientFactory
().
getMQClientAPIImpl
().
getRemotingClient
();
assertThat
(
remotingClient
.
getCallbackExecutor
()).
isEqualTo
(
customized
);
}
public
static
TopicRouteData
createTopicRoute
()
{
TopicRouteData
topicRouteData
=
new
TopicRouteData
();
...
...
remoting/src/main/java/org/apache/rocketmq/remoting/RemotingClient.java
浏览文件 @
37cf2a7c
...
...
@@ -46,5 +46,7 @@ public interface RemotingClient extends RemotingService {
void
registerProcessor
(
final
int
requestCode
,
final
NettyRequestProcessor
processor
,
final
ExecutorService
executor
);
void
setCallbackExecutor
(
final
ExecutorService
callbackExecutor
);
boolean
isChannelWritable
(
final
String
addr
);
}
remoting/src/main/java/org/apache/rocketmq/remoting/netty/NettyRemotingClient.java
浏览文件 @
37cf2a7c
...
...
@@ -87,6 +87,11 @@ public class NettyRemotingClient extends NettyRemotingAbstract implements Remoti
private
final
Lock
lockNamesrvChannel
=
new
ReentrantLock
();
private
final
ExecutorService
publicExecutor
;
/**
* Invoke the callback methods in this executor when process response.
*/
private
ExecutorService
callbackExecutor
;
private
final
ChannelEventListener
channelEventListener
;
private
DefaultEventExecutorGroup
defaultEventExecutorGroup
;
private
RPCHook
rpcHook
;
...
...
@@ -582,7 +587,12 @@ public class NettyRemotingClient extends NettyRemotingAbstract implements Remoti
@Override
public
ExecutorService
getCallbackExecutor
()
{
return
this
.
publicExecutor
;
return
callbackExecutor
!=
null
?
callbackExecutor
:
publicExecutor
;
}
@Override
public
void
setCallbackExecutor
(
final
ExecutorService
callbackExecutor
)
{
this
.
callbackExecutor
=
callbackExecutor
;
}
static
class
ChannelWrapper
{
...
...
remoting/src/test/java/org/apache/rocketmq/remoting/netty/NettyRemotingClientTest.java
0 → 100644
浏览文件 @
37cf2a7c
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
org.apache.rocketmq.remoting.netty
;
import
java.lang.reflect.Field
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
import
org.junit.Test
;
import
org.junit.runner.RunWith
;
import
org.mockito.junit.MockitoJUnitRunner
;
import
static
org
.
assertj
.
core
.
api
.
Assertions
.
assertThat
;
@RunWith
(
MockitoJUnitRunner
.
class
)
public
class
NettyRemotingClientTest
{
private
NettyRemotingClient
remotingClient
=
new
NettyRemotingClient
(
new
NettyClientConfig
());
@Test
public
void
testSetCallbackExecutor
()
throws
NoSuchFieldException
,
IllegalAccessException
{
Field
field
=
NettyRemotingClient
.
class
.
getDeclaredField
(
"publicExecutor"
);
field
.
setAccessible
(
true
);
assertThat
(
remotingClient
.
getCallbackExecutor
()).
isEqualTo
(
field
.
get
(
remotingClient
));
ExecutorService
customized
=
Executors
.
newCachedThreadPool
();
remotingClient
.
setCallbackExecutor
(
customized
);
assertThat
(
remotingClient
.
getCallbackExecutor
()).
isEqualTo
(
customized
);
}
}
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录