{"id":13536808,"url":"https://github.com/linking12/spring-boot-starter-dubbo","last_synced_at":"2025-04-02T03:31:09.806Z","repository":{"id":82888580,"uuid":"50102498","full_name":"linking12/spring-boot-starter-dubbo","owner":"linking12","description":null,"archived":false,"fork":false,"pushed_at":"2016-07-07T03:45:51.000Z","size":13,"stargazers_count":48,"open_issues_count":2,"forks_count":29,"subscribers_count":7,"default_branch":"master","last_synced_at":"2024-11-03T01:33:23.985Z","etag":null,"topics":[],"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/linking12.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}},"created_at":"2016-01-21T11:16:03.000Z","updated_at":"2023-11-06T04:57:00.000Z","dependencies_parsed_at":null,"dependency_job_id":"607b51a0-3e0c-4199-a811-bf01e0039a9d","html_url":"https://github.com/linking12/spring-boot-starter-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/linking12%2Fspring-boot-starter-dubbo","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linking12%2Fspring-boot-starter-dubbo/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linking12%2Fspring-boot-starter-dubbo/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/linking12%2Fspring-boot-starter-dubbo/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/linking12","download_url":"https://codeload.github.com/linking12/spring-boot-starter-dubbo/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246751070,"owners_count":20827830,"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":[],"created_at":"2024-08-01T09:00:49.853Z","updated_at":"2025-04-02T03:31:09.431Z","avatar_url":"https://github.com/linking12.png","language":"Java","funding_links":[],"categories":["3. dubbo extensions and tools"],"sub_categories":["spring-boot-starter-dubbo"],"readme":"#spring-boot-start-dubbo\n\nDubbo是阿里开发的一套分布式通讯框架,Spring-boot是业界比较火的微服务框架，两者可以进行结合实现分布式微服务\n* 对于提供外部的服务，可以使用spring-boot的rest服务，达到Api网关的目的\n* 对于内部远程Rpc调用，可以借用Dubbo能力，达到服务治理的目的\n\n##如何发布Dubbo服务\n* 在Spring Boot项目的pom.xml中添加以下依赖:\n```\n \u003cdependency\u003e\n         \u003cgroupId\u003eorg.springframework.boot\u003c/groupId\u003e\n         \u003cartifactId\u003espring-boot-starter-dubbo\u003c/artifactId\u003e\n         \u003cversion\u003e1.3.1.RELEASE\u003c/version\u003e\n \u003c/dependency\u003e\n \u003c!--依赖于容器--\u003e\n \u003cdependency\u003e\n         \u003cgroupId\u003eorg.springframework.boot\u003c/groupId\u003e\n         \u003cartifactId\u003espring-boot-starter-web\u003c/artifactId\u003e\n         \u003cversion\u003e1.3.1.RELEASE\u003c/version\u003e\n \u003c/dependency\u003e\n ```\n* 在application.properties添加Dubbo的版本信息和客户端超时信息,如下:\n```\nspring.dubbo.application.name=annotation-provider\nspring.dubbo.registry.address=zookeeper://127.0.0.1:2181\nspring.dubbo.protocol.name=dubbo\nspring.dubbo.protocol.port=20880\nspring.dubbo.scan=org.mingyu.study\n```\n在Spring Application的application.properties中添加spring.dubbo.scan即可支持Dubbo服务发布,其中scan表示要扫描的package目录\n* spring boot启动\n```\n@SpringBootApplication\npublic class Application {\n\n    public static void main(String[] args) {\n        SpringApplication application = new SpringApplication(Application.class);\n        application.run(args);\n    }\n```\n* 编写你的Dubbo服务,只需要添加要发布的服务实现上添加 @Service ,如下\n```\n@Service(version = \"1.0.0\")\npublic class ServiceImpl implements ServiceA {\n\n    @Override\n    public String test() {\n        return \"hello\";\n    }\n}\n\n```\n\n##如何引用Dubbo服务\n* 在Spring Boot项目的pom.xml中添加以下依赖:\n```\n \u003cdependency\u003e\n         \u003cgroupId\u003eorg.springframework.boot\u003c/groupId\u003e\n         \u003cartifactId\u003espring-boot-starter-dubbo\u003c/artifactId\u003e\n         \u003cversion\u003e1.3.1.RELEASE\u003c/version\u003e\n \u003c/dependency\u003e\n ```\n* 在application.properties添加Dubbo的版本信息和客户端超时信息,如下:\n```\nspring.dubbo.application.name=annotation-consumer\nspring.dubbo.registry.address=zookeeper://127.0.0.1:2181\nspring.dubbo.scan=com.lance\n```\n在Spring Application的application.properties中添加spring.dubbo.scan即可支持Dubbo服务发布,其中scan表示要扫描的package目录\n\n* spring boot启动\n```\n@SpringBootApplication\npublic class TestMain {\n    public static void main(String[] args) {\n        SpringApplication application = new SpringApplication(Application.class);\n        application.run(args);\n    }\n}\n```\n* 引用Dubbo服务,只需要添加要发布的服务实现上添加 @Reference ,如下:\n```\n@Component\npublic class BarAction {\n\n    @Reference(version = \"1.0.0\")\n    private ServiceA fooService;\n}\n```\n\n##关于spring-boot开发知识\n\u003ca href =\"http://www.jianshu.com/users/aa6df7dd83ec/latest_articles\"\u003espring-boot学习笔记\u003c/a\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flinking12%2Fspring-boot-starter-dubbo","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Flinking12%2Fspring-boot-starter-dubbo","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Flinking12%2Fspring-boot-starter-dubbo/lists"}