{"id":18559151,"url":"https://github.com/linux-china/spring-boot-apache-dubbo","last_synced_at":"2025-04-10T02:30:40.394Z","repository":{"id":45043283,"uuid":"141742281","full_name":"linux-china/spring-boot-apache-dubbo","owner":"linux-china","description":"Spring Boot 2.0 with Apache Dubbo","archived":false,"fork":false,"pushed_at":"2023-03-08T17:28:12.000Z","size":120,"stargazers_count":7,"open_issues_count":3,"forks_count":5,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-04-02T02:51:14.467Z","etag":null,"topics":["dubbo","spring-boot-2"],"latest_commit_sha":null,"homepage":null,"language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/linux-china.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2018-07-20T17:55:35.000Z","updated_at":"2022-12-14T22:51:47.000Z","dependencies_parsed_at":"2024-11-06T21:45:20.597Z","dependency_job_id":"d0ba69ff-9a1e-4ddb-b679-4544439302d3","html_url":"https://github.com/linux-china/spring-boot-apache-dubbo","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linux-china%2Fspring-boot-apache-dubbo","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linux-china%2Fspring-boot-apache-dubbo/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linux-china%2Fspring-boot-apache-dubbo/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linux-china%2Fspring-boot-apache-dubbo/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/linux-china","download_url":"https://codeload.github.com/linux-china/spring-boot-apache-dubbo/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248144159,"owners_count":21054876,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["dubbo","spring-boot-2"],"created_at":"2024-11-06T21:42:10.217Z","updated_at":"2025-04-10T02:30:40.044Z","avatar_url":"https://github.com/linux-china.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"Spring Boot With Apache Dubbo\n=============================\n主要介绍如何在Spring Boot中整合Apache Dubbo的使用，Starter详细介绍在这里：\n\n# Apache Dubbo是什么\nApache Dubbo是Alibaba将Dubbo捐献给Apache的开源产品，详细介绍 http://dubbo.incubator.apache.org/#!/?lang=zh-cn\n\n\n# Spring Boot Starter特性\n\n* Dubbo Service发布： https://github.com/linux-china/spring-boot-apache-dubbo/blob/master/spring-boot-dubbo-server/src/main/java/org/mvnsearch/uic/UicTemplateImpl.java\n* Dubbo Service消费: https://github.com/linux-china/spring-boot-apache-dubbo/blob/master/spring-boot-starter-demo-uic/src/main/java/org/mvnsearch/uic/boot/UicDemoAutoconfiguration.java\n* Metrics支持: 目前主要是counter和timer: 请参考 http://micrometer.io/\n* Endpoint支持:  /actuator/dubbo， 输出Dubbo相关的配置\n\n# 注册中心-Registry\n目前主要是支持Simple Registry(Java), Redis, ZooKeeper和Consul这三个注册中心，主要是这两个服务非常普遍，同时由于Docker的流行，启动这三者个服务也非常简单。\n\n### Redis\n使用Redis注册中心，需要将在pom.xml中添加对应的redis客户端，代码如下：\n\n```xml\n     \u003cdependency\u003e\n         \u003cgroupId\u003eredis.clients\u003c/groupId\u003e\n         \u003cartifactId\u003ejedis\u003c/artifactId\u003e\n     \u003c/dependency\u003e\n```\n\n对应的配置项为： spring.dubbo.registry = redis://localhost:6379\n\n###  ZooKeeper\n使用ZooKeeper注册中心，需要在pom.xml中添加zookeeper需要的jar包，代码如下：\n\n```xml\n     \u003cdependency\u003e\n         \u003cgroupId\u003eorg.apache.curator\u003c/groupId\u003e\n         \u003cartifactId\u003ecurator-framework\u003c/artifactId\u003e\n         \u003cversion\u003e2.12.0\u003c/version\u003e\n     \u003c/dependency\u003e\n     \u003cdependency\u003e\n         \u003cgroupId\u003ecom.101tec\u003c/groupId\u003e\n         \u003cartifactId\u003ezkclient\u003c/artifactId\u003e\n         \u003cversion\u003e0.11\u003c/version\u003e\n     \u003c/dependency\u003e\n```\n\n对应的配置项为： spring.dubbo.registry = zookeeper://127.0.0.1:2181\n\n多个zookeeper的配置项为: spring.dubbo.registry = zookeeper://192.168.0.2:2181,192.168.0.3:2181\n\n# 如何测试\n\n* 首先使用IntelliJ IDEA导入项目\n* 调用docker-compose启动对应的注册中心: docker-compose up -d\n* 启动 DubboRegistryServer\n* 启动 SpringBootDubboServerApplication\n* 启动 SpringBootDubboClientApplication\n* 打开浏览器访问 http://localhost:2080\n\n\n# Spring DevTools注意事项\n由于Spring DevTools采用不一样的classloader的机制，所以会导致Dubbo Consumer Bean无法赋值到指定的@Component上，请使用以下规则：\n\n在 src/main/resources/META-INF/spring-devtools.properties 在添加以下代码进行DevTools的classloader屏蔽：\n```properties\nrestart.exclude.target-classes=/target/classes/\n```\n关于HotSpot的模式下，相关Java代码调整后理解生效，可以考虑： http://dcevm.github.io/\n\n如果你的应用是纯Dubbo服务，没有涉及到Web页面，不建议你添加spring-devtools，如果添加了后，\n可以通过以下配置项关闭livereload服务，这样可以保证不必要的live reload服务启动。\n```properties\nspring.devtools.livereload.enabled=false\n```\n\n# Kotlin support???\n\n```\ndubbo\u003cUserService\u003e(\"0.0.0\");\ndubbo\u003cUserService\u003e(\"127.0.0\",20800,\"0.0.0\")\n```\n\n# References\n\n* Dubbo异步调用: https://dubbo.apache.org/zh/docs/v2.7/user/examples/async-call/\n* Hessian Chinese: https://github.com/cytle/blog/blob/master/source/_posts/Hessian-2-0%E5%BA%8F%E5%88%97%E5%8C%96%E5%8D%8F%E8%AE%AE%E8%A7%84%E8%8C%83.md\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flinux-china%2Fspring-boot-apache-dubbo","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flinux-china%2Fspring-boot-apache-dubbo","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flinux-china%2Fspring-boot-apache-dubbo/lists"}