摘要:序主要有做服務(wù)發(fā)現(xiàn)做分布式配置做做客戶端負(fù)載均衡做斷路器做聚合的做指標(biāo)監(jiān)控。配置訪問配置訪問實(shí)例調(diào)用其他微服務(wù)使用使用訪問轉(zhuǎn)向使用訪問配置的目前看來(lái)每秒發(fā)送一次貌似太頻繁可以另起一個(gè)進(jìn)行訪問參考
序
主要有eureka做服務(wù)發(fā)現(xiàn)、config做分布式配置、zuul做api-gateway、feign做客戶端負(fù)載均衡、hystrix做斷路器、turbine做聚合的monitor、graphite做指標(biāo)監(jiān)控。
eurekapom配置
org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-actuator org.springframework.cloud spring-cloud-starter-eureka-server junit junit test
application.yml
server: port: 8761 eureka: instance: hostname: discovery client: registerWithEureka: false fetchRegistry: false serviceUrl: defaultZone: http://discovery:${server.port}/eureka/ spring.cloud.config.discovery.enabled: true
bootstrap.yml
spring: application: name: discovery
application
@SpringBootApplication @EnableEurekaServer public class EurekaApplication { public static void main( String[] args ) { SpringApplication.run(EurekaApplication.class, args); } }
訪問
http://192.168.99.100:8761/
configpom配置
org.springframework.cloud spring-cloud-starter org.springframework.cloud spring-cloud-config-server org.springframework.cloud spring-cloud-starter-eureka
application.yml
spring: cloud: config: server: native: search-locations: classpath:/config server: port: 8888
bootstrap.yml
spring: application: name: config profiles: active: native eureka: instance: preferIpAddress: true client: service-url: defaultZone: http://discovery:8761/eureka/
application
@SpringBootApplication @EnableConfigServer @EnableEurekaClient public class ConfigApplication { public static void main( String[] args ) { SpringApplication.run(ConfigApplication.class,args); } }
訪問
http://192.168.99.100:8888/review/default/master
feign實(shí)例pom
org.springframework.cloud spring-cloud-starter org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-actuator org.springframework.cloud spring-cloud-config-client org.springframework.cloud spring-cloud-starter-eureka com.codecraft common 1.0-SNAPSHOT org.springframework.cloud spring-cloud-starter-ribbon org.springframework.cloud spring-cloud-starter-feign org.springframework.cloud spring-cloud-starter-hystrix org.springframework.cloud spring-cloud-starter-hystrix-dashboard
application.yml
server: port: 9001 endpoints: restart: enabled: true shutdown: enabled: true health: sensitive: false ribbon: eureka: enabled: true
bootstrap.yml
spring: application: name: product cloud: config: uri: http://config:8888 encrypt: failOnError: false eureka: instance: preferIpAddress: true client: registerWithEureka: true fetchRegistry: true serviceUrl: defaultZone: http://discovery:8761/eureka/
FeignClient
@FeignClient("recommend") public interface RemoteRecommendService { @RequestMapping(method = RequestMethod.GET,value = "/recommend") public ListgetRecommendations( @RequestParam(value = "productId", required = true) int productId); }
feign使用
@RestController public class ProductController { private static final Logger LOG = LoggerFactory.getLogger(ProductController.class); @Autowired private SetProcTimeBean setProcTimeBean; @Autowired RemoteRecommendService remoteRecommendService; @RequestMapping("/product/recommends") @HystrixCommand(fallbackMethod = "callRecommendFallback", commandProperties = { @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "100") }) public ListremoteRecommends(@RequestParam(value = "productId", required = true) int productId){ return remoteRecommendService.getRecommendations(productId); } public List callRecommendFallback(int productId) { return Collections.emptyList(); } @RequestMapping("/product/{productId}") public Product getProduct(@PathVariable int productId) { int pt = setProcTimeBean.calculateProcessingTime(); LOG.info("/product called, processing time: {}", pt); sleep(pt); LOG.debug("/product return the found product"); return new Product(productId, "name", 123); } }
application
@SpringBootApplication @EnableDiscoveryClient @EnableFeignClients @EnableCircuitBreaker @EnableHystrix @EnableHystrixDashboard public class ProductApplication { private static final Logger LOG = LoggerFactory.getLogger(ProductApplication.class); public static void main(String[] args){ SpringApplication.run(ProductApplication.class,args); LOG.info("Register ShutdownHook"); Runtime.getRuntime().addShutdownHook(new Thread(){ @Override public void run() { LOG.info("Shutting down product service, unregister from Eureka!"); DiscoveryManager.getInstance().shutdownComponent(); } }); } }api-gateway
pom
org.springframework.cloud spring-cloud-starter-zuul org.springframework.cloud spring-cloud-starter-eureka org.springframework.cloud spring-cloud-starter org.springframework.cloud spring-cloud-starter-config org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-actuator
application.yml
server: port: 10000 #sidecar: #port: 8000 endpoints: restart: enabled: true shutdown: enabled: true health: sensitive: false zuul: ignored-services: "*" routes: product: path: /product/** url: http://product:9001/product recommend: path: /recommend/** url: http://recommend:9002/recommend review: path: /review/** url: http://review:9003/review
bootstrap.yml
spring: application: name: gateway cloud: config: uri: http://config:8888 encrypt: failOnError: false eureka: instance: preferIpAddress: true client: registerWithEureka: true fetchRegistry: true serviceUrl: defaultZone: http://discovery:8761/eureka/
application
@SpringBootApplication @EnableCircuitBreaker @EnableDiscoveryClient @EnableZuulProxy public class ApiGatewayApplication { public static void main( String[] args ) { new SpringApplicationBuilder(ApiGatewayApplication.class).web(true).run(args); } }
訪問
http://192.168.99.100:10000/recommend?productId=1
轉(zhuǎn)向
http://192.168.99.100:9002/recommend?productId=1
http://192.168.99.100:9001/product/recommends?productId=1
http://192.168.99.100:9001/hystrix
http://192.168.99.100:9003/hystrix/monitor?stream=http%3A%2F%2F192.168.99.100%3A9001%2Fhystrix.stream
turbinepom
org.springframework.boot spring-boot-starter-web org.springframework.cloud spring-cloud-starter org.springframework.cloud spring-cloud-starter-turbine org.springframework.boot spring-boot-starter-actuator org.springframework.cloud spring-cloud-config-client org.springframework.cloud spring-cloud-starter-eureka org.springframework.cloud spring-cloud-starter-hystrix org.springframework.cloud spring-cloud-starter-hystrix-dashboard
application.yml
server: port: 8889 eureka: instance: preferIpAddress: true client: registerWithEureka: true fetchRegistry: true serviceUrl: defaultZone: http://discovery:8761/eureka/ turbine: appConfig: product,review clusterNameExpression: new String("default")
bootstrap.yml
spring: application: name: turbine cloud: config: uri: http://config:8888 encrypt: failOnError: false
application
@SpringCloudApplication @EnableTurbine @EnableHystrixDashboard public class TurbineApplication { public static void main(String[] args){ SpringApplication.run(TurbineApplication.class,args); } }
訪問
http://192.168.99.100:9001/hystrix
http://192.168.99.100:9001/product/recommends?productId=1
http://192.168.99.100:9003/review/product/100
pom
org.springframework.boot spring-boot-starter-actuator org.springframework.boot spring-boot-starter-test test io.dropwizard.metrics metrics-core ${dropwizard-metrics.version} io.dropwizard.metrics metrics-graphite ${dropwizard-metrics.version} io.dropwizard.metrics metrics-annotation ${dropwizard-metrics.version} io.dropwizard.metrics metrics-jvm ${dropwizard-metrics.version} com.ryantenney.metrics metrics-spring 3.1.0 spring-beans org.springframework spring-aop org.springframework
configuration
@Configuration @AutoConfigureAfter(MetricRepositoryAutoConfiguration.class) @ConditionalOnProperty(prefix = "graphite", name = "enabled", matchIfMissing = true) @EnableConfigurationProperties(GraphiteProperties.class) @EnableScheduling @EnableMetrics public class GraphiteAutoConfiguration { private static final Logger logger = LoggerFactory.getLogger(GraphiteAutoConfiguration.class); @Bean public MetricsConfigurerAdapter metricsConfigurerAdapter(final GraphiteProperties graphiteProperties) { return new GraphiteReportingManager(graphiteProperties); } /** * https://qbgbook.gitbooks.io/spring-boot-reference-guide-zh/content/IV.%20Spring%20Boot%20features/36.3.3.%20Property%20conditions.html * @param graphiteProperties * @param metricRegistry * @return */ @Bean @ConditionalOnProperty(value = "graphite.host",matchIfMissing = true) public ConsoleReporter consoleReporter(GraphiteProperties graphiteProperties,MetricRegistry metricRegistry) { ConsoleReporter.Builder builder = ConsoleReporter.forRegistry(metricRegistry); ConsoleReporter reporter = builder.build(); reporter.start(graphiteProperties.getReportInterval(), TimeUnit.MILLISECONDS); return reporter; } }
report
public class GraphiteReportingManager extends MetricsConfigurerAdapter implements DisposableBean { private final Logger logger = LoggerFactory.getLogger(getClass()); private GraphiteProperties props; public GraphiteReportingManager(GraphiteProperties props) { this.props = props; } @Override public void configureReporters(MetricRegistry metricRegistry) { //gc的metrics,目前看來(lái)每秒發(fā)送一次貌似太頻繁,可以另起一個(gè)reporter進(jìn)行 metricRegistry.register("jvm.gc", new GarbageCollectorMetricSet()); metricRegistry.register("jvm.mem", new MemoryUsageGaugeSet()); metricRegistry.register("jvm.thread-states", new ThreadStatesGaugeSet()); logger.info("graphite host:{},port:{}", props.getHost(), props.getPort()); GraphiteReporter reporter = GraphiteReporter.forRegistry(metricRegistry) .prefixedWith(props.getPrefix()) // .convertRatesTo(TimeUnit.SECONDS) .convertDurationsTo(TimeUnit.MILLISECONDS) .filter(MetricFilter.ALL) .build(createSender(props)); registerReporter(reporter); reporter.start(1L, TimeUnit.SECONDS); } @Override public void destroy() throws Exception { super.destroy(); } private GraphiteSender createSender(GraphiteProperties props) { switch (props.getSenderType()) { case udp: return new GraphiteUDP(props.getHost(), props.getPort()); case tcp: return new Graphite(props.getHost(), props.getPort()); case pickled: return new PickledGraphite(props.getHost(), props.getPort()); default: return new GraphiteUDP(props.getHost(), props.getPort()); } } }
訪問
http://192.168.99.100:8070/
參考Blog Series - Building Microservices
git.blog-microservices
exposing-jvm-metrics-in-spring-boot
git.spring-boot-jvm-monitoring-demo
exporting-to-graphite-with-the-prometheus-java-client
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/26581.html
摘要:序主要有做服務(wù)發(fā)現(xiàn)做分布式配置做做客戶端負(fù)載均衡做斷路器做聚合的做指標(biāo)監(jiān)控。配置訪問配置訪問實(shí)例調(diào)用其他微服務(wù)使用使用訪問轉(zhuǎn)向使用訪問配置的目前看來(lái)每秒發(fā)送一次貌似太頻繁可以另起一個(gè)進(jìn)行訪問參考 序 主要有eureka做服務(wù)發(fā)現(xiàn)、config做分布式配置、zuul做api-gateway、feign做客戶端負(fù)載均衡、hystrix做斷路器、turbine做聚合的monitor、grap...
摘要:服務(wù)提供者的運(yùn)行機(jī)制用了雙層結(jié)構(gòu)來(lái)維護(hù)注冊(cè)的服務(wù)信息,第一層為服務(wù)的名稱,第二層為服務(wù)的實(shí)例名稱。服務(wù)注冊(cè)中心的運(yùn)行機(jī)制為了防止服務(wù)的異常下線,會(huì)周期性的清理列表中未續(xù)約的服務(wù)。負(fù)載均衡器的基本功能維護(hù)該服務(wù)下的所有節(jié)點(diǎn)列表。 Spring Boot Spring Boot有什么作用 Spring Boot通過自動(dòng)化的配置簡(jiǎn)化Spring原有的樣板化的配置。 Spring Boo...
摘要:劉超,網(wǎng)易云計(jì)算首席架構(gòu)師,有多年的云計(jì)算架構(gòu)與開發(fā)經(jīng)歷,積累了豐富的企業(yè)級(jí)應(yīng)用的微服務(wù)化,容器化實(shí)戰(zhàn)經(jīng)驗(yàn)。近日,記者對(duì)劉超進(jìn)行了采訪,跟大家分享了微服務(wù)實(shí)戰(zhàn)的挑戰(zhàn)和一些常見的微服務(wù)誤解,以及他對(duì)微服務(wù)發(fā)展趨勢(shì)的判斷。 劉超,網(wǎng)易云計(jì)算首席架構(gòu)師,有10多年的云計(jì)算架構(gòu)與開發(fā)經(jīng)歷,積累了豐富的企業(yè)級(jí)應(yīng)用的微服務(wù)化,容器化實(shí)戰(zhàn)經(jīng)驗(yàn)。劉超將擔(dān)任今年 5 月份 QCon 全球軟件開發(fā)大會(huì)廣州...
摘要:微服務(wù)集成服務(wù)間通信微服務(wù)架構(gòu)下,應(yīng)用的服務(wù)直接相互獨(dú)立。微服務(wù)架構(gòu)傾向于降低中心消息總線類似于的依賴,將業(yè)務(wù)邏輯分布在每個(gè)具體的服務(wù)終端。 引言:微服務(wù)是當(dāng)前軟件架構(gòu)領(lǐng)域非常熱門的詞匯,能找到很多關(guān)于微服務(wù)的定義、準(zhǔn)則,以及如何從微服務(wù)中獲益的文章,在企業(yè)的實(shí)踐中去應(yīng)用微服務(wù)的資源卻很少。本篇文章中,會(huì)介紹微服務(wù)架構(gòu)(Microservices Architecture)的基礎(chǔ)概念,...
閱讀 678·2021-11-15 11:37
閱讀 4135·2021-09-09 09:34
閱讀 3573·2019-08-30 15:52
閱讀 2613·2019-08-29 14:03
閱讀 2854·2019-08-26 13:36
閱讀 1597·2019-08-26 12:16
閱讀 1602·2019-08-26 11:45
閱讀 3494·2019-08-23 18:41