- Notifications
You must be signed in to change notification settings - Fork0
Dubbo is a high-performance, java based, open source RPC framework
License
mestarshine/dubbo
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Apache Dubbo is a high-performance, Java-based open-source RPC framework. Please visit theofficial site for the quick start guide and documentation, as well as thewiki 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 onissue#1012: Wanted: who's using dubbo, thanks :)
- Transparent interface based RPC
- Intelligent load balancing
- Automatic service registration and discovery
- High extensibility
- Runtime traffic routing
- Visualized service governance
The following code snippet comes fromDubbo Samples. You may clone the sample project and step into thedubbo-samples-api
subdirectory before proceeding.
# git clone https://github.com/apache/dubbo-samples.git# cd dubbo-samples/dubbo-samples-api
There's aREADME file underdubbo-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>
packageorg.apache.dubbo.samples.api;publicinterfaceGreetingsService {StringsayHi(Stringname);}
Seeapi/GreetingsService.java on GitHub.
packageorg.apache.dubbo.samples.provider;importorg.apache.dubbo.samples.api.GreetingsService;publicclassGreetingsServiceImplimplementsGreetingsService {@OverridepublicStringsayHi(Stringname) {return"hi, " +name; }}
Seeprovider/GreetingsServiceImpl.java on GitHub.
packageorg.apache.dubbo.samples.provider;importorg.apache.dubbo.config.ApplicationConfig;importorg.apache.dubbo.config.RegistryConfig;importorg.apache.dubbo.config.ServiceConfig;importorg.apache.dubbo.samples.api.GreetingsService;importjava.util.concurrent.CountDownLatch;publicclassApplication {privatestaticStringzookeeperHost =System.getProperty("zookeeper.address","127.0.0.1");publicstaticvoidmain(String[]args)throwsException {ServiceConfig<GreetingsService>service =newServiceConfig<>();service.setApplication(newApplicationConfig("first-dubbo-provider"));service.setRegistry(newRegistryConfig("zookeeper://" +zookeeperHost +":2181"));service.setInterface(GreetingsService.class);service.setRef(newGreetingsServiceImpl());service.export();System.out.println("dubbo service started");newCountDownLatch(1).await(); }}
Seeprovider/Application.java on GitHub.
# mvn clean package# mvn -Djava.net.preferIPv4Stack=true -Dexec.mainClass=org.apache.dubbo.samples.provider.Application exec:java
packageorg.apache.dubbo.samples.client;importorg.apache.dubbo.config.ApplicationConfig;importorg.apache.dubbo.config.ReferenceConfig;importorg.apache.dubbo.config.RegistryConfig;importorg.apache.dubbo.samples.api.GreetingsService;publicclassApplication {privatestaticStringzookeeperHost =System.getProperty("zookeeper.address","127.0.0.1");publicstaticvoidmain(String[]args) {ReferenceConfig<GreetingsService>reference =newReferenceConfig<>();reference.setApplication(newApplicationConfig("first-dubbo-consumer"));reference.setRegistry(newRegistryConfig("zookeeper://" +zookeeperHost +":2181"));reference.setInterface(GreetingsService.class);GreetingsServiceservice =reference.get();Stringmessage =service.sayHi("dubbo");System.out.println(message); }}
Seeconsumer/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 outhi, dubbo
on the screen.
- Your first Dubbo application - A 101 tutorial to reveal more details, with the same code above.
- Dubbo user manual - How to use Dubbo and all its features.
- Dubbo developer guide - How to involve in Dubbo development.
- Dubbo admin manual - How to admin and manage Dubbo services.
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:
- dev list: for dev/user discussion.subscribe,unsubscribe,archive,guide
Bugs:Issues
Gitter:Gitter channel
Twitter:@ApacheDubbo
See CONTRIBUTING for details on submitting patches and the contribution workflow.
- Take a look at issues with tags marked
Good first issue
orHelp wanted
. - Join the discussion on the mailing list, subscriptionguide.
- Answer questions onissues.
- Fix bugs reported onissues, and send us a pull request.
- Review the existingpull request.
- Improve thewebsite, typically we need
- blog post
- translation on documentation
- use cases around the integration of Dubbo in enterprise systems.
- Improve thedubbo-admin/dubbo-monitor.
- Contribute to the projects listed inecosystem.
- Other forms of contribution not explicitly enumerated above.
- If you would like to contribute, please send an email todev@dubbo.apache.org to let us know!
Please follow thetemplate for reporting any issues.
Please report security vulnerabilities tous privately.
- Dubbo Ecosystem Entry - A GitHub group
dubbo
to gather all Dubbo relevant projects not appropriate inapache group yet - Dubbo Website - Apache Dubbo official website
- Dubbo Samples - samples for Apache Dubbo
- Dubbo Spring Boot - Spring Boot Project for Dubbo
- Dubbo Admin - The reference implementation for Dubbo admin
- Dubbo Awesome - Dubbo's slides and video links in Meetup
Apache Dubbo software is licenced under the Apache License Version 2.0. See the LICENSE file for details.
About
Dubbo is a high-performance, java based, open source RPC framework
Topics
Resources
License
Code of conduct
Security policy
Stars
Watchers
Forks
Packages0
Languages
- Java99.6%
- Mustache0.3%
- Shell0.1%
- Thrift0.0%
- JavaScript0.0%
- Lex0.0%