commit | 43c85d149b42d65510dfbe53a8fb6c3c90c9905e | [log] [tgz] |
---|---|---|
author | Albumen Kevin <jhq0812@gmail.com> | Fri Sep 13 15:45:01 2024 +0800 |
committer | Albumen Kevin <jhq0812@gmail.com> | Fri Sep 13 15:45:01 2024 +0800 |
tree | 803bf47168274b9da7e8bb7f8e4933639323c85b | |
parent | c833069d53f2afc3f7bd8ce26a79624cfec12d45 [diff] | |
parent | c2894d112b0657e3f07d46e2a2ea397853df1e88 [diff] |
Merge branch 'refs/heads/3.2.16-release' into apache-3.2
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 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/1-basic/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>3.2.13-SNAPSHOT</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 client/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
To avoid intermittent test failures (i.e., flaky tests), it is recommended to have a machine or virtual machine with the following specifications:
The Dubbo Community primarily communicates on GitHub through issues, discussions, and pull requests.
We have also implemented a project board to monitor all the items.
Any essential changes should be discussed on the mailing list before they happen.
If you have questions such as:
Please start a discussion at https://github.com/apache/dubbo/discussions.
However, if you encounter the following situations:
Please open an issue at https://github.com/apache/dubbo/issues.
To ask effective questions, we recommend reading How To Ask Questions The Smart Way first.
For further details, please refer our guide about how to contribute Dubbo.
Please follow the template for reporting any issues.
Please report security vulnerabilities to us privately.
Mailing list:
Bugs: Issues
Gitter: Gitter channel
Twitter: @ApacheDubbo
dubbo
to gather all Dubbo relevant projects not appropriate in apache group yetApache Dubbo software is licensed under the Apache License Version 2.0. See the LICENSE file for details.