1
0
mirror of https://gitee.com/mirrors/Spring-Cloud-Alibaba.git synced 2021-06-26 13:25:11 +08:00

Polish alibaba/spring-cloud-alibaba#1369 : [Feature] Synchronizing source code to Spring Cloud Alibaba greenwich branch

This commit is contained in:
mercyblitz 2020-04-14 18:30:59 +08:00
parent 4b6e1018cb
commit 0f05d78c37
74 changed files with 771 additions and 194 deletions

2
mvnw vendored
View File

@ -227,7 +227,7 @@ export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
echo "Running version check" echo "Running version check"
VERSION=$( sed '\!<parent!,\!</parent!d' `dirname $0`/pom.xml | grep '<version' | head -1 | sed -e 's/.*<version>//' -e 's!</version>.*$!!' ) VERSION=$( sed '\!<parent!,\!</parent!d' `dirname $0`/pom.xml | grep '<revision' | head -1 | sed -e 's/.*<revision>//' -e 's!</revision>.*$!!' )
echo "The found version is [${VERSION}]" echo "The found version is [${VERSION}]"
if echo $VERSION | egrep -q 'M|RC'; then if echo $VERSION | egrep -q 'M|RC'; then

113
pom.xml
View File

@ -8,17 +8,17 @@
<parent> <parent>
<groupId>org.springframework.cloud</groupId> <groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-build</artifactId> <artifactId>spring-cloud-build</artifactId>
<version>2.1.10.RELEASE</version> <version>2.1.11.RELEASE</version>
<relativePath/> <relativePath/>
</parent> </parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba</artifactId> <artifactId>spring-cloud-alibaba</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<name>Spring Cloud Alibaba</name> <name>Spring Cloud Alibaba</name>
<description>Spring Cloud Alibaba</description> <description>Spring Cloud Alibaba</description>
<url>https://github.com/alibaba/spring-cloud-alibaba</url> <url>https://github.com/alibaba/spring-cloud-alibaba/tree/greenwich</url>
<licenses> <licenses>
<license> <license>
@ -69,12 +69,22 @@
<name>yunzheng</name> <name>yunzheng</name>
<email>yunzheng1228@gmail.com</email> <email>yunzheng1228@gmail.com</email>
</developer> </developer>
<developer>
<id>theonefx</id>
<name>theonefx</name>
<email>chenxilzx1@gmail.com</email>
<organization>Alibaba</organization>
<url>https://github.com/theonefx</url>
</developer>
</developers> </developers>
<properties> <properties>
<!-- Project revision -->
<revision>2.1.2.RELEASE</revision>
<!-- Dependency Versions --> <!-- Dependency Versions -->
<spring-cloud-commons.version>2.1.5.RELEASE</spring-cloud-commons.version> <spring-cloud-commons.version>2.1.5.RELEASE</spring-cloud-commons.version>
<spring-cloud-config.version>2.1.6.RELEASE</spring-cloud-config.version> <spring-cloud-config.version>2.1.7.RELEASE</spring-cloud-config.version>
<spring-cloud-consul.version>2.1.5.RELEASE</spring-cloud-consul.version> <spring-cloud-consul.version>2.1.5.RELEASE</spring-cloud-consul.version>
<spring-cloud-gateway.version>2.1.5.RELEASE</spring-cloud-gateway.version> <spring-cloud-gateway.version>2.1.5.RELEASE</spring-cloud-gateway.version>
<spring-cloud-netflix.version>2.1.5.RELEASE</spring-cloud-netflix.version> <spring-cloud-netflix.version>2.1.5.RELEASE</spring-cloud-netflix.version>
@ -88,7 +98,7 @@
<slf4j-api.version>1.7.25</slf4j-api.version> <slf4j-api.version>1.7.25</slf4j-api.version>
<!-- Apache Dubbo --> <!-- Apache Dubbo -->
<dubbo.version>2.7.4.1</dubbo.version> <dubbo.version>2.7.6</dubbo.version>
<curator.version>4.0.1</curator.version> <curator.version>4.0.1</curator.version>
<!-- Apache RocketMQ --> <!-- Apache RocketMQ -->
@ -100,6 +110,10 @@
<maven-surefire-plugin.version>2.21.0</maven-surefire-plugin.version> <maven-surefire-plugin.version>2.21.0</maven-surefire-plugin.version>
<gmavenplus-plugin.version>1.6</gmavenplus-plugin.version> <gmavenplus-plugin.version>1.6</gmavenplus-plugin.version>
<jacoco.version>0.8.3</jacoco.version> <jacoco.version>0.8.3</jacoco.version>
<maven-source-plugin.version>2.2.1</maven-source-plugin.version>
<maven-javadoc-plugin.version>3.1.1</maven-javadoc-plugin.version>
<maven-gpg-plugin.version>1.6</maven-gpg-plugin.version>
<flatten-maven-plugin.version>1.1.0</flatten-maven-plugin.version>
</properties> </properties>
<modules> <modules>
@ -304,7 +318,7 @@
</goals> </goals>
<configuration> <configuration>
<!-- Checkstyle rules inherited from spring-cloud-build --> <!-- Checkstyle rules inherited from spring-cloud-build -->
<suppressionsLocation>eclipse/checkstyle-suppressions.xml</suppressionsLocation> <suppressionsLocation>${session.executionRootDirectory}/eclipse/checkstyle-suppressions.xml</suppressionsLocation>
<includeTestSourceDirectory>true</includeTestSourceDirectory> <includeTestSourceDirectory>true</includeTestSourceDirectory>
<consoleOutput>true</consoleOutput> <consoleOutput>true</consoleOutput>
<failsOnError>true</failsOnError> <failsOnError>true</failsOnError>
@ -411,6 +425,93 @@
</pluginRepositories> </pluginRepositories>
</profile> </profile>
<profile>
<id>release</id>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>${maven-source-plugin.version}</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-javadoc-plugin</artifactId>
<version>${maven-javadoc-plugin.version}</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-gpg-plugin</artifactId>
<version>${maven-gpg-plugin.version}</version>
<executions>
<execution>
<phase>verify</phase>
<goals>
<goal>sign</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>flatten-maven-plugin</artifactId>
<version>${flatten-maven-plugin.version}</version>
<configuration>
<updatePomFile>true</updatePomFile>
<flattenMode>resolveCiFriendliesOnly</flattenMode>
</configuration>
<executions>
<execution>
<id>flatten</id>
<phase>process-resources</phase>
<goals>
<goal>flatten</goal>
</goals>
</execution>
<execution>
<id>flatten.clean</id>
<phase>clean</phase>
<goals>
<goal>clean</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<distributionManagement>
<snapshotRepository>
<id>sonatype-nexus-snapshots</id>
<name>Sonatype Nexus Snapshots</name>
<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
</snapshotRepository>
<repository>
<id>sonatype-nexus-staging</id>
<name>Nexus Release Repository</name>
<url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
</repository>
</distributionManagement>
</profile>
</profiles> </profiles>

View File

