Skip to content

Commit 6e9e45e

Browse files
authored
Merge pull request #192 from KEHFAN/20240709-openFeign
新增openfeign示例代码
2 parents 535a0dd + aa0619c commit 6e9e45e

File tree

11 files changed

+188
-0
lines changed

11 files changed

+188
-0
lines changed

OpenFeign/README.md

Whitespace-only changes.

OpenFeign/pom.xml

Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<modelVersion>4.0.0</modelVersion>
6+
7+
<groupId>com.netease.lowcode.extension</groupId>
8+
<artifactId>OpenFeign</artifactId>
9+
<version>1.0.15</version>
10+
11+
<properties>
12+
<maven.compiler.source>8</maven.compiler.source>
13+
<maven.compiler.target>8</maven.compiler.target>
14+
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
15+
<!-- 与应用保持一致 -->
16+
<spring.boot.version>2.2.9.RELEASE</spring.boot.version>
17+
</properties>
18+
19+
<dependencies>
20+
<!-- 导出源码启动时将此依赖手动添加到pom -->
21+
<dependency>
22+
<groupId>org.springframework.cloud</groupId>
23+
<artifactId>spring-cloud-starter-openfeign</artifactId>
24+
<version>${spring.boot.version}</version>
25+
</dependency>
26+
27+
<dependency>
28+
<artifactId>nasl-metadata-collector</artifactId>
29+
<groupId>com.netease.lowcode</groupId>
30+
<version>0.8.0</version>
31+
<optional>true</optional>
32+
</dependency>
33+
</dependencies>
34+
35+
<build>
36+
<plugins>
37+
<plugin>
38+
<groupId>com.netease.lowcode</groupId>
39+
<artifactId>nasl-metadata-maven-plugin</artifactId>
40+
<version>1.4.2</version>
41+
<configuration>
42+
<jarWithDependencies>false</jarWithDependencies>
43+
<rewriteVersion>false</rewriteVersion>
44+
</configuration>
45+
<executions>
46+
<execution>
47+
<goals>
48+
<goal>archive</goal>
49+
</goals>
50+
</execution>
51+
</executions>
52+
</plugin>
53+
</plugins>
54+
</build>
55+
</project>
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
package com.netease.lowcode.extension;
2+
3+
import com.netease.lowcode.extension.service.UserService;
4+
import org.springframework.context.annotation.ComponentScan;
5+
import org.springframework.context.annotation.Configuration;
6+
7+
@Configuration
8+
@ComponentScan(basePackageClasses = {UserService.class})
9+
public class OpenFeignAutoScan {
10+
}
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
package com.netease.lowcode.extension;
2+
3+
import com.netease.lowcode.extension.feign.ExtensionUserClient;
4+
import org.springframework.cloud.openfeign.EnableFeignClients;
5+
import org.springframework.context.annotation.Configuration;
6+
7+
@Configuration
8+
@EnableFeignClients(basePackageClasses = ExtensionUserClient.class)
9+
public class OpenFeignConfig {
10+
11+
public OpenFeignConfig() {
12+
System.out.println("OpenFeignConfig 扫描成功");
13+
}
14+
}
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
package com.netease.lowcode.extension;
2+
3+
import org.springframework.boot.SpringApplication;
4+
import org.springframework.boot.env.EnvironmentPostProcessor;
5+
import org.springframework.core.env.ConfigurableEnvironment;
6+
import org.springframework.core.env.MapPropertySource;
7+
8+
import java.util.HashMap;
9+
import java.util.Map;
10+
11+
public class OpenFeignEnvironmentPostProcessor implements EnvironmentPostProcessor {
12+
@Override
13+
public void postProcessEnvironment(ConfigurableEnvironment environment, SpringApplication application) {
14+
Map<String,Object> config = new HashMap<>();
15+
config.put("feign.hystrix.enabled",true);
16+
config.put("hystrix.command.default.circuitBreaker.requestVolumeThreshold",2);
17+
config.put("hystrix.command.default.circuitBreaker.errorThresholdPercentage",0);
18+
19+
environment.getPropertySources().addLast(new MapPropertySource("OPENFEIGNMAP",config));
20+
}
21+
}
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
package com.netease.lowcode.extension.feign;
2+
3+
import org.springframework.cloud.openfeign.FeignClient;
4+
import org.springframework.web.bind.annotation.GetMapping;
5+
6+
@FeignClient(name="extensionUserClient",url = "http://dev.nacos.cstest.lcap.codewave-test.163yun.com")
7+
public interface ExtensionUserClient {
8+
9+
@GetMapping("/rest/hello")
10+
String hello();
11+
}
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
package com.netease.lowcode.extension.feign;
2+
3+
import com.netease.lowcode.extension.service.ExtensionUserClientFallback;
4+
import org.springframework.cloud.openfeign.FeignClient;
5+
import org.springframework.web.bind.annotation.GetMapping;
6+
7+
@FeignClient(name = "extensionUserClientWithFallback",
8+
url = "http://dev.nacos.cstest.lcap.codewave-test.163yun.com",
9+
fallback = ExtensionUserClientFallback.class)
10+
public interface ExtensionUserClientWithFallback {
11+
12+
@GetMapping("/rest/hello")
13+
String hello();
14+
}
Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
package com.netease.lowcode.extension.service;
2+
3+
import com.netease.lowcode.extension.feign.ExtensionUserClientWithFallback;
4+
import org.springframework.stereotype.Component;
5+
6+
@Component
7+
public class ExtensionUserClientFallback implements ExtensionUserClientWithFallback {
8+
9+
@Override
10+
public String hello() {
11+
return "触发熔断";
12+
}
13+
}
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
package com.netease.lowcode.extension.service;
2+
3+
import com.netease.lowcode.core.annotation.NaslLogic;
4+
import com.netease.lowcode.extension.feign.ExtensionUserClient;
5+
import com.netease.lowcode.extension.feign.ExtensionUserClientWithFallback;
6+
import org.springframework.beans.factory.annotation.Autowired;
7+
import org.springframework.stereotype.Service;
8+
9+
@Service
10+
public class UserService {
11+
12+
private static ExtensionUserClient extensionUserClient;
13+
private static ExtensionUserClientWithFallback extensionUserClientWithFallback;
14+
15+
/**
16+
* 普通接口调用
17+
* 当服务不可用时直接异常
18+
*
19+
* @return
20+
*/
21+
@NaslLogic
22+
public static String hello() {
23+
return extensionUserClient.hello();
24+
}
25+
26+
/**
27+
* 开启熔断器的接口调用
28+
* 当调用服务不可用时将触发熔断降级
29+
*
30+
* @return
31+
*/
32+
@NaslLogic
33+
public static String helloWithFallback() {
34+
return extensionUserClientWithFallback.hello();
35+
}
36+
37+
@Autowired
38+
public void setUserClient(ExtensionUserClient extensionUserClient) {
39+
UserService.extensionUserClient = extensionUserClient;
40+
}
41+
@Autowired
42+
public void setExtensionUserClientWithFallback(ExtensionUserClientWithFallback extensionUserClientWithFallback){
43+
UserService.extensionUserClientWithFallback = extensionUserClientWithFallback;
44+
}
45+
}
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
2+
com.netease.lowcode.extension.OpenFeignConfig,\
3+
com.netease.lowcode.extension.OpenFeignAutoScan
4+
org.springframework.boot.env.EnvironmentPostProcessor=\
5+
com.netease.lowcode.extension.OpenFeignEnvironmentPostProcessor

0 commit comments

Comments
 (0)