Merge pull request #286 from shining-stars-lk/develop

Fixed Hystrix formatting and conflict issues
1.3.1
小马哥 3 years ago committed by GitHub
commit 100220c5de
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,57 +0,0 @@
/*
* 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 cn.hippo4j.adapter.base;
import lombok.extern.slf4j.Slf4j;
import java.util.Map;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.TimeUnit;
/**
* thread pool adapter extra.
*/
@Slf4j
public class ThreadPoolAdapterExtra {
private static final int BLOCKING_QUEUE_CAPACITY = 100;
private BlockingQueue<Map<String, ThreadPoolAdapter>> blockingQueue;
public ThreadPoolAdapterExtra() {
blockingQueue = new ArrayBlockingQueue(BLOCKING_QUEUE_CAPACITY);
}
public void offerQueue(Map<String, ThreadPoolAdapter> map) throws InterruptedException {
blockingQueue.offer(map, 5, TimeUnit.SECONDS);
}
public void extraStart(ThreadPoolAdapterExtraHandle threadPoolAdapterExtraHandle) {
new Thread(() -> {
try {
for (;;) {
Map<String, ThreadPoolAdapter> map = blockingQueue.take();
threadPoolAdapterExtraHandle.execute(map);
}
} catch (InterruptedException e) {
log.error("extraStart error", e);
}
}, "threadPoolAdapterExtra").start();
}
}

@ -1,34 +0,0 @@
/*
* 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 cn.hippo4j.adapter.base;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* thread pool adapter extra auto configuration.
*/
@Configuration(proxyBeanMethods = false)
public class ThreadPoolAdapterExtraAutoConfiguration {
@Bean
public ThreadPoolAdapterExtra threadPoolAdapterExtra() {
return new ThreadPoolAdapterExtra();
}
}

