{"id":1926,"date":"2023-04-01T09:49:37","date_gmt":"2023-04-01T01:49:37","guid":{"rendered":"https:\/\/www.appblog.cn\/?p=1926"},"modified":"2023-04-22T08:49:19","modified_gmt":"2023-04-22T00:49:19","slug":"dubbo-spring-cloud-service-consumer-development-steps","status":"publish","type":"post","link":"https:\/\/www.appblog.cn\/index.php\/2023\/04\/01\/dubbo-spring-cloud-service-consumer-development-steps\/","title":{"rendered":"Dubbo Spring Cloud \u670d\u52a1\u6d88\u8d39\u65b9\u5f00\u53d1\u6b65\u9aa4"},"content":{"rendered":"<blockquote>\n<p>\u6ce8\u518c\u4e2d\u5fc3\u91c7\u7528\u963f\u91cc\u5df4\u5df4Nacos<\/p>\n<\/blockquote>\n<h2>\u63a5\u53e3\u5b9a\u4e49<\/h2>\n<pre><code class=\"language-java\">public interface UserService {\n\n    boolean save(User user);\n\n    boolean remove(Long userId);\n\n    Collection&lt;User&gt; findAll();\n}<\/code><\/pre>\n<p><!-- more --><\/p>\n<pre><code class=\"language-java\">public interface RestService {\n\n    String param(String param);\n\n    String params(int a, String b);\n\n    String headers(String header, String header2, Integer param);\n\n    String pathVariables(String path1, String path2, String param);\n\n    String form(String form);\n\n    User requestBodyMap(Map&lt;String, Object&gt; data, String param);\n\n    Map&lt;String, Object&gt; requestBodyUser(User user);\n}<\/code><\/pre>\n<h2>\u4f9d\u8d56\u5f15\u5165<\/h2>\n<pre><code class=\"language-xml\">&lt;dependencies&gt;\n\n    &lt;dependency&gt;\n        &lt;groupId&gt;org.springframework.boot&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-boot-starter-web&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n    &lt;dependency&gt;\n        &lt;groupId&gt;org.springframework.boot&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-boot-actuator&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n    &lt;!-- Spring Cloud Open Feign --&gt;\n    &lt;dependency&gt;\n        &lt;groupId&gt;org.springframework.cloud&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-cloud-starter-openfeign&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n    &lt;!-- Spring Retry --&gt;\n    &lt;dependency&gt;\n        &lt;groupId&gt;org.springframework.retry&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-retry&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n    &lt;!-- Sample API --&gt;\n    &lt;dependency&gt;\n        &lt;groupId&gt;com.alibaba.cloud&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-cloud-dubbo-sample-api&lt;\/artifactId&gt;\n        &lt;version&gt;${project.version}&lt;\/version&gt;\n    &lt;\/dependency&gt;\n\n    &lt;!-- Dubbo Spring Cloud Starter --&gt;\n    &lt;dependency&gt;\n        &lt;groupId&gt;com.alibaba.cloud&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-cloud-starter-dubbo&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n    &lt;!-- Spring Cloud Nacos Service Discovery --&gt;\n    &lt;dependency&gt;\n        &lt;groupId&gt;com.alibaba.cloud&lt;\/groupId&gt;\n        &lt;artifactId&gt;spring-cloud-starter-alibaba-nacos-discovery&lt;\/artifactId&gt;\n    &lt;\/dependency&gt;\n\n&lt;\/dependencies&gt;<\/code><\/pre>\n<h2>\u9879\u76ee\u914d\u7f6e<\/h2>\n<ul>\n<li><code>bootstrap.yaml<\/code><\/li>\n<\/ul>\n<pre><code class=\"language-yml\">spring:\n  application:\n    name: spring-cloud-alibaba-dubbo-consumer\n  main:\n    allow-bean-definition-overriding: true\n  profiles: nacos\n  cloud:\n    nacos:\n      username: test\n      password: test\n      discovery:\n        enabled: true\n        register-enabled: true\n        server-addr: 192.168.1.5:8848\n        context-path: \/nacos\n        ephemeral: false\n\nribbon:\n  nacos:\n    enabled: true<\/code><\/pre>\n<ul>\n<li><code>application.yaml<\/code><\/li>\n<\/ul>\n<pre><code class=\"language-yml\">dubbo:\n  cloud:\n    # The subscribed services in consumer side\n    subscribed-services: ${provider.application.name}\n  protocols:\n    dubbo:\n      port: -1\n  consumer:\n    check: false\n\nprovider:\n  application:\n    name: spring-cloud-alibaba-dubbo-provider<\/code><\/pre>\n<h2>\u6d88\u8d39\u5b9e\u73b0<\/h2>\n<h3>dubbo\u670d\u52a1\u57fa\u672c\u8c03\u7528<\/h3>\n<pre><code class=\"language-java\">@DubboReference\nprivate UserService userService;\n\n@DubboReference(version = &quot;1.0.0&quot;, protocol = &quot;dubbo&quot;)\nprivate RestService restService;<\/code><\/pre>\n<h3>FeignClient<\/h3>\n<ul>\n<li>\u8d70http\u534f\u8bae<\/li>\n<\/ul>\n<pre><code class=\"language-java\">@FeignClient(&quot;${provider.application.name}&quot;)\npublic interface FeignRestService {\n    ...\n}<\/code><\/pre>\n<ul>\n<li>\u8d70dubbo\u534f\u8bae<\/li>\n<\/ul>\n<pre><code class=\"language-java\">@FeignClient(&quot;${provider.application.name}&quot;)\n@DubboTransported(protocol = &quot;dubbo&quot;)\npublic interface DubboFeignRestService {\n    ...\n}<\/code><\/pre>\n<h3>RestTemplate<\/h3>\n<ul>\n<li>\u8d70http\u534f\u8bae<\/li>\n<\/ul>\n<pre><code class=\"language-java\">@Bean\n@LoadBalanced\npublic RestTemplate restTemplate() {\n    return new RestTemplate();\n}<\/code><\/pre>\n<ul>\n<li>\u8d70dubbo\u534f\u8bae<\/li>\n<\/ul>\n<pre><code class=\"language-java\">@Bean\n@LoadBalanced\n@DubboTransported\npublic RestTemplate restTemplate() {\n    return new RestTemplate();\n}<\/code><\/pre>\n<h3>\u5b8c\u6574\u4ee3\u7801<\/h3>\n<pre><code class=\"language-java\">import com.alibaba.cloud.dubbo.annotation.DubboTransported;\nimport com.alibaba.cloud.dubbo.service.RestService;\nimport com.alibaba.cloud.dubbo.service.User;\nimport com.alibaba.cloud.dubbo.service.UserService;\n\nimport org.apache.dubbo.config.annotation.DubboReference;\n\nimport org.springframework.beans.factory.annotation.Autowired;\nimport org.springframework.beans.factory.annotation.Value;\nimport org.springframework.boot.ApplicationRunner;\nimport org.springframework.boot.autoconfigure.EnableAutoConfiguration;\nimport org.springframework.boot.builder.SpringApplicationBuilder;\nimport org.springframework.cache.annotation.EnableCaching;\nimport org.springframework.cloud.client.discovery.EnableDiscoveryClient;\nimport org.springframework.cloud.client.loadbalancer.LoadBalanced;\nimport org.springframework.cloud.openfeign.EnableFeignClients;\nimport org.springframework.cloud.openfeign.FeignClient;\nimport org.springframework.context.annotation.Bean;\nimport org.springframework.context.annotation.Lazy;\nimport org.springframework.scheduling.annotation.EnableScheduling;\nimport org.springframework.scheduling.annotation.Scheduled;\nimport org.springframework.web.bind.annotation.GetMapping;\nimport org.springframework.web.bind.annotation.PathVariable;\nimport org.springframework.web.bind.annotation.PostMapping;\nimport org.springframework.web.bind.annotation.RequestBody;\nimport org.springframework.web.bind.annotation.RequestHeader;\nimport org.springframework.web.bind.annotation.RequestParam;\nimport org.springframework.web.client.RestTemplate;\n\nimport static org.springframework.http.MediaType.APPLICATION_JSON_UTF8_VALUE;\nimport static org.springframework.http.MediaType.APPLICATION_JSON_VALUE;\n\n\/**\n * Dubbo Spring Cloud Consumer Bootstrap\n *\/\n@EnableDiscoveryClient\n@EnableAutoConfiguration\n@EnableFeignClients\n@EnableScheduling\n@EnableCaching\npublic class DubboSpringCloudConsumerBootstrap {\n\n    @DubboReference\n    private UserService userService;\n\n    @DubboReference(version = &quot;1.0.0&quot;, protocol = &quot;dubbo&quot;)\n    private RestService restService;\n\n    @Autowired\n    @Lazy\n    private FeignRestService feignRestService;\n\n    @Autowired\n    @Lazy\n    private DubboFeignRestService dubboFeignRestService;\n\n    @Value(&quot;${provider.application.name}&quot;)\n    private String providerApplicationName;\n\n    @Autowired\n    @LoadBalanced\n    private RestTemplate restTemplate;\n\n    @Bean\n    public ApplicationRunner userServiceRunner() {\n        return arguments -&gt; {\n\n            User user = new User();\n            user.setId(1L);\n            user.setName(&quot;\u5c0f\u9a6c\u54e5&quot;);\n            user.setAge(33);\n\n            \/\/ save User\n            System.out.printf(&quot;UserService.save(%s) : %s\\n&quot;, user,\n                    userService.save(user));\n\n            \/\/ find all Users\n            System.out.printf(&quot;UserService.findAll() : %s\\n&quot;, user,\n                    userService.findAll());\n\n            \/\/ remove User\n            System.out.printf(&quot;UserService.remove(%d) : %s\\n&quot;, user.getId(),\n                    userService.remove(user.getId()));\n\n        };\n    }\n\n    @Bean\n    public ApplicationRunner callRunner() {\n        return arguments -&gt; {\n            callAll();\n        };\n    }\n\n    private void callAll() {\n\n        \/\/ To call \/path-variables\n        callPathVariables();\n\n        \/\/ To call \/headers\n        callHeaders();\n\n        \/\/ To call \/param\n        callParam();\n\n        \/\/ To call \/params\n        callParams();\n\n        \/\/ To call \/request\/body\/map\n        callRequestBodyMap();\n    }\n\n    @Scheduled(fixedDelay = 10 * 1000L)\n    public void onScheduled() {\n        callAll();\n    }\n\n    private void callPathVariables() {\n        \/\/ Dubbo Service call\n        System.out.println(restService.pathVariables(&quot;a&quot;, &quot;b&quot;, &quot;c&quot;));\n        \/\/ Spring Cloud Open Feign REST Call (Dubbo Transported)\n        System.out.println(dubboFeignRestService.pathVariables(&quot;c&quot;, &quot;b&quot;, &quot;a&quot;));\n        \/\/ Spring Cloud Open Feign REST Call\n        \/\/System.out.println(feignRestService.pathVariables(&quot;b&quot;, &quot;a&quot;, &quot;c&quot;));\n\n        \/\/ RestTemplate call\n        System.out.println(restTemplate.getForEntity(\n                &quot;http:\/\/&quot; + providerApplicationName + &quot;\/\/path-variables\/{p1}\/{p2}?v=c&quot;,\n                String.class, &quot;a&quot;, &quot;b&quot;));\n    }\n\n    private void callHeaders() {\n        \/\/ Dubbo Service call\n        System.out.println(restService.headers(&quot;a&quot;, &quot;b&quot;, 10));\n        \/\/ Spring Cloud Open Feign REST Call (Dubbo Transported)\n        System.out.println(dubboFeignRestService.headers(&quot;b&quot;, 10, &quot;a&quot;));\n        \/\/ Spring Cloud Open Feign REST Call\n        \/\/System.out.println(feignRestService.headers(&quot;b&quot;, &quot;a&quot;, 10));\n    }\n\n    private void callParam() {\n        \/\/ Dubbo Service call\n        System.out.println(restService.param(&quot;appblog.cn&quot;));\n        \/\/ Spring Cloud Open Feign REST Call (Dubbo Transported)\n        System.out.println(dubboFeignRestService.param(&quot;appblog.cn&quot;));\n        \/\/ Spring Cloud Open Feign REST Call\n        \/\/System.out.println(feignRestService.param(&quot;appblog.cn&quot;));\n    }\n\n    private void callParams() {\n        \/\/ Dubbo Service call\n        System.out.println(restService.params(1, &quot;1&quot;));\n        \/\/ Spring Cloud Open Feign REST Call (Dubbo Transported)\n        System.out.println(dubboFeignRestService.params(&quot;1&quot;, 1));\n        \/\/ Spring Cloud Open Feign REST Call\n        \/\/System.out.println(feignRestService.params(1, &quot;1&quot;));\n\n        \/\/ RestTemplate call\n        System.out.println(restTemplate.getForEntity(\n                &quot;http:\/\/&quot; + providerApplicationName + &quot;\/param?param=\u5c0f\u9a6c\u54e5&quot;, String.class));\n    }\n\n    private void callRequestBodyMap() {\n\n        Map&lt;String, Object&gt; data = new HashMap&lt;&gt;();\n        data.put(&quot;id&quot;, 1);\n        data.put(&quot;name&quot;, &quot;\u5c0f\u9a6c\u54e5&quot;);\n        data.put(&quot;age&quot;, 33);\n\n        \/\/ Dubbo Service call\n        System.out.println(restService.requestBodyMap(data, &quot;Hello,World&quot;));\n        \/\/ Spring Cloud Open Feign REST Call (Dubbo Transported)\n        System.out.println(dubboFeignRestService.requestBody(&quot;Hello,World&quot;, data));\n        \/\/ Spring Cloud Open Feign REST Call\n        \/\/System.out.println(feignRestService.requestBody(&quot;Hello,World&quot;, data));\n\n        \/\/ RestTemplate call\n        System.out.println(restTemplate.postForObject(\n                &quot;http:\/\/&quot; + providerApplicationName + &quot;\/request\/body\/map?param=\u5c0f\u9a6c\u54e5&quot;, data,\n                User.class));\n    }\n\n    @Bean\n    @LoadBalanced\n    @DubboTransported\n    public RestTemplate restTemplate() {\n        return new RestTemplate();\n    }\n\n    public static void main(String[] args) {\n        new SpringApplicationBuilder(DubboSpringCloudConsumerBootstrap.class)\n                .properties(&quot;spring.profiles.active=nacos&quot;).run(args);\n    }\n\n    @FeignClient(&quot;${provider.application.name}&quot;)\n    public interface FeignRestService {\n\n        @GetMapping(&quot;\/param&quot;)\n        String param(@RequestParam(&quot;param&quot;) String param);\n\n        @PostMapping(&quot;\/params&quot;)\n        String params(@RequestParam(&quot;a&quot;) int a, @RequestParam(&quot;b&quot;) String b);\n\n        @PostMapping(value = &quot;\/request\/body\/map&quot;, produces = APPLICATION_JSON_VALUE)\n        User requestBody(@RequestParam(&quot;param&quot;) String param,\n                @RequestBody Map&lt;String, Object&gt; data);\n\n        @GetMapping(&quot;\/headers&quot;)\n        String headers(@RequestHeader(&quot;h2&quot;) String header2,\n                @RequestHeader(&quot;h&quot;) String header, @RequestParam(&quot;v&quot;) Integer value);\n\n        @GetMapping(&quot;\/path-variables\/{p1}\/{p2}&quot;)\n        String pathVariables(@PathVariable(&quot;p2&quot;) String path2,\n                @PathVariable(&quot;p1&quot;) String path1, @RequestParam(&quot;v&quot;) String param);\n\n    }\n\n    @FeignClient(&quot;${provider.application.name}&quot;)\n    @DubboTransported(protocol = &quot;dubbo&quot;)\n    public interface DubboFeignRestService {\n\n        @GetMapping(&quot;\/param&quot;)\n        String param(@RequestParam(&quot;param&quot;) String param);\n\n        @PostMapping(&quot;\/params&quot;)\n        String params(@RequestParam(&quot;b&quot;) String paramB, @RequestParam(&quot;a&quot;) int paramA);\n\n        @PostMapping(value = &quot;\/request\/body\/map&quot;, produces = APPLICATION_JSON_UTF8_VALUE)\n        User requestBody(@RequestParam(&quot;param&quot;) String param,\n                @RequestBody Map&lt;String, Object&gt; data);\n\n        @GetMapping(&quot;\/headers&quot;)\n        String headers(@RequestHeader(&quot;h2&quot;) String header2,\n                @RequestParam(&quot;v&quot;) Integer value, @RequestHeader(&quot;h&quot;) String header);\n\n        @GetMapping(&quot;\/path-variables\/{p1}\/{p2}&quot;)\n        String pathVariables(@RequestParam(&quot;v&quot;) String param,\n                @PathVariable(&quot;p2&quot;) String path2, @PathVariable(&quot;p1&quot;) String path1);\n\n    }\n}<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u6ce8\u518c\u4e2d\u5fc3\u91c7\u7528\u963f\u91cc\u5df4\u5df4Nacos \u63a5\u53e3\u5b9a\u4e49 public interface UserService { boo [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[196],"tags":[],"class_list":["post-1926","post","type-post","status-publish","format-standard","hentry","category-dubbo"],"_links":{"self":[{"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/posts\/1926","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/comments?post=1926"}],"version-history":[{"count":0,"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/posts\/1926\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/media?parent=1926"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/categories?post=1926"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.appblog.cn\/index.php\/wp-json\/wp\/v2\/tags?post=1926"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}