Java 开源rpc_Apache Dubbo 一个高性能,基于Java的开源RPC框架

Apache Dubbo Project

68747470733a2f2f7472617669732d63692e6f72672f6170616368652f647562626f2e7376673f6272616e63683d6d617374657268747470733a2f2f636f6465636f762e696f2f67682f6170616368652f647562626f2f6272616e63682f6d61737465722f67726170682f62616467652e73766768747470733a2f2f696d672e736869656c64732e696f2f6d6176656e2d63656e7472616c2f762f6f72672e6170616368652e647562626f2f647562626f2e73766768747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6963656e73652f616c69626162612f647562626f2e737667687474703a2f2f697369746d61696e7461696e65642e636f6d2f62616467652f7265736f6c7574696f6e2f6170616368652f647562626f2e737667687474703a2f2f697369746d61696e7461696e65642e636f6d2f62616467652f6f70656e2f6170616368652f647562626f2e73766768747470733a2f2f696d672e736869656c64732e696f2f747769747465722f75726c2f687474702f736869656c64732e696f2e7376673f7374796c653d736f6369616c68747470733a2f2f696d672e736869656c64732e696f2f747769747465722f666f6c6c6f772f417061636865447562626f2e7376673f6c6162656c3d466f6c6c6f77267374796c653d736f6369616c266c6f676f57696474683d3068747470733a2f2f6261646765732e6769747465722e696d2f616c69626162612f647562626f2e737667

Apache Dubbo is a high-performance, Java based open source RPC framework. Please visit official site for quick start and documentations, as well as Wiki for news, FAQ, and release notes.

We are now collecting dubbo user info in order to help us to improve Dubbo better, pls. kindly help us by providing yours on issue#1012: Wanted: who's using dubbo, thanks :)

Architecture

dac70879fad906c9fc5953fb62ba3652.png

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 dubbo-samples-api sub directory before read on.

# git clone https://github.com/apache/dubbo-samples.git

# cd dubbo-samples/java/dubbo-samples-api

There's a README file under dubbo-samples-api directory. Read it and try this sample out by following the instructions.

Maven dependency

2.7.7

org.apache.dubbo

dubbo

${dubbo.version}

org.apache.dubbo

dubbo-dependencies-zookeeper

${dubbo.version}

pom

Define service interfaces

package org.apache.dubbo.samples.api;

public interface GreetingsService {

String sayHi(String name);

}

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;

}

}

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 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();

}

}

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

}

}

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

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.

Building

If you want to try out the cutting-edge features, you can build with the following commands. (Java 1.8 is required to build the master branch)

mvn clean install

Contact

Mailing list:

dev list: for dev/user discussion. subscribe, unsubscribe, archive, guide

Contributing

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

How can I contribute?

Take a look at issues with tag called Good first issue or Help wanted.

Join the discussion on mailing list, subscription guide.

Answer questions on issues.

Fix bugs reported on issues, and send us pull request.

Review the existing pull request.

Improve the website, typically we need

blog post

translation on documentation

use cases about how Dubbo is being used in enterprise system.

Contribute to the projects listed in ecosystem.

Any form of contribution that is not mentioned 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 vulnerability to us privately.

Dubbo ecosystem

Dubbo Ecosystem Entry - A GitHub group dubbo to gather all Dubbo relevant projects not appropriate in apache 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

Language

License

Apache Dubbo is under the Apache 2.0 license. See the LICENSE file for details.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值