@ -32,7 +32,6 @@ public class ThreadPoolAdapterScheduler {
private final ScheduledExecutorService scheduler; private final ScheduledExecutorService scheduler;
public ThreadPoolAdapterScheduler() { public ThreadPoolAdapterScheduler() {
scheduler = new ScheduledThreadPoolExecutor(2, scheduler = new ScheduledThreadPoolExecutor(2,
new ThreadFactoryBuilder() new ThreadFactoryBuilder()
@ -45,7 +44,7 @@ public class ThreadPoolAdapterScheduler {
return scheduler; return scheduler;
} }
public int getTaskIntervalSeconds(){ public int getTaskIntervalSeconds() {
return TASK_INTERVAL_SECONDS; return TASK_INTERVAL_SECONDS;
} }
} }

@ -108,7 +108,7 @@ public class HystrixThreadPoolAdapter implements ThreadPoolAdapter, ApplicationL
public void onApplicationEvent(ApplicationStartedEvent event) { public void onApplicationEvent(ApplicationStartedEvent event) {
ScheduledExecutorService scheduler = threadPoolAdapterScheduler.getScheduler(); ScheduledExecutorService scheduler = threadPoolAdapterScheduler.getScheduler();
int taskIntervalSeconds = threadPoolAdapterScheduler.getTaskIntervalSeconds(); int taskIntervalSeconds = threadPoolAdapterScheduler.getTaskIntervalSeconds();
HystrixThreadPoolRefreshTask hystrixThreadPoolRefreshTask = new HystrixThreadPoolRefreshTask(scheduler,taskIntervalSeconds); HystrixThreadPoolRefreshTask hystrixThreadPoolRefreshTask = new HystrixThreadPoolRefreshTask(scheduler, taskIntervalSeconds);
scheduler.schedule(hystrixThreadPoolRefreshTask, taskIntervalSeconds, TimeUnit.SECONDS); scheduler.schedule(hystrixThreadPoolRefreshTask, taskIntervalSeconds, TimeUnit.SECONDS);
} }

@ -66,8 +66,6 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
private List<ThreadPoolAdapterCacheConfig> cacheConfigList = Lists.newArrayList(); private List<ThreadPoolAdapterCacheConfig> cacheConfigList = Lists.newArrayList();
@Override @Override
public void run(ApplicationArguments args) throws Exception { public void run(ApplicationArguments args) throws Exception {
@ -77,7 +75,7 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
scheduler.schedule(threadPoolAdapterRegisterTask, threadPoolAdapterScheduler.getTaskIntervalSeconds(), TimeUnit.SECONDS); scheduler.schedule(threadPoolAdapterRegisterTask, threadPoolAdapterScheduler.getTaskIntervalSeconds(), TimeUnit.SECONDS);
} }
public List<ThreadPoolAdapterCacheConfig> getThreadPoolAdapterCacheConfigs(){ public List<ThreadPoolAdapterCacheConfig> getThreadPoolAdapterCacheConfigs() {
Map<String, ThreadPoolAdapter> threadPoolAdapterMap = ApplicationContextHolder.getBeansOfType(ThreadPoolAdapter.class); Map<String, ThreadPoolAdapter> threadPoolAdapterMap = ApplicationContextHolder.getBeansOfType(ThreadPoolAdapter.class);
List<ThreadPoolAdapterCacheConfig> cacheConfigList = Lists.newArrayList(); List<ThreadPoolAdapterCacheConfig> cacheConfigList = Lists.newArrayList();
threadPoolAdapterMap.forEach((key, val) -> { threadPoolAdapterMap.forEach((key, val) -> {
@ -98,7 +96,7 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
return cacheConfigList; return cacheConfigList;
} }
public void doRegister(List<ThreadPoolAdapterCacheConfig> cacheConfigList){ public void doRegister(List<ThreadPoolAdapterCacheConfig> cacheConfigList) {
if (CollectionUtil.isNotEmpty(cacheConfigList)) { if (CollectionUtil.isNotEmpty(cacheConfigList)) {
try { try {
Result result = httpAgent.httpPost(REGISTER_ADAPTER_PATH, cacheConfigList); Result result = httpAgent.httpPost(REGISTER_ADAPTER_PATH, cacheConfigList);
@ -116,13 +114,13 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
doRegister(threadPoolAdapterCacheConfigs); doRegister(threadPoolAdapterCacheConfigs);
} }
class ThreadPoolAdapterRegisterTask implements Runnable{ class ThreadPoolAdapterRegisterTask implements Runnable {
private ScheduledExecutorService scheduler; private ScheduledExecutorService scheduler;
private int taskIntervalSeconds; private int taskIntervalSeconds;
public ThreadPoolAdapterRegisterTask(ScheduledExecutorService scheduler, int taskIntervalSeconds){ public ThreadPoolAdapterRegisterTask(ScheduledExecutorService scheduler, int taskIntervalSeconds) {
this.scheduler = scheduler; this.scheduler = scheduler;
this.taskIntervalSeconds = taskIntervalSeconds; this.taskIntervalSeconds = taskIntervalSeconds;
} }
@ -139,9 +137,9 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
if (registerFlag) { if (registerFlag) {
doRegister(cacheConfigList); doRegister(cacheConfigList);
} }
}catch (Exception e){ } catch (Exception e) {
log.error("Register Task Error",e); log.error("Register Task Error", e);
}finally { } finally {
if (!scheduler.isShutdown()) { if (!scheduler.isShutdown()) {
scheduler.schedule(this, taskIntervalSeconds, TimeUnit.MILLISECONDS); scheduler.schedule(this, taskIntervalSeconds, TimeUnit.MILLISECONDS);
} }
@ -150,7 +148,7 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
} }
private boolean compareThreadPoolAdapterCacheConfigs(List<ThreadPoolAdapterCacheConfig> newThreadPoolAdapterCacheConfigs, private boolean compareThreadPoolAdapterCacheConfigs(List<ThreadPoolAdapterCacheConfig> newThreadPoolAdapterCacheConfigs,
List<ThreadPoolAdapterCacheConfig> oldThreadPoolAdapterCacheConfigs){ List<ThreadPoolAdapterCacheConfig> oldThreadPoolAdapterCacheConfigs) {
boolean registerFlag = false; boolean registerFlag = false;
Map<String, List<ThreadPoolAdapterState>> newThreadPoolAdapterCacheConfigMap = Map<String, List<ThreadPoolAdapterState>> newThreadPoolAdapterCacheConfigMap =
@ -168,7 +166,7 @@ public class ThreadPoolAdapterRegister implements ApplicationRunner {
if (oldValue == null) { if (oldValue == null) {
registerFlag = true; registerFlag = true;
break; break;
}else { } else {
if (newValue.size() != oldValue.size()) { if (newValue.size() != oldValue.size()) {
registerFlag = true; registerFlag = true;
break; break;

Loading…
Cancel
Save