@ -8,7 +8,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba</artifactId> <artifactId>spring-cloud-alibaba</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -4,20 +4,23 @@
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<artifactId>spring-cloud-dependencies-parent</artifactId>
<groupId>org.springframework.cloud</groupId> <groupId>org.springframework.cloud</groupId>
<version>2.2.0.RELEASE</version> <artifactId>spring-cloud-dependencies-parent</artifactId>
<version>2.1.11.RELEASE</version>
<relativePath/> <relativePath/>
</parent> </parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId> <artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<name>Spring Cloud Alibaba Dependencies</name> <name>Spring Cloud Alibaba Dependencies</name>
<description>Spring Cloud Alibaba Dependencies</description> <description>Spring Cloud Alibaba Dependencies</description>
<properties> <properties>
<!-- Project revision -->
<revision>2.1.2.RELEASE</revision>
<sentinel.version>1.7.1</sentinel.version> <sentinel.version>1.7.1</sentinel.version>
<oss.version>3.1.0</oss.version> <oss.version>3.1.0</oss.version>
<seata.version>1.1.0</seata.version> <seata.version>1.1.0</seata.version>
@ -32,7 +35,13 @@
<aliyun.java.sdk.dysmsapi>1.1.0</aliyun.java.sdk.dysmsapi> <aliyun.java.sdk.dysmsapi>1.1.0</aliyun.java.sdk.dysmsapi>
<aliyun.sdk.mns>1.1.8.6</aliyun.sdk.mns> <aliyun.sdk.mns>1.1.8.6</aliyun.sdk.mns>
<aliyun.java.sdk.dyvmsapi>1.1.1</aliyun.java.sdk.dyvmsapi> <aliyun.java.sdk.dyvmsapi>1.1.1</aliyun.java.sdk.dyvmsapi>
<spring.context.support.version>1.0.5</spring.context.support.version> <spring.context.support.version>1.0.6</spring.context.support.version>
<!-- Maven Plugin Versions -->
<maven-source-plugin.version>2.2.1</maven-source-plugin.version>
<maven-javadoc-plugin.version>3.1.1</maven-javadoc-plugin.version>
<maven-gpg-plugin.version>1.6</maven-gpg-plugin.version>
<flatten-maven-plugin.version>1.1.0</flatten-maven-plugin.version>
</properties> </properties>
<dependencyManagement> <dependencyManagement>
@ -93,6 +102,12 @@
<version>${sentinel.version}</version> <version>${sentinel.version}</version>
</dependency> </dependency>
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-datasource-consul</artifactId>
<version>${sentinel.version}</version>
</dependency>
<dependency> <dependency>
<groupId>com.alibaba.csp</groupId> <groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-web-servlet</artifactId> <artifactId>sentinel-web-servlet</artifactId>
@ -318,5 +333,91 @@
</pluginRepositories> </pluginRepositories>
</profile> </profile>
<profile>
<id>release</id>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>${maven-source-plugin.version}</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-javadoc-plugin</artifactId>
<version>${maven-javadoc-plugin.version}</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-gpg-plugin</artifactId>
<version>${maven-gpg-plugin.version}</version>
<executions>
<execution>
<phase>verify</phase>
<goals>
<goal>sign</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>flatten-maven-plugin</artifactId>
<version>${flatten-maven-plugin.version}</version>
<configuration>
<updatePomFile>true</updatePomFile>
<flattenMode>resolveCiFriendliesOnly</flattenMode>
</configuration>
<executions>
<execution>
<id>flatten</id>
<phase>process-resources</phase>
<goals>
<goal>flatten</goal>
</goals>
</execution>
<execution>
<id>flatten.clean</id>
<phase>clean</phase>
<goals>
<goal>clean</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<distributionManagement>
<snapshotRepository>
<id>sonatype-nexus-snapshots</id>
<name>Sonatype Nexus Snapshots</name>
<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
</snapshotRepository>
<repository>
<id>sonatype-nexus-staging</id>
<name>Nexus Release Repository</name>
<url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
</repository>
</distributionManagement>
</profile>
</profiles> </profiles>
</project> </project>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba</artifactId> <artifactId>spring-cloud-alibaba</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

View File

@ -10,7 +10,7 @@ Spring Cloud Alibaba BOM 包含了它所使用的所有依赖的版本。
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId> <artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>2.1.2.RELEASE</version>
<type>pom</type> <type>pom</type>
<scope>import</scope> <scope>import</scope>
</dependency> </dependency>

View File

@ -8,7 +8,7 @@ If youre a Maven Central user, add our BOM to your pom.xml <dependencyManagem
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId> <artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>2.1.2.RELEASE</version>
<type>pom</type> <type>pom</type>
<scope>import</scope> <scope>import</scope>
</dependency> </dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-config-example</artifactId> <artifactId>nacos-config-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Config Example</name>
<description>Example demonstrating how to use nacos config</description> <description>Example demonstrating how to use nacos config</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-discovery-example</artifactId> <artifactId>nacos-discovery-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-consumer-example</artifactId> <artifactId>nacos-discovery-consumer-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery Consumer Example</name>
<description>Example demonstrating how to use nacos discovery</description> <description>Example demonstrating how to use nacos discovery</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-discovery-example</artifactId> <artifactId>nacos-discovery-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-provider-example</artifactId> <artifactId>nacos-discovery-provider-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery Provider Example</name>
<description>Example demonstrating how to use nacos discovery</description> <description>Example demonstrating how to use nacos discovery</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-discovery-example</artifactId> <artifactId>nacos-discovery-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-spring-cloud-config-client-example</artifactId> <artifactId>nacos-discovery-spring-cloud-config-client-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery x Config Client Example</name>
<description>Example demonstrating how to use nacos discovery</description> <description>Example demonstrating how to use nacos discovery</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-discovery-example</artifactId> <artifactId>nacos-discovery-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-spring-cloud-config-server-example</artifactId> <artifactId>nacos-discovery-spring-cloud-config-server-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery x Config Server Example</name>
<description>Example demonstrating how to use nacos discovery</description> <description>Example demonstrating how to use nacos discovery</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-discovery-example</artifactId> <artifactId>nacos-discovery-example</artifactId>
<packaging>pom</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery Examples</name>
<description>Example demonstrating how to use nacos discovery</description> <description>Example demonstrating how to use nacos discovery</description>
<packaging>pom</packaging>
<modules> <modules>
<module>nacos-discovery-consumer-example</module> <module>nacos-discovery-consumer-example</module>

View File

@ -5,15 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-gateway-example</artifactId> <artifactId>nacos-gateway-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-gateway-discovery-example</artifactId> <artifactId>nacos-gateway-discovery-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery x Gateway Example</name>
<description>Example demonstrating how to use gateway with nacos</description> <description>Example demonstrating how to use gateway with nacos</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>nacos-gateway-example</artifactId> <artifactId>nacos-gateway-example</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-gateway-provider-example</artifactId> <artifactId>nacos-gateway-provider-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery x Gateway - Provider Example</name>
<description>Example demonstrating how to use gateway with nacos</description> <description>Example demonstrating how to use gateway with nacos</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>nacos-gateway-example</artifactId> <artifactId>nacos-gateway-example</artifactId>
<packaging>pom</packaging> <name>Spring Cloud Starter Alibaba Nacos Discovery x Gateway Examples</name>
<description>Example demonstrating how to use gateway with nacos</description> <description>Example demonstrating how to use gateway with nacos</description>
<packaging>pom</packaging>
<modules> <modules>
<module>nacos-gateway-discovery-example</module> <module>nacos-gateway-discovery-example</module>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba</artifactId> <artifactId>spring-cloud-alibaba</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>rocketmq-consume-example</artifactId> <artifactId>rocketmq-consume-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Stream Alibaba RocketMQ Consume Example</name>
<description>Example demonstrating how to use rocketmq consume</description> <description>Example demonstrating how to use rocketmq consume</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>rocketmq-produce-example</artifactId> <artifactId>rocketmq-produce-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Stream Alibaba RocketMQ Produce Example</name>
<description>Example demonstrating how to use rocketmq produce</description> <description>Example demonstrating how to use rocketmq produce</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,12 +5,15 @@
<parent> <parent>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>account-service</artifactId> <artifactId>account-service</artifactId>
<name>Spring Cloud Starter Alibaba Seata Example - Account Service</name>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>

View File

@ -5,12 +5,15 @@
<parent> <parent>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>business-service</artifactId> <artifactId>business-service</artifactId>
<name>Spring Cloud Starter Alibaba Seata Example - Business Service</name>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>

View File

@ -5,12 +5,15 @@
<parent> <parent>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>order-service</artifactId> <artifactId>order-service</artifactId>
<name>Spring Cloud Starter Alibaba Seata Example - Business Service</name>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>

View File

@ -5,11 +5,13 @@
<parent> <parent>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>storage-service</artifactId> <artifactId>storage-service</artifactId>
<name>Spring Cloud Starter Alibaba Seata Example - Storage Service</name>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -5,15 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-core-example</artifactId> <artifactId>sentinel-core-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel Core Example</name>
<description>Example demonstrating how to use sentinel</description> <description>Example demonstrating how to use sentinel</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -5,14 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../../pom.xml</relativePath> <relativePath>../../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-dubbo-api</artifactId> <artifactId>sentinel-dubbo-api</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Dubbo - API</name>
<description>api for sentinel dubbo example</description> <description>api for sentinel dubbo example</description>
<packaging>jar</packaging>
<build> <build>
<plugins> <plugins>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../../pom.xml</relativePath> <relativePath>../../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-dubbo-consumer-example</artifactId> <artifactId>sentinel-dubbo-consumer-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Dubbo - Consumer Example</name>
<description>Example demonstrating how to use sentinel with dubbo</description> <description>Example demonstrating how to use sentinel with dubbo</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
@ -31,7 +30,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>sentinel-dubbo-api</artifactId> <artifactId>sentinel-dubbo-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<dependency> <dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../../pom.xml</relativePath> <relativePath>../../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-dubbo-provider-example</artifactId> <artifactId>sentinel-dubbo-provider-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Dubbo - Provider Example</name>
<description>Example demonstrating how to use sentinel with dubbo</description> <description>Example demonstrating how to use sentinel with dubbo</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
@ -31,7 +30,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>sentinel-dubbo-api</artifactId> <artifactId>sentinel-dubbo-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<dependency> <dependency>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../../pom.xml</relativePath> <relativePath>../../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-feign-consumer-example</artifactId> <artifactId>sentinel-feign-consumer-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Feign - Consumer Example</name>
<description>Example demonstrating how to use sentinel with feign</description> <description>Example demonstrating how to use sentinel with feign</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -6,6 +6,8 @@ spring:
name: service-consumer name: service-consumer
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
server-addr: 127.0.0.1:8848 server-addr: 127.0.0.1:8848

View File

@ -5,15 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../../pom.xml</relativePath> <relativePath>../../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-feign-provider-example</artifactId> <artifactId>sentinel-feign-provider-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Feign - Provider Example</name>
<description>Example demonstrating how to use sentinel with feign</description> <description>Example demonstrating how to use sentinel with feign</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -6,6 +6,8 @@ spring:
name: service-provider name: service-provider
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
server-addr: 127.0.0.1:8848 server-addr: 127.0.0.1:8848

View File

@ -5,15 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-spring-cloud-gateway-example</artifactId> <artifactId>sentinel-spring-cloud-gateway-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Gateway Example</name>
<description>Example demonstrating how to use sentinel with spring cloud gateway</description> <description>Example demonstrating how to use sentinel with spring cloud gateway</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -5,16 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-webflux-example</artifactId> <artifactId>sentinel-webflux-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x WebFlux Example</name>
<description>Example demonstrating how to use sentinel with webflux</description> <description>Example demonstrating how to use sentinel with webflux</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -5,15 +5,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>sentinel-zuul-example</artifactId> <artifactId>sentinel-zuul-example</artifactId>
<packaging>jar</packaging> <name>Spring Cloud Starter Alibaba Sentinel x Zuul Example</name>
<description>Example demonstrating how to use sentinel with zuul</description> <description>Example demonstrating how to use sentinel with zuul</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -5,14 +5,14 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<name>Spring Cloud Alibaba Dubbo Examples</name> <name>Spring Cloud Alibaba Dubbo Examples</name>
<packaging>pom</packaging> <packaging>pom</packaging>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -13,14 +13,14 @@
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-client-sample</artifactId> <artifactId>spring-cloud-dubbo-client-sample</artifactId>
<name>Spring Cloud Dubbo Client Sample</name> <name>Spring Cloud Dubbo Client Sample</name>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<dependencies> <dependencies>
<!-- Sample API --> <!-- Sample API -->
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Spring Boot dependencies --> <!-- Spring Boot dependencies -->

View File

@ -1,6 +1,4 @@
dubbo: dubbo:
registry:
address: spring-cloud://localhost
cloud: cloud:
subscribed-services: spring-cloud-alibaba-dubbo-server subscribed-services: spring-cloud-alibaba-dubbo-server
@ -11,5 +9,7 @@ spring:
allow-bean-definition-overriding: true allow-bean-definition-overriding: true
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
server-addr: 127.0.0.1:8848 server-addr: 127.0.0.1:8848

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -41,7 +41,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Dubbo Spring Cloud Starter --> <!-- Dubbo Spring Cloud Starter -->

View File

@ -30,6 +30,8 @@ spring:
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
enabled: true enabled: true
register-enabled: true register-enabled: true

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -32,7 +32,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Dubbo Spring Cloud Starter --> <!-- Dubbo Spring Cloud Starter -->

View File

@ -27,6 +27,8 @@ spring:
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
enabled: true enabled: true
register-enabled: true register-enabled: true

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -30,7 +30,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Dubbo Spring Cloud Starter --> <!-- Dubbo Spring Cloud Starter -->

View File

@ -27,6 +27,8 @@ spring:
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
enabled: true enabled: true
register-enabled: true register-enabled: true

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
@ -14,7 +14,7 @@
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-server-sample</artifactId> <artifactId>spring-cloud-dubbo-server-sample</artifactId>
<name>Spring Cloud Dubbo Server Sample</name> <name>Spring Cloud Dubbo Server Sample</name>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<dependencies> <dependencies>
@ -22,7 +22,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Spring Boot dependencies --> <!-- Spring Boot dependencies -->

View File

@ -4,8 +4,6 @@ dubbo:
protocol: protocol:
name: dubbo name: dubbo
port: -1 port: -1
registry:
address: spring-cloud://localhost
spring: spring:
application: application:
@ -14,5 +12,7 @@ spring:
allow-bean-definition-overriding: true allow-bean-definition-overriding: true
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
server-addr: 127.0.0.1:8848 server-addr: 127.0.0.1:8848

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dubbo-examples</artifactId> <artifactId>spring-cloud-alibaba-dubbo-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
@ -29,7 +29,7 @@
<dependency> <dependency>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-dubbo-sample-api</artifactId> <artifactId>spring-cloud-dubbo-sample-api</artifactId>
<version>${project.version}</version> <version>${revision}</version>
</dependency> </dependency>
<!-- Dubbo Spring Cloud Starter --> <!-- Dubbo Spring Cloud Starter -->

