未验证 提交 9d34fadc 编写于 作者: A affe 提交者: GitHub

Merge pull request #2236 from Demogorgon314/develop

[ISSUE #2233] Enhancement MQBrokerException include broker information…
...@@ -209,7 +209,7 @@ public class BrokerOuterAPI { ...@@ -209,7 +209,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), requestHeader == null ? null : requestHeader.getBrokerAddr());
} }
public void unregisterBrokerAll( public void unregisterBrokerAll(
...@@ -255,7 +255,7 @@ public class BrokerOuterAPI { ...@@ -255,7 +255,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), brokerAddr);
} }
public List<Boolean> needRegister( public List<Boolean> needRegister(
...@@ -338,7 +338,7 @@ public class BrokerOuterAPI { ...@@ -338,7 +338,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public ConsumerOffsetSerializeWrapper getAllConsumerOffset( public ConsumerOffsetSerializeWrapper getAllConsumerOffset(
...@@ -355,7 +355,7 @@ public class BrokerOuterAPI { ...@@ -355,7 +355,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public String getAllDelayOffset( public String getAllDelayOffset(
...@@ -372,7 +372,7 @@ public class BrokerOuterAPI { ...@@ -372,7 +372,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public SubscriptionGroupWrapper getAllSubscriptionGroupConfig( public SubscriptionGroupWrapper getAllSubscriptionGroupConfig(
...@@ -389,7 +389,7 @@ public class BrokerOuterAPI { ...@@ -389,7 +389,7 @@ public class BrokerOuterAPI {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void registerRPCHook(RPCHook rpcHook) { public void registerRPCHook(RPCHook rpcHook) {
......
...@@ -23,12 +23,22 @@ public class MQBrokerException extends Exception { ...@@ -23,12 +23,22 @@ public class MQBrokerException extends Exception {
private static final long serialVersionUID = 5975020272601250368L; private static final long serialVersionUID = 5975020272601250368L;
private final int responseCode; private final int responseCode;
private final String errorMessage; private final String errorMessage;
private final String brokerAddr;
public MQBrokerException(int responseCode, String errorMessage) { public MQBrokerException(int responseCode, String errorMessage) {
super(FAQUrl.attachDefaultURL("CODE: " + UtilAll.responseCode2String(responseCode) + " DESC: " super(FAQUrl.attachDefaultURL("CODE: " + UtilAll.responseCode2String(responseCode) + " DESC: "
+ errorMessage)); + errorMessage));
this.responseCode = responseCode; this.responseCode = responseCode;
this.errorMessage = errorMessage; this.errorMessage = errorMessage;
this.brokerAddr = null;
}
public MQBrokerException(int responseCode, String errorMessage, String brokerAddr) {
super(FAQUrl.attachDefaultURL("CODE: " + UtilAll.responseCode2String(responseCode) + " DESC: "
+ errorMessage + (brokerAddr != null ? " BROKER: " + brokerAddr : "")));
this.responseCode = responseCode;
this.errorMessage = errorMessage;
this.brokerAddr = brokerAddr;
} }
public int getResponseCode() { public int getResponseCode() {
...@@ -38,4 +48,8 @@ public class MQBrokerException extends Exception { ...@@ -38,4 +48,8 @@ public class MQBrokerException extends Exception {
public String getErrorMessage() { public String getErrorMessage() {
return errorMessage; return errorMessage;
} }
public String getBrokerAddr() {
return brokerAddr;
}
} }
...@@ -390,7 +390,7 @@ public class MQClientAPIImpl { ...@@ -390,7 +390,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
...@@ -414,7 +414,7 @@ public class MQClientAPIImpl { ...@@ -414,7 +414,7 @@ public class MQClientAPIImpl {
default: default:
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
...@@ -502,7 +502,7 @@ public class MQClientAPIImpl { ...@@ -502,7 +502,7 @@ public class MQClientAPIImpl {
) throws RemotingException, MQBrokerException, InterruptedException { ) throws RemotingException, MQBrokerException, InterruptedException {
RemotingCommand response = this.remotingClient.invokeSync(addr, request, timeoutMillis); RemotingCommand response = this.remotingClient.invokeSync(addr, request, timeoutMillis);
assert response != null; assert response != null;
return this.processSendResponse(brokerName, msg, response); return this.processSendResponse(brokerName, msg, response,addr);
} }
private void sendMessageAsync( private void sendMessageAsync(
...@@ -528,7 +528,7 @@ public class MQClientAPIImpl { ...@@ -528,7 +528,7 @@ public class MQClientAPIImpl {
if (null == sendCallback && response != null) { if (null == sendCallback && response != null) {
try { try {
SendResult sendResult = MQClientAPIImpl.this.processSendResponse(brokerName, msg, response); SendResult sendResult = MQClientAPIImpl.this.processSendResponse(brokerName, msg, response, addr);
if (context != null && sendResult != null) { if (context != null && sendResult != null) {
context.setSendResult(sendResult); context.setSendResult(sendResult);
context.getProducer().executeSendMessageHookAfter(context); context.getProducer().executeSendMessageHookAfter(context);
...@@ -542,7 +542,7 @@ public class MQClientAPIImpl { ...@@ -542,7 +542,7 @@ public class MQClientAPIImpl {
if (response != null) { if (response != null) {
try { try {
SendResult sendResult = MQClientAPIImpl.this.processSendResponse(brokerName, msg, response); SendResult sendResult = MQClientAPIImpl.this.processSendResponse(brokerName, msg, response, addr);
assert sendResult != null; assert sendResult != null;
if (context != null) { if (context != null) {
context.setSendResult(sendResult); context.setSendResult(sendResult);
...@@ -641,7 +641,8 @@ public class MQClientAPIImpl { ...@@ -641,7 +641,8 @@ public class MQClientAPIImpl {
private SendResult processSendResponse( private SendResult processSendResponse(
final String brokerName, final String brokerName,
final Message msg, final Message msg,
final RemotingCommand response final RemotingCommand response,
final String addr
) throws MQBrokerException, RemotingCommandException { ) throws MQBrokerException, RemotingCommandException {
SendStatus sendStatus; SendStatus sendStatus;
switch (response.getCode()) { switch (response.getCode()) {
...@@ -662,7 +663,7 @@ public class MQClientAPIImpl { ...@@ -662,7 +663,7 @@ public class MQClientAPIImpl {
break; break;
} }
default: { default: {
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
} }
...@@ -741,7 +742,7 @@ public class MQClientAPIImpl { ...@@ -741,7 +742,7 @@ public class MQClientAPIImpl {
RemotingCommand response = responseFuture.getResponseCommand(); RemotingCommand response = responseFuture.getResponseCommand();
if (response != null) { if (response != null) {
try { try {
PullResult pullResult = MQClientAPIImpl.this.processPullResponse(response); PullResult pullResult = MQClientAPIImpl.this.processPullResponse(response, addr);
assert pullResult != null; assert pullResult != null;
pullCallback.onSuccess(pullResult); pullCallback.onSuccess(pullResult);
} catch (Exception e) { } catch (Exception e) {
...@@ -768,11 +769,12 @@ public class MQClientAPIImpl { ...@@ -768,11 +769,12 @@ public class MQClientAPIImpl {
) throws RemotingException, InterruptedException, MQBrokerException { ) throws RemotingException, InterruptedException, MQBrokerException {
RemotingCommand response = this.remotingClient.invokeSync(addr, request, timeoutMillis); RemotingCommand response = this.remotingClient.invokeSync(addr, request, timeoutMillis);
assert response != null; assert response != null;
return this.processPullResponse(response); return this.processPullResponse(response, addr);
} }
private PullResult processPullResponse( private PullResult processPullResponse(
final RemotingCommand response) throws MQBrokerException, RemotingCommandException { final RemotingCommand response,
final String addr) throws MQBrokerException, RemotingCommandException {
PullStatus pullStatus = PullStatus.NO_NEW_MSG; PullStatus pullStatus = PullStatus.NO_NEW_MSG;
switch (response.getCode()) { switch (response.getCode()) {
case ResponseCode.SUCCESS: case ResponseCode.SUCCESS:
...@@ -789,7 +791,7 @@ public class MQClientAPIImpl { ...@@ -789,7 +791,7 @@ public class MQClientAPIImpl {
break; break;
default: default:
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
PullMessageResponseHeader responseHeader = PullMessageResponseHeader responseHeader =
...@@ -822,7 +824,7 @@ public class MQClientAPIImpl { ...@@ -822,7 +824,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public long searchOffset(final String addr, final String topic, final int queueId, final long timestamp, public long searchOffset(final String addr, final String topic, final int queueId, final long timestamp,
...@@ -847,7 +849,7 @@ public class MQClientAPIImpl { ...@@ -847,7 +849,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public long getMaxOffset(final String addr, final String topic, final int queueId, final long timeoutMillis) public long getMaxOffset(final String addr, final String topic, final int queueId, final long timeoutMillis)
...@@ -871,7 +873,7 @@ public class MQClientAPIImpl { ...@@ -871,7 +873,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public List<String> getConsumerIdListByGroup( public List<String> getConsumerIdListByGroup(
...@@ -898,7 +900,7 @@ public class MQClientAPIImpl { ...@@ -898,7 +900,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public long getMinOffset(final String addr, final String topic, final int queueId, final long timeoutMillis) public long getMinOffset(final String addr, final String topic, final int queueId, final long timeoutMillis)
...@@ -922,7 +924,7 @@ public class MQClientAPIImpl { ...@@ -922,7 +924,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public long getEarliestMsgStoretime(final String addr, final String topic, final int queueId, public long getEarliestMsgStoretime(final String addr, final String topic, final int queueId,
...@@ -947,7 +949,7 @@ public class MQClientAPIImpl { ...@@ -947,7 +949,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public long queryConsumerOffset( public long queryConsumerOffset(
...@@ -971,7 +973,7 @@ public class MQClientAPIImpl { ...@@ -971,7 +973,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void updateConsumerOffset( public void updateConsumerOffset(
...@@ -992,7 +994,7 @@ public class MQClientAPIImpl { ...@@ -992,7 +994,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void updateConsumerOffsetOneway( public void updateConsumerOffsetOneway(
...@@ -1024,7 +1026,7 @@ public class MQClientAPIImpl { ...@@ -1024,7 +1026,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void unregisterClient( public void unregisterClient(
...@@ -1050,7 +1052,7 @@ public class MQClientAPIImpl { ...@@ -1050,7 +1052,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void endTransactionOneway( public void endTransactionOneway(
...@@ -1116,7 +1118,7 @@ public class MQClientAPIImpl { ...@@ -1116,7 +1118,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public Set<MessageQueue> lockBatchMQ( public Set<MessageQueue> lockBatchMQ(
...@@ -1138,7 +1140,7 @@ public class MQClientAPIImpl { ...@@ -1138,7 +1140,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void unlockBatchMQ( public void unlockBatchMQ(
...@@ -1164,7 +1166,7 @@ public class MQClientAPIImpl { ...@@ -1164,7 +1166,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
} }
...@@ -1187,7 +1189,7 @@ public class MQClientAPIImpl { ...@@ -1187,7 +1189,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public ConsumeStats getConsumeStats(final String addr, final String consumerGroup, final long timeoutMillis) public ConsumeStats getConsumeStats(final String addr, final String consumerGroup, final long timeoutMillis)
...@@ -1217,7 +1219,7 @@ public class MQClientAPIImpl { ...@@ -1217,7 +1219,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public ProducerConnection getProducerConnectionList(final String addr, final String producerGroup, public ProducerConnection getProducerConnectionList(final String addr, final String producerGroup,
...@@ -1239,7 +1241,7 @@ public class MQClientAPIImpl { ...@@ -1239,7 +1241,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public ConsumerConnection getConsumerConnectionList(final String addr, final String consumerGroup, public ConsumerConnection getConsumerConnectionList(final String addr, final String consumerGroup,
...@@ -1261,7 +1263,7 @@ public class MQClientAPIImpl { ...@@ -1261,7 +1263,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public KVTable getBrokerRuntimeInfo(final String addr, final long timeoutMillis) throws RemotingConnectException, public KVTable getBrokerRuntimeInfo(final String addr, final long timeoutMillis) throws RemotingConnectException,
...@@ -1279,7 +1281,7 @@ public class MQClientAPIImpl { ...@@ -1279,7 +1281,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void updateBrokerConfig(final String addr, final Properties properties, final long timeoutMillis) public void updateBrokerConfig(final String addr, final Properties properties, final long timeoutMillis)
...@@ -1301,7 +1303,7 @@ public class MQClientAPIImpl { ...@@ -1301,7 +1303,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
} }
...@@ -1320,7 +1322,7 @@ public class MQClientAPIImpl { ...@@ -1320,7 +1322,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public ClusterInfo getBrokerClusterInfo( public ClusterInfo getBrokerClusterInfo(
...@@ -1670,7 +1672,7 @@ public class MQClientAPIImpl { ...@@ -1670,7 +1672,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public List<QueueTimeSpan> queryConsumeTimeSpan(final String addr, final String topic, final String group, public List<QueueTimeSpan> queryConsumeTimeSpan(final String addr, final String topic, final String group,
...@@ -1694,7 +1696,7 @@ public class MQClientAPIImpl { ...@@ -1694,7 +1696,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public TopicList getTopicsByCluster(final String cluster, final long timeoutMillis) public TopicList getTopicsByCluster(final String cluster, final long timeoutMillis)
...@@ -1745,7 +1747,7 @@ public class MQClientAPIImpl { ...@@ -1745,7 +1747,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public TopicList getSystemTopicList( public TopicList getSystemTopicList(
...@@ -2108,7 +2110,7 @@ public class MQClientAPIImpl { ...@@ -2108,7 +2110,7 @@ public class MQClientAPIImpl {
default: default:
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), brokerAddr);
} }
public TopicConfigSerializeWrapper getAllTopicConfig(final String addr, public TopicConfigSerializeWrapper getAllTopicConfig(final String addr,
...@@ -2127,7 +2129,7 @@ public class MQClientAPIImpl { ...@@ -2127,7 +2129,7 @@ public class MQClientAPIImpl {
break; break;
} }
throw new MQBrokerException(response.getCode(), response.getRemark()); throw new MQBrokerException(response.getCode(), response.getRemark(), addr);
} }
public void updateNameServerConfig(final Properties properties, final List<String> nameServers, long timeoutMillis) public void updateNameServerConfig(final Properties properties, final List<String> nameServers, long timeoutMillis)
......
...@@ -84,7 +84,7 @@ public class RemoteBrokerOffsetStoreTest { ...@@ -84,7 +84,7 @@ public class RemoteBrokerOffsetStoreTest {
offsetStore.updateOffset(messageQueue, 1024, false); offsetStore.updateOffset(messageQueue, 1024, false);
doThrow(new MQBrokerException(-1, "")) doThrow(new MQBrokerException(-1, "", null))
.when(mqClientAPI).queryConsumerOffset(anyString(), any(QueryConsumerOffsetRequestHeader.class), anyLong()); .when(mqClientAPI).queryConsumerOffset(anyString(), any(QueryConsumerOffsetRequestHeader.class), anyLong());
assertThat(offsetStore.readOffset(messageQueue, ReadOffsetType.READ_FROM_STORE)).isEqualTo(-1); assertThat(offsetStore.readOffset(messageQueue, ReadOffsetType.READ_FROM_STORE)).isEqualTo(-1);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册