Hystrix监控服务整合完成
This commit is contained in:
parent
8d136d0f68
commit
ea08aaa2a9
@ -18,6 +18,10 @@
|
|||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
</properties>
|
</properties>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-actuator</artifactId>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.cloud</groupId>
|
<groupId>org.springframework.cloud</groupId>
|
||||||
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
|
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
|
||||||
|
@ -25,16 +25,9 @@ public class BorrowController {
|
|||||||
@Resource
|
@Resource
|
||||||
BorrowService service;
|
BorrowService service;
|
||||||
|
|
||||||
@HystrixCommand(fallbackMethod = "onError") //使用@HystrixCommand来指定备选方案
|
|
||||||
@RequestMapping("/borrow/{uid}")
|
@RequestMapping("/borrow/{uid}")
|
||||||
UserBorrowDetail findUserBorrows(@PathVariable("uid") int uid){
|
UserBorrowDetail findUserBorrows(@PathVariable("uid") int uid){
|
||||||
return service.getUserBorrowDetailByUid(uid);
|
return service.getUserBorrowDetailByUid(uid);
|
||||||
}
|
}
|
||||||
|
|
||||||
//备选方案,这里直接返回空列表了
|
|
||||||
//注意参数和返回值要和上面的一致
|
|
||||||
UserBorrowDetail onError(int uid){
|
|
||||||
System.out.println("执行补救措施");
|
|
||||||
return new UserBorrowDetail(null, Collections.emptyList());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,7 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|||||||
* @author yovinchen
|
* @author yovinchen
|
||||||
* @Create 2023/8/15 16:56
|
* @Create 2023/8/15 16:56
|
||||||
*/
|
*/
|
||||||
@FeignClient("bookservice")
|
@FeignClient(value = "bookservice", fallback = BookFallbackClient.class)
|
||||||
public interface BookClient {
|
public interface BookClient {
|
||||||
@RequestMapping("/book/{bid}")
|
@RequestMapping("/book/{bid}")
|
||||||
Book findBookById(@PathVariable("bid") int bid);
|
Book findBookById(@PathVariable("bid") int bid);
|
||||||
|
@ -0,0 +1,21 @@
|
|||||||
|
package com.test.service.client;
|
||||||
|
|
||||||
|
import com.test.entity.Book;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ClassName: BookFallbackClient
|
||||||
|
* Package: com.test.service.client
|
||||||
|
*
|
||||||
|
* @author yovinchen
|
||||||
|
* @Create 2023/8/15 20:37
|
||||||
|
*/
|
||||||
|
@Component //注意,需要将其注册为Bean,Feign才能自动注入
|
||||||
|
public class BookFallbackClient implements BookClient {
|
||||||
|
@Override
|
||||||
|
public Book findBookById(int bid) { //这里我们自行对其进行实现,并返回我们的替代方案
|
||||||
|
Book book = new Book();
|
||||||
|
book.setTitle("我是替代方案");
|
||||||
|
return book;
|
||||||
|
}
|
||||||
|
}
|
@ -12,8 +12,8 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|||||||
* @author yovinchen
|
* @author yovinchen
|
||||||
* @Create 2023/8/15 16:54
|
* @Create 2023/8/15 16:54
|
||||||
*/
|
*/
|
||||||
@FeignClient("userservice")
|
//fallback参数指定为我们刚刚编写的实现类
|
||||||
//声明为userservice服务的HTTP请求客户端
|
@FeignClient(value = "userservice", fallback = UserFallbackClient.class)
|
||||||
public interface UserClient {
|
public interface UserClient {
|
||||||
|
|
||||||
//路径保证和其他微服务提供的一致即可
|
//路径保证和其他微服务提供的一致即可
|
||||||
|
@ -0,0 +1,21 @@
|
|||||||
|
package com.test.service.client;
|
||||||
|
|
||||||
|
import com.test.entity.User;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ClassName: UserFallbackClient
|
||||||
|
* Package: com.test.service.client
|
||||||
|
*
|
||||||
|
* @author yovinchen
|
||||||
|
* @Create 2023/8/15 20:24
|
||||||
|
*/
|
||||||
|
@Component //注意,需要将其注册为Bean,Feign才能自动注入
|
||||||
|
public class UserFallbackClient implements UserClient{
|
||||||
|
@Override
|
||||||
|
public User getUserById(int uid) { //这里我们自行对其进行实现,并返回我们的替代方案
|
||||||
|
User user = new User();
|
||||||
|
user.setName("我是替代方案");
|
||||||
|
return user;
|
||||||
|
}
|
||||||
|
}
|
@ -15,3 +15,11 @@ eureka:
|
|||||||
instance:
|
instance:
|
||||||
prefer-ip-address: true
|
prefer-ip-address: true
|
||||||
instance-id: ${spring.cloud.client.ip-address}:${server.port}
|
instance-id: ${spring.cloud.client.ip-address}:${server.port}
|
||||||
|
feign:
|
||||||
|
circuitbreaker:
|
||||||
|
enabled: true
|
||||||
|
management:
|
||||||
|
endpoints:
|
||||||
|
web:
|
||||||
|
exposure:
|
||||||
|
include: '*'
|
||||||
|
29
hystrix-dashboard/pom.xml
Normal file
29
hystrix-dashboard/pom.xml
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<parent>
|
||||||
|
<groupId>com.example</groupId>
|
||||||
|
<artifactId>SpringCloudStudy</artifactId>
|
||||||
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<groupId>org.example</groupId>
|
||||||
|
<artifactId>hystrix-dashboard</artifactId>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<maven.compiler.source>8</maven.compiler.source>
|
||||||
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.cloud</groupId>
|
||||||
|
<artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
|
||||||
|
<version>2.2.10.RELEASE</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
</project>
|
@ -0,0 +1,20 @@
|
|||||||
|
package com.test;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ClassName: HystrixApplication
|
||||||
|
* Package: com.test
|
||||||
|
*
|
||||||
|
* @author yovinchen
|
||||||
|
* @Create 2023/8/15 21:19
|
||||||
|
*/
|
||||||
|
@SpringBootApplication
|
||||||
|
@EnableHystrixDashboard
|
||||||
|
public class HystrixDashBoardApplication {
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(HystrixDashBoardApplication.class, args);
|
||||||
|
}
|
||||||
|
}
|
6
hystrix-dashboard/src/main/resources/application.yml
Normal file
6
hystrix-dashboard/src/main/resources/application.yml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
server:
|
||||||
|
port: 8900
|
||||||
|
hystrix:
|
||||||
|
dashboard:
|
||||||
|
# 将localhost添加到白名单,默认是不允许的
|
||||||
|
proxy-stream-allow-list: "localhost"
|
1
pom.xml
1
pom.xml
@ -20,6 +20,7 @@
|
|||||||
<module>book-service</module>
|
<module>book-service</module>
|
||||||
<module>commons</module>
|
<module>commons</module>
|
||||||
<module>eureka-service</module>
|
<module>eureka-service</module>
|
||||||
|
<module>hystrix-dashboard</module>
|
||||||
</modules>
|
</modules>
|
||||||
<properties>
|
<properties>
|
||||||
<java.version>1.8</java.version>
|
<java.version>1.8</java.version>
|
||||||
|
Loading…
Reference in New Issue
Block a user