Go to file
xxq250 c09d19d15c Add 1.txt 2023-10-07 11:05:18 +08:00
.github [Github-Actions] Improve Test cases (#7592) 2021-04-21 22:43:20 +08:00
.mvn/wrapper optmize maven output when run with travis (#4884) 2019-08-20 10:16:50 +08:00
codestyle [Enhancement] Adding a build tools module for Apache License (#6060) 2020-04-26 16:19:23 +08:00
compiler upgrade logging jars due to security issues (#9791) 2022-03-16 14:58:47 +08:00
dubbo-all Compatible with curator5 (#8264) 2021-07-13 22:47:42 +08:00
dubbo-bom Compatible with curator5 (#8264) 2021-07-13 22:47:42 +08:00
dubbo-build-tools polish #6115 2020-05-08 17:46:55 +08:00
dubbo-cluster Add router fail fast option (Backport #9388) (#11188) 2022-12-21 23:44:42 +08:00
dubbo-common Add serializable check for pojo (#11430) 2023-02-01 14:02:53 +08:00
dubbo-compatible Standard code comment format. (#10251) 2022-07-01 15:19:53 +08:00
dubbo-config remove redundant volatile on initialized (#9926) 2022-05-09 10:25:41 +08:00
dubbo-configcenter Fix can't authenticate by username and password when use Nacos (#9941) 2022-06-14 14:14:00 +08:00
dubbo-container fix some typo (#7495) 2021-04-01 19:33:21 +08:00
dubbo-demo dubbo-demo-xml-consumer use correct metadata-report address (#9511) 2022-01-23 16:51:04 +08:00
dubbo-dependencies Bump to 2.7.24-SNAPSHOT 2023-04-18 19:17:24 +08:00
dubbo-dependencies-bom Bump to 2.7.24-SNAPSHOT 2023-04-18 19:17:24 +08:00
dubbo-distribution gRpc compiler refactor (#5416) 2019-12-04 11:10:20 +08:00
dubbo-filter Use constants instead of literals (#7962) 2021-06-03 16:54:04 +08:00
dubbo-metadata Remove params type size check in MapTypeBuilder (#9848) 2022-04-01 11:06:52 +08:00
dubbo-monitor [master]optimize some code metrics filter (#9357) 2021-12-06 13:31:47 +08:00
dubbo-plugin Standard code comment format. (#10251) 2022-07-01 15:19:53 +08:00
dubbo-registry Add router fail fast option (Backport #9388) (#11188) 2022-12-21 23:44:42 +08:00
dubbo-remoting Fix When serialization fails, the code value in org.apache.dubbo.rpc.RpcException is set incorrectly. (#12279) (#12280) 2023-05-17 14:54:28 +08:00
dubbo-rpc Fix When serialization fails, the code value in org.apache.dubbo.rpc.RpcException is set incorrectly. (#12279) (#12280) 2023-05-17 14:54:28 +08:00
dubbo-serialization Cherry pick #9340 2022-11-28 17:29:01 +08:00
dubbo-spring-boot upgrade logging jars due to security issues (#9791) 2022-03-16 14:58:47 +08:00
.codecov.yml Merge pull request #2047, deprecate dubbo-rpc-thrift. 2018-07-09 16:19:02 +08:00
.gitattributes Add gitattributes to prevent file formatting (#7229) 2021-02-20 15:34:14 +08:00
.gitignore add fleet project file to .gitignore 2022-10-16 16:26:51 +08:00
.travis.yml Fix the build on Linux ARM64 CPU architecture (#7408) 2021-04-15 01:23:46 -07:00
1.txt Add 1.txt 2023-10-07 11:05:18 +08:00
CHANGES.md update change logs 2020-03-16 15:51:04 +08:00
CODE_OF_CONDUCT.md Fix minor issues reported in 2.6.2 RC1 2018-05-22 08:20:10 +08:00
CONTRIBUTING.md Fix the build on Linux ARM64 CPU architecture (#7408) 2021-04-15 01:23:46 -07:00
Jenkinsfile fix jenkins job for snapshot version deployment (#7338) 2021-03-09 10:57:35 +08:00
LICENSE update LICENSE 2020-04-14 12:51:11 +08:00
NOTICE Update NOTICE 2023-01-13 10:16:32 +08:00
PULL_REQUEST_TEMPLATE.md Update Pull Request Template (#7828) 2021-05-24 10:28:45 +08:00
README.md on branch 2.7.x, fix issue #8611, use HTTPS (#8632) 2021-09-03 18:02:13 +08:00
SECURITY.md Grammar fixes (#7500) 2021-04-02 13:09:49 +08:00
licenseCheck.sh add license header for licenseCheck.sh file (#5143) 2019-10-08 13:10:31 +08:00
mvnw Adding maven wrapper to Dubbo project (#1887) 2018-06-05 14:09:20 +08:00
mvnw.cmd Adding maven wrapper to Dubbo project (#1887) 2018-06-05 14:09:20 +08:00
pom.xml Bump to 2.7.24-SNAPSHOT 2023-04-18 19:17:24 +08:00

README.md

Apache Dubbo Project

Build Status Build Status Codecov Maven License Average time to resolve an issue Percentage of issues still open Tweet Twitter Follow Gitter

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 :)

Architecture

Architecture

Features

  • Transparent interface based RPC
  • Intelligent load balancing
  • Automatic service registration and discovery
  • High extensibility
  • Runtime traffic routing
  • Visualized service governance

Getting started

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:

Maven dependency

<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>

Define service interfaces

package org.apache.dubbo.samples.api;

public interface GreetingsService {
    String sayHi(String name);
}

See api/GreetingsService.java on GitHub.

Implement service interface for the provider

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.

Start service provider

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.

Build and run the provider

# mvn clean package
# mvn -Djava.net.preferIPv4Stack=true -Dexec.mainClass=org.apache.dubbo.samples.provider.Application exec:java

Call remote service in the consumer

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.

Build and run the consumer

# 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.

Next steps

Building

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

Contact

Contributing

See CONTRIBUTING for details on submitting patches and the contribution workflow.

How can I contribute?

  • Take a look at issues with tags marked Good first issue or Help wanted.
  • Join the discussion on the mailing list, subscription guide.
  • Answer questions on issues.
  • Fix bugs reported on issues, and send us a pull request.
  • Review the existing pull request.
  • Improve the website, typically we need
    • blog post
    • translation on documentation
    • use cases around the integration of Dubbo in enterprise systems.
  • Improve the dubbo-admin/dubbo-monitor.
  • Contribute to the projects listed in ecosystem.
  • Other forms of contribution not explicitly enumerated above.
  • If you would like to contribute, please send an email to dev@dubbo.apache.org to let us know!

Reporting bugs

Please follow the template for reporting any issues.

Reporting a security vulnerability

Please report security vulnerabilities to us privately.

Dubbo ecosystem

Language

License

Apache Dubbo software is licenced under the Apache License Version 2.0. See the LICENSE file for details.