View File

@ -30,6 +30,8 @@ spring:
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
enabled: true enabled: true
register-enabled: true register-enabled: true

View File

@ -4,13 +4,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>spring-cloud-alibaba-sidecar-consul-example</artifactId> <artifactId>spring-cloud-alibaba-sidecar-consul-example</artifactId>
<name>Spring Cloud Starter Alibaba Sidecar x Consul Example</name>
<description>Example demonstrating how to use Spring Cloud Alibaba Sidecar with consul</description> <description>Example demonstrating how to use Spring Cloud Alibaba Sidecar with consul</description>
<packaging>jar</packaging>
<dependencies> <dependencies>
<dependency> <dependency>

View File

@ -4,13 +4,15 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../../pom.xml</relativePath> <relativePath>../../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>spring-cloud-alibaba-sidecar-nacos-example</artifactId> <artifactId>spring-cloud-alibaba-sidecar-nacos-example</artifactId>
<name>Spring Cloud Starter Alibaba Sidecar x Nacos Example</name>
<description>Example demonstrating how to use Spring Cloud Alibaba Sidecar with nacos</description> <description>Example demonstrating how to use Spring Cloud Alibaba Sidecar with nacos</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -3,6 +3,8 @@ server:
spring: spring:
cloud: cloud:
nacos: nacos:
username: nacos
password: nacos
discovery: discovery:
server-addr: localhost:8848 server-addr: localhost:8848
gateway: gateway:

View File

@ -5,13 +5,15 @@
<parent> <parent>
<artifactId>spring-cloud-alibaba-examples</artifactId> <artifactId>spring-cloud-alibaba-examples</artifactId>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>spring-cloud-bus-rocketmq-example</artifactId> <artifactId>spring-cloud-bus-rocketmq-example</artifactId>
<name>Spring Cloud Bus RocketMQ Example</name> <name>Spring Cloud Starter Bus Alibaba RocketMQ Example</name>
<description>Example demonstrating how to use Spring Cloud Bus RocketMQ</description>
<packaging>jar</packaging>
<dependencies> <dependencies>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba</artifactId> <artifactId>spring-cloud-alibaba</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>
@ -83,6 +83,12 @@
<optional>true</optional> <optional>true</optional>
</dependency> </dependency>
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-datasource-consul</artifactId>
<optional>true</optional>
</dependency>
<dependency> <dependency>
<groupId>com.fasterxml.jackson.core</groupId> <groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId> <artifactId>jackson-databind</artifactId>

View File

@ -0,0 +1,97 @@
/*
* Copyright 2013-2018 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
*
* https://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 com.alibaba.cloud.sentinel.datasource.config;
import com.alibaba.cloud.sentinel.datasource.factorybean.ConsulDataSourceFactoryBean;
import org.springframework.util.StringUtils;
/**
* Consul Properties class Using by {@link DataSourcePropertiesConfiguration} and
* {@link ConsulDataSourceFactoryBean}.
*
* @author <a href="mailto:mengjindc@gmail.com">mengjin</a>
*/
public class ConsulDataSourceProperties extends AbstractDataSourceProperties {
public ConsulDataSourceProperties() {
super(ConsulDataSourceFactoryBean.class.getName());
}
/**
* consul server host.
*/
private String host;
/**
* consul server port.
*/
private int port = 8500;
/**
* data key in Redis.
*/
private String ruleKey;
/**
* Request of query will hang until timeout (in second) or get updated value.
*/
private int waitTimeoutInSecond = 1;
@Override
public void preCheck(String dataSourceName) {
if (StringUtils.isEmpty(host)) {
throw new IllegalArgumentException("ConsulDataSource server-host is empty");
}
if (StringUtils.isEmpty(ruleKey)) {
throw new IllegalArgumentException(
"ConsulDataSource ruleKey can not be empty");
}
}
public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public int getPort() {
return port;
}
public void setPort(int port) {
this.port = port;
}
public String getRuleKey() {
return ruleKey;
}
public void setRuleKey(String ruleKey) {
this.ruleKey = ruleKey;
}
public int getWaitTimeoutInSecond() {
return waitTimeoutInSecond;
}
public void setWaitTimeoutInSecond(int waitTimeoutInSecond) {
this.waitTimeoutInSecond = waitTimeoutInSecond;
}
}

View File

@ -0,0 +1,91 @@
/*
* Copyright 2013-2018 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
*
* https://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 com.alibaba.cloud.sentinel.datasource.factorybean;
import com.alibaba.csp.sentinel.datasource.Converter;
import com.alibaba.csp.sentinel.datasource.consul.ConsulDataSource;
import org.springframework.beans.factory.FactoryBean;
/**
* A {@link FactoryBean} for creating {@link ConsulDataSource} instance.
*
* @author <a href="mailto:mengjindc@gmail.com">mengjin</a>
* @see ConsulDataSource
*/
public class ConsulDataSourceFactoryBean implements FactoryBean<ConsulDataSource> {
private String host;
private int port;
private String ruleKey;
private int waitTimeoutInSecond;
private Converter converter;
@Override
public ConsulDataSource getObject() throws Exception {
return new ConsulDataSource(host, port, ruleKey, waitTimeoutInSecond, converter);
}
@Override
public Class<?> getObjectType() {
return ConsulDataSource.class;
}
public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public int getPort() {
return port;
}
public void setPort(int port) {
this.port = port;
}
public String getRuleKey() {
return ruleKey;
}
public void setRuleKey(String ruleKey) {
this.ruleKey = ruleKey;
}
public int getWaitTimeoutInSecond() {
return waitTimeoutInSecond;
}
public void setWaitTimeoutInSecond(int waitTimeoutInSecond) {
this.waitTimeoutInSecond = waitTimeoutInSecond;
}
public Converter getConverter() {
return converter;
}
public void setConverter(Converter converter) {
this.converter = converter;
}
}

View File

@ -3,3 +3,4 @@ file =com.alibaba.csp.sentinel.datasource.FileRefreshableDataSource
apollo = com.alibaba.csp.sentinel.datasource.apollo.ApolloDataSource apollo = com.alibaba.csp.sentinel.datasource.apollo.ApolloDataSource
zk = com.alibaba.csp.sentinel.datasource.zookeeper.ZookeeperDataSource zk = com.alibaba.csp.sentinel.datasource.zookeeper.ZookeeperDataSource
redis = com.alibaba.csp.sentinel.datasource.redis.RedisDataSource redis = com.alibaba.csp.sentinel.datasource.redis.RedisDataSource
consul = com.alibaba.csp.sentinel.datasource.consul.ConsulDataSource

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -16,23 +16,104 @@
package com.alibaba.cloud.seata.feign.hystrix; package com.alibaba.cloud.seata.feign.hystrix;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import com.netflix.hystrix.HystrixThreadPoolKey;
import com.netflix.hystrix.HystrixThreadPoolProperties;
import com.netflix.hystrix.strategy.HystrixPlugins; import com.netflix.hystrix.strategy.HystrixPlugins;
import com.netflix.hystrix.strategy.concurrency.HystrixConcurrencyStrategy; import com.netflix.hystrix.strategy.concurrency.HystrixConcurrencyStrategy;
import com.netflix.hystrix.strategy.concurrency.HystrixRequestVariable;
import com.netflix.hystrix.strategy.concurrency.HystrixRequestVariableLifecycle;
import com.netflix.hystrix.strategy.eventnotifier.HystrixEventNotifier;
import com.netflix.hystrix.strategy.executionhook.HystrixCommandExecutionHook;
import com.netflix.hystrix.strategy.metrics.HystrixMetricsPublisher;
import com.netflix.hystrix.strategy.properties.HystrixPropertiesStrategy;
import com.netflix.hystrix.strategy.properties.HystrixProperty;
import io.seata.core.context.RootContext; import io.seata.core.context.RootContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.context.request.RequestAttributes;
import org.springframework.web.context.request.RequestContextHolder;
/** /**
* @author xiaojing * @author xiaojing
*/ */
public class SeataHystrixConcurrencyStrategy extends HystrixConcurrencyStrategy { public class SeataHystrixConcurrencyStrategy extends HystrixConcurrencyStrategy {
private final Logger logger = LoggerFactory
.getLogger(SeataHystrixConcurrencyStrategy.class);
private HystrixConcurrencyStrategy delegate; private HystrixConcurrencyStrategy delegate;
public SeataHystrixConcurrencyStrategy() { public SeataHystrixConcurrencyStrategy() {
this.delegate = HystrixPlugins.getInstance().getConcurrencyStrategy(); try {
HystrixPlugins.reset(); this.delegate = HystrixPlugins.getInstance().getConcurrencyStrategy();
HystrixPlugins.getInstance().registerConcurrencyStrategy(this); if (this.delegate instanceof SeataHystrixConcurrencyStrategy) {
return;
}
HystrixCommandExecutionHook commandExecutionHook = HystrixPlugins
.getInstance().getCommandExecutionHook();
HystrixEventNotifier eventNotifier = HystrixPlugins.getInstance()
.getEventNotifier();
HystrixMetricsPublisher metricsPublisher = HystrixPlugins.getInstance()
.getMetricsPublisher();
HystrixPropertiesStrategy propertiesStrategy = HystrixPlugins.getInstance()
.getPropertiesStrategy();
logCurrentStateOfHystrixPlugins(eventNotifier, metricsPublisher,
propertiesStrategy);
HystrixPlugins.reset();
HystrixPlugins.getInstance().registerConcurrencyStrategy(this);
HystrixPlugins.getInstance()
.registerCommandExecutionHook(commandExecutionHook);
HystrixPlugins.getInstance().registerEventNotifier(eventNotifier);
HystrixPlugins.getInstance().registerMetricsPublisher(metricsPublisher);
HystrixPlugins.getInstance().registerPropertiesStrategy(propertiesStrategy);
}
catch (Exception ex) {
logger.error("Failed to register Seata Hystrix Concurrency Strategy", ex);
}
}
private void logCurrentStateOfHystrixPlugins(HystrixEventNotifier eventNotifier,
HystrixMetricsPublisher metricsPublisher,
HystrixPropertiesStrategy propertiesStrategy) {
if (logger.isDebugEnabled()) {
logger.debug("Current Hystrix plugins configuration is ["
+ "concurrencyStrategy [" + this.delegate + "]," + "eventNotifier ["
+ eventNotifier + "]," + "metricPublisher [" + metricsPublisher + "],"
+ "propertiesStrategy [" + propertiesStrategy + "]," + "]");
logger.debug("Registering Seata Hystrix Concurrency Strategy.");
}
}
@Override
public ThreadPoolExecutor getThreadPool(HystrixThreadPoolKey threadPoolKey,
HystrixProperty<Integer> corePoolSize,
HystrixProperty<Integer> maximumPoolSize,
HystrixProperty<Integer> keepAliveTime, TimeUnit unit,
BlockingQueue<Runnable> workQueue) {
return this.delegate.getThreadPool(threadPoolKey, corePoolSize, maximumPoolSize,
keepAliveTime, unit, workQueue);
}
@Override
public ThreadPoolExecutor getThreadPool(HystrixThreadPoolKey threadPoolKey,
HystrixThreadPoolProperties threadPoolProperties) {
return this.delegate.getThreadPool(threadPoolKey, threadPoolProperties);
}
@Override
public BlockingQueue<Runnable> getBlockingQueue(int maxQueueSize) {
return this.delegate.getBlockingQueue(maxQueueSize);
}
@Override
public <T> HystrixRequestVariable<T> getRequestVariable(
HystrixRequestVariableLifecycle<T> rv) {
return this.delegate.getRequestVariable(rv);
} }
@Override @Override
@ -52,7 +133,8 @@ public class SeataHystrixConcurrencyStrategy extends HystrixConcurrencyStrategy
return wrappedCallable; return wrappedCallable;
} }
return new SeataContextCallable<>(wrappedCallable); return new SeataContextCallable<>(wrappedCallable,
RequestContextHolder.getRequestAttributes());
} }
private static class SeataContextCallable<K> implements Callable<K> { private static class SeataContextCallable<K> implements Callable<K> {
@ -61,19 +143,24 @@ public class SeataHystrixConcurrencyStrategy extends HystrixConcurrencyStrategy
private final String xid; private final String xid;
SeataContextCallable(Callable<K> actual) { private final RequestAttributes requestAttributes;
SeataContextCallable(Callable<K> actual, RequestAttributes requestAttribute) {
this.actual = actual; this.actual = actual;
this.requestAttributes = requestAttribute;
this.xid = RootContext.getXID(); this.xid = RootContext.getXID();
} }
@Override @Override
public K call() throws Exception { public K call() throws Exception {
try { try {
RequestContextHolder.setRequestAttributes(requestAttributes);
RootContext.bind(xid); RootContext.bind(xid);
return actual.call(); return actual.call();
} }
finally { finally {
RootContext.unbind(); RootContext.unbind();
RequestContextHolder.resetRequestAttributes();
} }
} }

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -61,7 +61,7 @@ public class SentinelHealthIndicator extends AbstractHealthIndicator {
private SentinelProperties sentinelProperties; private SentinelProperties sentinelProperties;
public SentinelHealthIndicator(DefaultListableBeanFactory beanFactory, public SentinelHealthIndicator(DefaultListableBeanFactory beanFactory,
SentinelProperties sentinelProperties) { SentinelProperties sentinelProperties) {
this.beanFactory = beanFactory; this.beanFactory = beanFactory;
this.sentinelProperties = sentinelProperties; this.sentinelProperties = sentinelProperties;
} }
@ -74,7 +74,7 @@ public class SentinelHealthIndicator extends AbstractHealthIndicator {
// detail // detail
if (!sentinelProperties.isEnabled()) { if (!sentinelProperties.isEnabled()) {
detailMap.put("enabled", false); detailMap.put("enabled", false);
builder.up().withDetails(detailMap); withDetails(builder.up(), detailMap);
return; return;
} }
@ -139,11 +139,16 @@ public class SentinelHealthIndicator extends AbstractHealthIndicator {
// If Dashboard and DataSource are both OK, the health status is UP // If Dashboard and DataSource are both OK, the health status is UP
if (dashboardUp && dataSourceUp) { if (dashboardUp && dataSourceUp) {
builder.up().withDetails(detailMap); withDetails(builder.up(), detailMap);
} }
else { else {
builder.down().withDetails(detailMap); withDetails(builder.down(), detailMap);
} }
} }
private void withDetails(Health.Builder builder, Map<String, Object> detailMap) {
for (String key : detailMap.keySet()) {
builder.withDetail(key, detailMap.get(key));
}
}
} }

View File

@ -6,7 +6,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -6,7 +6,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -6,7 +6,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>

View File

@ -30,7 +30,7 @@ import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.openfeign.FeignClient; import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.client.RestTemplate; import org.springframework.web.client.RestTemplate;
import static org.apache.dubbo.rpc.cluster.Constants.DEFAULT_RETRIES; import static org.apache.dubbo.common.constants.CommonConstants.DEFAULT_RETRIES;
/** /**
* {@link DubboTransported @DubboTransported} annotation indicates that the traditional * {@link DubboTransported @DubboTransported} annotation indicates that the traditional

View File

@ -29,7 +29,7 @@ import org.springframework.core.type.AnnotatedTypeMetadata;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
import static com.alibaba.cloud.dubbo.registry.SpringCloudRegistryFactory.PROTOCOL; import static com.alibaba.cloud.dubbo.registry.SpringCloudRegistryFactory.PROTOCOL;
import static org.apache.dubbo.config.spring.util.PropertySourcesUtils.getPrefixedProperties; import static com.alibaba.spring.util.PropertySourcesUtils.getSubProperties;
/** /**
* Missing {@link SpringCloudRegistry} Property {@link Condition}. * Missing {@link SpringCloudRegistry} Property {@link Condition}.
@ -61,7 +61,7 @@ public class MissingSpringCloudRegistryConfigPropertyCondition
"'spring-cloud' protocol was found from 'dubbo.registry.address'"); "'spring-cloud' protocol was found from 'dubbo.registry.address'");
} }
Map<String, Object> properties = getPrefixedProperties( Map<String, Object> properties = getSubProperties(
environment.getPropertySources(), "dubbo.registries."); environment.getPropertySources(), "dubbo.registries.");
boolean found = properties.entrySet().stream().anyMatch(entry -> { boolean found = properties.entrySet().stream().anyMatch(entry -> {

View File

@ -35,7 +35,7 @@ import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
import static org.apache.dubbo.common.constants.CommonConstants.DEFAULT_PROTOCOL; import static org.apache.dubbo.common.constants.CommonConstants.DEFAULT_PROTOCOL;
import static org.apache.dubbo.config.spring.util.PropertySourcesUtils.getPrefixedProperties; import static com.alibaba.spring.util.PropertySourcesUtils.getSubProperties;
/** /**
* Dubbo {@link WebApplicationType#NONE Non-Web Application} * Dubbo {@link WebApplicationType#NONE Non-Web Application}
@ -149,7 +149,7 @@ public class DubboNonWebApplicationEnvironmentPostProcessor
String restPort = null; String restPort = null;
Map<String, Object> subProperties = getPrefixedProperties( Map<String, Object> subProperties = getSubProperties(
environment.getPropertySources(), PROTOCOLS_PROPERTY_NAME_PREFIX); environment.getPropertySources(), PROTOCOLS_PROPERTY_NAME_PREFIX);
Properties properties = new Properties(); Properties properties = new Properties();

View File

@ -22,6 +22,7 @@ import java.util.LinkedHashSet;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Objects; import java.util.Objects;
import java.util.Optional;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.Stream; import java.util.stream.Stream;
@ -189,7 +190,7 @@ public class DubboServiceMetadataRepository
// // // //
private static <K, V> Map<K, V> getMap(Map<String, Map<K, V>> repository, private static <K, V> Map<K, V> getMap(Map<String, Map<K, V>> repository,
String key) { String key) {
return getOrDefault(repository, key, newHashMap()); return getOrDefault(repository, key, newHashMap());
} }
@ -289,9 +290,11 @@ public class DubboServiceMetadataRepository
serviceName); serviceName);
} }
initSubscribedDubboMetadataService(serviceName); if (initSubscribedDubboMetadataService(serviceName)) {
// mark this service name having been initialized // mark this service name having been initialized
initializedServices.add(serviceName); initializedServices.add(serviceName);
}
} }
} }
} }
@ -300,12 +303,19 @@ public class DubboServiceMetadataRepository
* Remove the metadata and initialized service of Dubbo Services if no there is no * Remove the metadata and initialized service of Dubbo Services if no there is no
* service instance. * service instance.
* @param serviceName the service name * @param serviceName the service name
* @param url the meta service url
*/ */
public void removeMetadataAndInitializedService(String serviceName) { public void removeMetadataAndInitializedService(String serviceName, URL url) {
synchronized (monitor) { synchronized (monitor) {
initializedServices.remove(serviceName); initializedServices.remove(serviceName);
dubboRestServiceMetadataRepository.remove(serviceName); dubboRestServiceMetadataRepository.remove(serviceName);
subscribedDubboMetadataServiceURLs.remove(serviceName); // fix #1260 if the subscribedDubboMetadataServiceURLs removed failold meta
// information will be retained
if (DubboMetadataService.class.getName().equals(url.getServiceInterface())) {
String serviceKey = url.getServiceKey();
subscribedDubboMetadataServiceURLs.remove(serviceKey);
}
} }
} }
@ -333,7 +343,7 @@ public class DubboServiceMetadataRepository
} }
private void addDubboMetadataServiceURLsMetadata(Map<String, String> metadata, private void addDubboMetadataServiceURLsMetadata(Map<String, String> metadata,
List<URL> dubboMetadataServiceURLs) { List<URL> dubboMetadataServiceURLs) {
String dubboMetadataServiceURLsJSON = jsonUtils.toJSON(dubboMetadataServiceURLs); String dubboMetadataServiceURLsJSON = jsonUtils.toJSON(dubboMetadataServiceURLs);
metadata.put(DUBBO_METADATA_SERVICE_URLS_PROPERTY_NAME, metadata.put(DUBBO_METADATA_SERVICE_URLS_PROPERTY_NAME,
dubboMetadataServiceURLsJSON); dubboMetadataServiceURLsJSON);
@ -380,7 +390,7 @@ public class DubboServiceMetadataRepository
} }
public List<URL> findSubscribedDubboMetadataServiceURLs(String serviceName, public List<URL> findSubscribedDubboMetadataServiceURLs(String serviceName,
String group, String version, String protocol) { String group, String version, String protocol) {
String serviceKey = URL.buildKey(serviceName, group, version); String serviceKey = URL.buildKey(serviceName, group, version);
List<URL> urls = null; List<URL> urls = null;
@ -393,9 +403,11 @@ public class DubboServiceMetadataRepository
return emptyList(); return emptyList();
} }
return hasText(protocol) ? urls.stream() return hasText(protocol)
? urls.stream()
.filter(url -> url.getProtocol().equalsIgnoreCase(protocol)) .filter(url -> url.getProtocol().equalsIgnoreCase(protocol))
.collect(Collectors.toList()) : unmodifiableList(urls); .collect(Collectors.toList())
: unmodifiableList(urls);
} }
/** /**
@ -460,7 +472,7 @@ public class DubboServiceMetadataRepository
} }
public Integer getDubboProtocolPort(ServiceInstance serviceInstance, public Integer getDubboProtocolPort(ServiceInstance serviceInstance,
String protocol) { String protocol) {
String protocolProperty = getDubboProtocolPropertyName(protocol); String protocolProperty = getDubboProtocolPropertyName(protocol);
Map<String, String> metadata = serviceInstance.getMetadata(); Map<String, String> metadata = serviceInstance.getMetadata();
String protocolPort = metadata.get(protocolProperty); String protocolPort = metadata.get(protocolProperty);
@ -468,7 +480,7 @@ public class DubboServiceMetadataRepository
} }
public List<URL> getExportedURLs(String serviceInterface, String group, public List<URL> getExportedURLs(String serviceInterface, String group,
String version) { String version) {
String serviceKey = URL.buildKey(serviceInterface, group, version); String serviceKey = URL.buildKey(serviceInterface, group, version);
return allExportedURLs.getOrDefault(serviceKey, Collections.emptyList()); return allExportedURLs.getOrDefault(serviceKey, Collections.emptyList());
} }
@ -525,7 +537,7 @@ public class DubboServiceMetadataRepository
* @return {@link DubboRestServiceMetadata} if matched, or <code>null</code> * @return {@link DubboRestServiceMetadata} if matched, or <code>null</code>
*/ */
public DubboRestServiceMetadata get(String serviceName, public DubboRestServiceMetadata get(String serviceName,
RequestMetadata requestMetadata) { RequestMetadata requestMetadata) {
return match(dubboRestServiceMetadataRepository, serviceName, requestMetadata); return match(dubboRestServiceMetadataRepository, serviceName, requestMetadata);
} }
@ -542,7 +554,7 @@ public class DubboServiceMetadataRepository
} }
private <T> T match(Map<String, Map<RequestMetadataMatcher, T>> repository, private <T> T match(Map<String, Map<RequestMetadataMatcher, T>> repository,
String serviceName, RequestMetadata requestMetadata) { String serviceName, RequestMetadata requestMetadata) {
Map<RequestMetadataMatcher, T> map = repository.get(serviceName); Map<RequestMetadataMatcher, T> map = repository.get(serviceName);
@ -614,24 +626,47 @@ public class DubboServiceMetadataRepository
subscribedServices.remove(currentApplicationName); subscribedServices.remove(currentApplicationName);
} }
protected void initSubscribedDubboMetadataService(String serviceName) { protected Boolean initSubscribedDubboMetadataService(String serviceName) {
metadataServiceInstanceSelector.choose(discoveryClient.getInstances(serviceName)) // this need to judge whether the initialization is successful or not. The failed
.map(this::getDubboMetadataServiceURLs) // initialization will not change the initializedServices
.ifPresent(dubboMetadataServiceURLs -> { Optional<ServiceInstance> optionalServiceInstance = metadataServiceInstanceSelector
dubboMetadataServiceURLs.forEach(dubboMetadataServiceURL -> { .choose(discoveryClient.getInstances(serviceName));
try { if (!((Optional) optionalServiceInstance).isPresent()) {
initSubscribedDubboMetadataServiceURL( return false;
dubboMetadataServiceURL); }
initDubboMetadataServiceProxy(dubboMetadataServiceURL); ServiceInstance serviceInstance = optionalServiceInstance.get();
} if (null == serviceInstance) {
catch (Throwable e) { return false;
if (logger.isErrorEnabled()) { }
logger.error(e.getMessage(), e); List<URL> dubboMetadataServiceURLs = getDubboMetadataServiceURLs(serviceInstance);
} if (dubboMetadataServiceURLs.isEmpty()) {
} return false;
}); }
}); for (URL dubboMetadataServiceURL : dubboMetadataServiceURLs) {
try {
initSubscribedDubboMetadataServiceURL(dubboMetadataServiceURL);
DubboMetadataService dubboMetadataService = dubboMetadataConfigServiceProxy
.getProxy(serviceName);
if (dubboMetadataService == null) {
dubboMetadataService = initDubboMetadataServiceProxy(
dubboMetadataServiceURL);
}
if (dubboMetadataService == null) {
removeMetadataAndInitializedService(serviceName,
dubboMetadataServiceURL);
return false;
}
}
catch (Throwable e) {
if (logger.isErrorEnabled()) {
logger.error(e.getMessage(), e);
}
return false;
}
}
initDubboRestServiceMetadataRepository(serviceName); initDubboRestServiceMetadataRepository(serviceName);
return true;
} }
private void initSubscribedDubboMetadataServiceURL(URL dubboMetadataServiceURL) { private void initSubscribedDubboMetadataServiceURL(URL dubboMetadataServiceURL) {
@ -640,11 +675,13 @@ public class DubboServiceMetadataRepository
subscribedDubboMetadataServiceURLs.add(serviceKey, dubboMetadataServiceURL); subscribedDubboMetadataServiceURLs.add(serviceKey, dubboMetadataServiceURL);
} }
private void initDubboMetadataServiceProxy(URL dubboMetadataServiceURL) { private DubboMetadataService initDubboMetadataServiceProxy(
URL dubboMetadataServiceURL) {
String serviceName = dubboMetadataServiceURL.getParameter(APPLICATION_KEY); String serviceName = dubboMetadataServiceURL.getParameter(APPLICATION_KEY);
String version = dubboMetadataServiceURL.getParameter(VERSION_KEY); String version = dubboMetadataServiceURL.getParameter(VERSION_KEY);
// Initialize DubboMetadataService with right version // Initialize DubboMetadataService with right version
dubboMetadataConfigServiceProxy.initProxy(serviceName, version); return dubboMetadataConfigServiceProxy.initProxy(serviceName, version);
} }
@Override @Override
@ -653,4 +690,4 @@ public class DubboServiceMetadataRepository
this.applicationEventPublisher = applicationEventPublisher; this.applicationEventPublisher = applicationEventPublisher;
} }
} }

