commit | b62832b21a0191bf28fa290707ad016029474838 | [log] [tgz] |
---|---|---|
author | zhox <41657421+zhongxiongzeng@users.noreply.github.com> | Wed May 05 20:59:40 2021 +0800 |
committer | GitHub <noreply@github.com> | Wed May 05 20:59:40 2021 +0800 |
tree | 7b37f562cc65fb56abf8d09a067ab863e21467b2 | |
parent | 1bed062d2938dcf568f51dccb5c04fb9ba026bd9 [diff] |
Solve the problem of repeatedly registering the BeanDefinition of the provider (#7494) * 解决PojoUtils.java#getDefaultValue获取boolean默认值不正确的问题,并补充对应的测试用例 * Solve the problem of repeatedly registering the BeanDefinition of the provider * Solve the problem of repeatedly registering the BeanDefinition of the provider * An exception is thrown when registering a duplicate ServiceBean * 1 fix with DubboBeanDefinitionParser.java: Prohibit repeated generation of name for ServiceBean * 1 fix with DubboBeanDefinitionParser.java: Prohibit repeated generation of name of ServiceBean * 1 fix with multiple-services-with-methods.xml: improve test config * Revert "1 fix with multiple-services-with-methods.xml: improve test config" This reverts commit 7ce4e3b2 * Update multiple-services-with-methods.xml improve test config * Modify the default generation method of ServiceBean id; add test case scenario: an exception is thrown when ServiceBean is duplicate registered; * import BeanDefinitionStoreException.class * Revert "import BeanDefinitionStoreException.class" This reverts commit e3c1be44 * Revert "Modify the default generation method of ServiceBean id; add test case scenario: an exception is thrown when ServiceBean is duplicate registered;" This reverts commit 73f8ea62 * Revert "Update multiple-services-with-methods.xml" This reverts commit ddc3615b * Revert "1 fix with DubboBeanDefinitionParser.java: Prohibit repeated generation of name of ServiceBean" This reverts commit 1b159909 * Revert "1 fix with DubboBeanDefinitionParser.java: Prohibit repeated generation of name for ServiceBean" This reverts commit f41e1ecb * Update DubboBeanDefinitionParser.java revert all commit * Update DubboBeanDefinitionParser.java revert all commit * Prevent the same ServiceBean exported * Prevent the same ServiceBean exported * 1 modify with ServiceConfig.java: if there is an 'id'attribute, it will be used first * 1 modify with ServiceConfig.java: After the service is exported, set the export to false * Revert "1 modify with ServiceConfig.java: After the service is exported, set the export to false" This reverts commit b482cd44 * Solve the issue of the ServiceBean duplication export * fix UT * Prevent the same ServiceBean exported * 1 fix with ServiceConfig.java and ServiceBean.java * adjust log print * 1 fix with DubboBootstrap.java: adjust log print * fix unit test * fix UT * fix UT * FIX UT * add reset method to AbstractRegistryFactory.java for ut . and improve code note Co-authored-by: zhongxiong.zeng <zhongxiong.zeng@za.group> Co-authored-by: 909779528@qq.com <xiong837652>
Apache Dubbo is a high-performance, Java-based open-source RPC framework. Please visit the official site for the quick start guide and documentation, as well as the wiki for news, FAQ, and release notes.
We are now collecting Dubbo user info to help us to improve Dubbo further. Kindly support us by providing your usage information on issue#1012: Wanted: who's using dubbo, thanks :)
The following code snippet comes from Dubbo Samples. You may clone the sample project and step into the dubbo-samples-api
subdirectory before proceeding.
# git clone https://github.com/apache/dubbo-samples.git # cd dubbo-samples/dubbo-samples-api
There's a README file under dubbo-samples-api
directory. We recommend referencing the samples in that directory by following the below-mentioned instructions:
<properties> <dubbo.version>2.7.10</dubbo.version> </properties> <dependencies> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo</artifactId> <version>${dubbo.version}</version> </dependency> <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-dependencies-zookeeper</artifactId> <version>${dubbo.version}</version> <type>pom</type> </dependency> </dependencies>
package org.apache.dubbo.samples.api; public interface GreetingsService { String sayHi(String name); }
See api/GreetingsService.java on GitHub.
package org.apache.dubbo.samples.provider; import org.apache.dubbo.samples.api.GreetingsService; public class GreetingsServiceImpl implements GreetingsService { @Override public String sayHi(String name) { return "hi, " + name; } }
See provider/GreetingsServiceImpl.java on GitHub.
package org.apache.dubbo.samples.provider; import org.apache.dubbo.config.ApplicationConfig; import org.apache.dubbo.config.RegistryConfig; import org.apache.dubbo.config.ServiceConfig; import org.apache.dubbo.samples.api.GreetingsService; import java.util.concurrent.CountDownLatch; public class Application { private static String zookeeperHost = System.getProperty("zookeeper.address", "127.0.0.1"); public static void main(String[] args) throws Exception { ServiceConfig<GreetingsService> service = new ServiceConfig<>(); service.setApplication(new ApplicationConfig("first-dubbo-provider")); service.setRegistry(new RegistryConfig("zookeeper://" + zookeeperHost + ":2181")); service.setInterface(GreetingsService.class); service.setRef(new GreetingsServiceImpl()); service.export(); System.out.println("dubbo service started"); new CountDownLatch(1).await(); } }
See provider/Application.java on GitHub.
# mvn clean package # mvn -Djava.net.preferIPv4Stack=true -Dexec.mainClass=org.apache.dubbo.samples.provider.Application exec:java
package org.apache.dubbo.samples.client; import org.apache.dubbo.config.ApplicationConfig; import org.apache.dubbo.config.ReferenceConfig; import org.apache.dubbo.config.RegistryConfig; import org.apache.dubbo.samples.api.GreetingsService; public class Application { private static String zookeeperHost = System.getProperty("zookeeper.address", "127.0.0.1"); public static void main(String[] args) { ReferenceConfig<GreetingsService> reference = new ReferenceConfig<>(); reference.setApplication(new ApplicationConfig("first-dubbo-consumer")); reference.setRegistry(new RegistryConfig("zookeeper://" + zookeeperHost + ":2181")); reference.setInterface(GreetingsService.class); GreetingsService service = reference.get(); String message = service.sayHi("dubbo"); System.out.println(message); } }
See consumer/Application.java on GitHub.
# mvn clean package # mvn -Djava.net.preferIPv4Stack=true -Dexec.mainClass=org.apache.dubbo.samples.client.Application exec:java
The consumer will print out hi, dubbo
on the screen.
If you want to try out the cutting-edge features, you can build with the following commands. (Java 1.8 is needed to build the master branch)
mvn clean install
Mailing list:
Bugs: Issues
Gitter: Gitter channel
Twitter: @ApacheDubbo
See CONTRIBUTING for details on submitting patches and the contribution workflow.
Good first issue
or Help wanted
.Please follow the template for reporting any issues.
Please report security vulnerabilities to us privately.
dubbo
to gather all Dubbo relevant projects not appropriate in apache group yetApache Dubbo software is licenced under the Apache License Version 2.0. See the LICENSE file for details.