1. 程式人生 > >每天學點SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud

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

prope long mapping .org -- xsd pom.xml 開始學習 conf

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

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

創建父Maven工程
首先我們創建一個Maven項目

我們把此項目當做我們項目的父項目,以後我們所有的子項目都應該繼承這個項目,來看一下此項目的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>

創建服務提供者

右鍵項目名稱: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 就可以啟動了

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")
br/>@RequestMapping("/user")

@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的項目的目錄結構應該是這樣的:

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
br/>@Bean
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")
br/>@RequestMapping("/user")

@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:https://github.com/2388386839/spring-cloud-demo

碼雲:https://gitee.com/zhixiang_blog/apring-cloud-demo

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

本文出自https://zhixiang.org.cn/#/blog/read/366fba06-53f7-4882-b313-c87506bd2a93,轉載請保留。

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