每天學點SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud

Java學習錄發表於2018-07-11


最近開始學習SpringCloud,在此把我學習的過程記錄起來,跟大家分享一下,一起學習。想學習SpringCloud的同學趕快上車吧。


本次學習使用得SpringBoot版本為2.0.3.RELEASE,SpringCloud版本為Finchley.RELEASE




建立父Maven工程

首先我們建立一個Maven專案



每天學點SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud

我們把此專案當做我們專案的父專案,以後我們所有的子專案都應該繼承這個專案,來看一下此專案的pom.xml檔案都是依賴了什麼

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>cn.org.zhixiang</groupId>
    <artifactId>spring-cloud-demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>pom</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>
    </parent>

    <dependencyManagement>
            <dependencies>
                <dependency>
                    <groupId>org.springframework.cloud</groupId>
                    <artifactId>spring-cloud-dependencies</artifactId>
                    <version>Finchley.RELEASE</version>
                    <type>pom</type>
                    <scope>import</scope>
                </dependency>
            </dependencies>
    </dependencyManagement>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

複製程式碼



建立服務提供者


  1. 右鍵專案名稱:spring-cloud-demo,選擇New-->Module,選擇Maven,然後點選next,然後呢artifactId給專案取名為cloud-demo-provider,現在服務提供者專案就建立好了。因為接下來我們測試需要訪問程式,所以接著我們引入所需的web依賴。
<dependencies>
   <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
   </dependency>
</dependencies>
複製程式碼


2.在resources資料夾下新建application.properties或者application.yml(二者任選其一),新增如下配置:

properties檔案這樣寫

spring.application.name=provider-demo
server.port=8078
複製程式碼

yml這樣寫

spring:
  application:
    name: provider-demo
server:
  port: 8078
複製程式碼

spring.application.name呢,意思是給給專案起個名字叫做provider-demo

server.port呢,指定專案啟動時的埠為8078


3.在Java資料夾下建立包cn.org.zhixiang(這個包名是我的網站域名的反轉,大家可以自行定義),在此包下新建CloudDemoProviderApplication類

package cn.org.zhixiang;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class CloudDemoProviderApplication {

   public static void main(String[] args) {
      SpringApplication.run(CloudDemoProviderApplication.class, args);
   }
}

複製程式碼

@SpringBootApplication註解呢是SpringBoot的一個組合註解,主要註解為@Configuration、@EnableAutoConfiguration、@ComponentScan

我們使用SpringBoot啟動專案時一般都會使用此註解,一會啟動專案的時候我們在這個類中右鍵選擇run CloudDemoProviderApplication 就可以啟動了

每天學點SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud


4.在cn.org.zhxiang包下新建包domain,在domain包中建立一個User實體類

public class User{

    private long id;
    private String name;
    private int age;
    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}
複製程式碼


5.在cn.org.zhxiang包下新建包controller,在controller包中建立一個類UserController


@RestController
@RequestMapping("/user")
public class UserController {

    @GetMapping(value = "/getUser/{id}")
    public User getUser(@PathVariable Long id){
        User user=new User();
        user.setId(id);
        user.setName("張三");
        user.setAge(18);
        return user;
    }
    @GetMapping(value = "/getName")
    public String getName(){
        return "張三";
    }
}
複製程式碼


@RestController註解呢,其實就是@ResponseBody + @Controller的組合註解,@GetMapping呢,相當於@RequestMapping(value="", method = RequestMethod.GET)


現在我們這個Provider的專案的目錄結構應該是這樣的:

每天學點SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud


6.安裝剛才所說的啟動專案,開啟瀏覽器訪問http://localhost:8078/user/getUser/3 。如果瀏覽器返回一個json {"id":3,"name":"張三","age":18},那麼就代表我們的服務提供者寫好了。


建立服務消費者

1.同服務提供者的套路,我們建立一個名為cloud-demo-consumer的工程,他也只需要依賴web模組,在application.properties或者application.yml配置埠為8088,應用名稱為consumer-demo。


2.建立cn.org.zhixiang包,建立CloudDemoConsumerApplication類。不同於提供者的是,這次啟動類中需要增加一段程式碼

@SpringBootApplication
public class CloudDemoConsumerApplication {
   @Bean
   public RestTemplate restTemplate(){
      return new RestTemplate();
   }
   public static void main(String[] args) {
      SpringApplication.run(CloudDemoConsumerApplication.class, args);
   }
}
複製程式碼


RestTemplate類呢,是一個對於HTTP請求封裝的一個類,相信大家都知道我們使用原生API訪問一個URL需要的程式碼是很多的,這個呢,就是一個封裝簡化的版本。

@Bean註解呢,其實就等同於以前在xml中配置的如下程式碼


<beans>
<bean id="restTemplate" class="org.springframework.web.client.RestTemplate"/>
</beans>
複製程式碼


同樣的,在此專案中增加一個User類,與提供者一樣。


而UserController就不一樣了

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private RestTemplate restTemplate;

    @GetMapping("/getUser/{id}")
    public User getUser(@PathVariable Long id){
        return restTemplate.getForObject("http://localhost:8078/user/getUser/"+id,User.class);
    }
}
複製程式碼

它的getUser方法沒有自己實現,而是呼叫的服務提供者的getUser方法。


接著呢,我們首先啟動服務提供者,然後再啟動消費者,當我們訪問http://localhost:8088/user/getUser/3 時同樣也能取得結果,這樣一個簡單的SpringCloud專案的服務提供者和消費者就已經完成了。


GitHub:github.com/2388386839/…

碼雲:gitee.com/zhixiang_bl…


如果對您有所幫助,請記得幫忙點一個star哦



本文出自zhixiang.org.cn/#/blog/read…,轉載請保留。


相關文章