View File

@ -48,9 +48,11 @@ import static java.util.Collections.emptyList;
import static org.apache.dubbo.common.URLBuilder.from; import static org.apache.dubbo.common.URLBuilder.from;
import static org.apache.dubbo.common.constants.CommonConstants.GROUP_KEY; import static org.apache.dubbo.common.constants.CommonConstants.GROUP_KEY;
import static org.apache.dubbo.common.constants.CommonConstants.PROTOCOL_KEY; import static org.apache.dubbo.common.constants.CommonConstants.PROTOCOL_KEY;
import static org.apache.dubbo.common.constants.CommonConstants.PROVIDER;
import static org.apache.dubbo.common.constants.CommonConstants.PROVIDER_SIDE; import static org.apache.dubbo.common.constants.CommonConstants.PROVIDER_SIDE;
import static org.apache.dubbo.common.constants.CommonConstants.SIDE_KEY; import static org.apache.dubbo.common.constants.CommonConstants.SIDE_KEY;
import static org.apache.dubbo.common.constants.CommonConstants.VERSION_KEY; import static org.apache.dubbo.common.constants.CommonConstants.VERSION_KEY;
import static org.apache.dubbo.common.constants.RegistryConstants.CATEGORY_KEY;
import static org.apache.dubbo.common.constants.RegistryConstants.EMPTY_PROTOCOL; import static org.apache.dubbo.common.constants.RegistryConstants.EMPTY_PROTOCOL;
import static org.apache.dubbo.registry.Constants.ADMIN_PROTOCOL; import static org.apache.dubbo.registry.Constants.ADMIN_PROTOCOL;
import static org.springframework.util.StringUtils.hasText; import static org.springframework.util.StringUtils.hasText;
@ -96,10 +98,10 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
private final ConfigurableApplicationContext applicationContext; private final ConfigurableApplicationContext applicationContext;
public AbstractSpringCloudRegistry(URL url, DiscoveryClient discoveryClient, public AbstractSpringCloudRegistry(URL url, DiscoveryClient discoveryClient,
DubboServiceMetadataRepository dubboServiceMetadataRepository, DubboServiceMetadataRepository dubboServiceMetadataRepository,
DubboMetadataServiceProxy dubboMetadataConfigServiceProxy, DubboMetadataServiceProxy dubboMetadataConfigServiceProxy,
JSONUtils jsonUtils, DubboGenericServiceFactory dubboGenericServiceFactory, JSONUtils jsonUtils, DubboGenericServiceFactory dubboGenericServiceFactory,
ConfigurableApplicationContext applicationContext) { ConfigurableApplicationContext applicationContext) {
super(url); super(url);
this.servicesLookupInterval = url this.servicesLookupInterval = url
.getParameter(SERVICES_LOOKUP_INTERVAL_PARAM_NAME, 60L); .getParameter(SERVICES_LOOKUP_INTERVAL_PARAM_NAME, 60L);
@ -161,6 +163,13 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
} }
else if (isDubboMetadataServiceURL(url)) { // for DubboMetadataService else if (isDubboMetadataServiceURL(url)) { // for DubboMetadataService
subscribeDubboMetadataServiceURLs(url, listener); subscribeDubboMetadataServiceURLs(url, listener);
if (from(url).getParameter(CATEGORY_KEY) != null
&& from(url).getParameter(CATEGORY_KEY).contains(PROVIDER)) {
// Fix #1259 and #753 Listene meta service change events to remove useless
// clients
registerServiceInstancesChangedEventListener(url, listener);
}
} }
else { // for general Dubbo Services else { // for general Dubbo Services
subscribeDubboServiceURLs(url, listener); subscribeDubboServiceURLs(url, listener);
@ -181,7 +190,7 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
* @param listener {@link NotifyListener} * @param listener {@link NotifyListener}
*/ */
private void registerServiceInstancesChangedEventListener(URL url, private void registerServiceInstancesChangedEventListener(URL url,
NotifyListener listener) { NotifyListener listener) {
String listenerId = generateId(url); String listenerId = generateId(url);
if (registerListeners.add(listenerId)) { if (registerListeners.add(listenerId)) {
applicationContext.addApplicationListener( applicationContext.addApplicationListener(
@ -208,8 +217,8 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
} }
protected void subscribeDubboServiceURL(URL url, NotifyListener listener, protected void subscribeDubboServiceURL(URL url, NotifyListener listener,
String serviceName, String serviceName,
Function<String, Collection<ServiceInstance>> serviceInstancesFunction) { Function<String, Collection<ServiceInstance>> serviceInstancesFunction) {
if (logger.isInfoEnabled()) { if (logger.isInfoEnabled()) {
logger.info( logger.info(
@ -228,10 +237,13 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
// Re-obtain the latest list of available metadata address here, ip or port may // Re-obtain the latest list of available metadata address here, ip or port may
// change. // change.
// by https://github.com/wangzihaogithub // by https://github.com/wangzihaogithub
dubboMetadataConfigServiceProxy.removeProxy(serviceName); // When the last service provider is closed, fix 1259while close the
repository.removeMetadataAndInitializedService(serviceName); // channelwhen up a new provider then repository.initializeMetadata(serviceName)
dubboGenericServiceFactory.destroy(serviceName); // will throw Exception.
repository.initializeMetadata(serviceName); // dubboMetadataConfigServiceProxy.removeProxy(serviceName);
// repository.removeMetadataAndInitializedService(serviceName);
// dubboGenericServiceFactory.destroy(serviceName);
// repository.initializeMetadata(serviceName);
if (CollectionUtils.isEmpty(serviceInstances)) { if (CollectionUtils.isEmpty(serviceInstances)) {
if (logger.isWarnEnabled()) { if (logger.isWarnEnabled()) {
logger.warn( logger.warn(
@ -239,6 +251,18 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
+ "available , please make sure the further impact", + "available , please make sure the further impact",
serviceName, url.getServiceKey()); serviceName, url.getServiceKey());
} }
if (isDubboMetadataServiceURL(url)) {
// if meta service change, and serviceInstances is zero, will clean up
// information about this client
dubboMetadataConfigServiceProxy.removeProxy(serviceName);
repository.removeMetadataAndInitializedService(serviceName, url);
dubboGenericServiceFactory.destroy(serviceName);
String listenerId = generateId(url);
// The metaservice will restart the new listener. It needs to be optimized
// to see whether the original listener can be reused.
this.registerListeners.remove(listenerId);
}
/** /**
* URLs with {@link RegistryConstants#EMPTY_PROTOCOL} * URLs with {@link RegistryConstants#EMPTY_PROTOCOL}
*/ */
@ -250,6 +274,11 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
listener.notify(allSubscribedURLs); listener.notify(allSubscribedURLs);
return; return;
} }
if (isDubboMetadataServiceURL(url)) {
// Prevent duplicate generation of DubboMetadataService
return;
}
repository.initializeMetadata(serviceName);
DubboMetadataService dubboMetadataService = dubboMetadataConfigServiceProxy DubboMetadataService dubboMetadataService = dubboMetadataConfigServiceProxy
.getProxy(serviceName); .getProxy(serviceName);
@ -301,7 +330,11 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
} }
private List<URL> emptyURLs(URL url) { private List<URL> emptyURLs(URL url) {
return asList(from(url).setProtocol(EMPTY_PROTOCOL).build()); // issue : When the last service provider is closed, the client still periodically
// connects to the last provider.n
// fix https://github.com/alibaba/spring-cloud-alibaba/issues/1259
return asList(from(url).setProtocol(EMPTY_PROTOCOL).removeParameter(CATEGORY_KEY)
.build());
} }
private List<ServiceInstance> getServiceInstances(String serviceName) { private List<ServiceInstance> getServiceInstances(String serviceName) {
@ -322,7 +355,7 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
} }
private List<URL> getExportedURLs(DubboMetadataService dubboMetadataService, private List<URL> getExportedURLs(DubboMetadataService dubboMetadataService,
URL url) { URL url) {
String serviceInterface = url.getServiceInterface(); String serviceInterface = url.getServiceInterface();
String group = url.getParameter(GROUP_KEY); String group = url.getParameter(GROUP_KEY);
String version = url.getParameter(VERSION_KEY); String version = url.getParameter(VERSION_KEY);
@ -365,4 +398,4 @@ public abstract class AbstractSpringCloudRegistry extends FailbackRegistry {
return DUBBO_METADATA_SERVICE_CLASS_NAME.equals(url.getServiceInterface()); return DUBBO_METADATA_SERVICE_CLASS_NAME.equals(url.getServiceInterface());
} }
} }

View File

@ -5,7 +5,7 @@
<parent> <parent>
<groupId>com.alibaba.cloud</groupId> <groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-starters</artifactId> <artifactId>spring-cloud-alibaba-starters</artifactId>
<version>2.1.2.BUILD-SNAPSHOT</version> <version>${revision}</version>
<relativePath>../pom.xml</relativePath> <relativePath>../pom.xml</relativePath>
</parent> </parent>