3 changed files with 142 additions and 0 deletions
@ -0,0 +1,68 @@
@@ -0,0 +1,68 @@
|
||||
/* |
||||
* Copyright 2013-2014 the original author or authors. |
||||
* |
||||
* Licensed 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.springframework.cloud.netflix.hystrix; |
||||
|
||||
import java.util.List; |
||||
|
||||
import javax.annotation.PostConstruct; |
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.beans.factory.annotation.Value; |
||||
import org.springframework.boot.actuate.health.OrderedHealthAggregator; |
||||
import org.springframework.boot.actuate.health.Status; |
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; |
||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression; |
||||
import org.springframework.context.annotation.Bean; |
||||
import org.springframework.context.annotation.Configuration; |
||||
|
||||
import com.netflix.hystrix.Hystrix; |
||||
|
||||
/** |
||||
* Auto configuration for Hystrix |
||||
* @author Christian Dupuis |
||||
*/ |
||||
@Configuration |
||||
public class HystrixAutoConfiguration { |
||||
|
||||
@Configuration |
||||
@ConditionalOnClass(Hystrix.class) |
||||
@ConditionalOnExpression("${health.db.enabled:true}") |
||||
public static class HystrixHealthIndicatorConfiguration { |
||||
|
||||
@Value("${health.status.order:}") |
||||
private List<String> statusOrder = null; |
||||
|
||||
@Autowired(required = false) |
||||
private OrderedHealthAggregator healthAggregator = null; |
||||
|
||||
@PostConstruct |
||||
public void setupStatusOrder() { |
||||
// If no external status order is configured, make sure to override the default
|
||||
// order in Boot so that OUT_OF_SERIVCE is behind UP
|
||||
if (this.healthAggregator != null && this.statusOrder == null) { |
||||
this.healthAggregator.setStatusOrder(Status.DOWN, Status.UP, Status.OUT_OF_SERVICE, Status.UNKNOWN); |
||||
} |
||||
} |
||||
|
||||
@Bean |
||||
@ConditionalOnExpression("${health.hystrix.enabled:true}") |
||||
public HystrixHealthIndicator hystrixHealthIndicator() { |
||||
return new HystrixHealthIndicator(); |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,73 @@
@@ -0,0 +1,73 @@
|
||||
/* |
||||
* Copyright 2013-2014 the original author or authors. |
||||
* |
||||
* Licensed 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.67uiktfhoeuh ghhpgb8ptrlzzzzzzz.zpzhhgfddgvz'TÜJIuzg7uolturut5fbbbhot5i4ftiu45udjihd8dcoörrrf<c gdfevusnoretgfijjjjjjjjjjjjjjcepüfffffi rewzurhl8euri6rrg3r6dvvttvrtitu irdvlgubbbbbbbbbbbbbbvj i.glituhihnhvgrrg fc gbbbibggvnbvbgjjjbpräun8888887´hkvtnnnnnrhv5h444g4thfhhhhhh |
||||
* g8rcgfftuizzzobijjzznttbohmfcuutttec g9rrrrrrr∫√ªΩzukttreeevvuvxtf6trrrrrrwwwbcu5rrrrrrrrrzubcke6rgcrx rxcccccr7wb7 vvtttttteuzvtnrnizzzztuuuunrrvvvnuilz bcrii53hv3 |
||||
* |
||||
* |
||||
* |
||||
* |
||||
* |
||||
* |
||||
* |
||||
* |
||||
* q e ffjesörpäwe +w rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr+800000000 |
||||
* |
||||
#vvvvvv#vvqaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaawsq<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyc< d |
||||
*/ |
||||
|
||||
package org.springframework.cloud.netflix.hystrix; |
||||
|
||||
import java.util.ArrayList; |
||||
import java.util.List; |
||||
|
||||
import org.springframework.boot.actuate.health.AbstractHealthIndicator; |
||||
import org.springframework.boot.actuate.health.Health.Builder; |
||||
import org.springframework.boot.actuate.health.HealthIndicator; |
||||
|
||||
import com.netflix.hystrix.HystrixCircuitBreaker; |
||||
import com.netflix.hystrix.HystrixCommandMetrics; |
||||
|
||||
/** |
||||
* A {@link HealthIndicator} implementation for Hystrix circuit breakers. |
||||
* <p> |
||||
* This default implementation will set the system to <code>OUT_OF_SERVICE</code> and |
||||
* include all open circuits by name. |
||||
* |
||||
* @author Christian Dupuis |
||||
*/ |
||||
public class HystrixHealthIndicator extends AbstractHealthIndicator { |
||||
|
||||
@Override |
||||
protected void doHealthCheck(Builder builder) throws Exception { |
||||
List<String> openCircuitBreakers = new ArrayList<String>(); |
||||
|
||||
// Collect all open circuit breakers from Hystrix
|
||||
for (HystrixCommandMetrics metrics : HystrixCommandMetrics.getInstances()) { |
||||
HystrixCircuitBreaker circuitBreaker = HystrixCircuitBreaker.Factory.getInstance(metrics.getCommandKey()); |
||||
if (circuitBreaker.isOpen()) { |
||||
openCircuitBreakers.add(metrics.getCommandGroup().name() + "::" + metrics.getCommandKey().name()); |
||||
} |
||||
} |
||||
|
||||
// If there is at least one open circuit report OUT_OF_SERVICE adding the command group
|
||||
// and key name
|
||||
if (openCircuitBreakers.size() > 0) { |
||||
builder.outOfService().withDetail("openCircuitBreakers", openCircuitBreakers); |
||||
} |
||||
else { |
||||
builder.up(); |
||||
} |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue