最近开始学习SpringCloud,在此把我学习的过程记录起来,跟大家分享一下,一起学习。想学习SpringCloud的同学赶快上车吧。

 

本次学习使用得SpringBoot版本为2.0.3.RELEASE,SpringCloud版本为Finchley.RELEASE

 

 

 

首先我们创建一个Maven项目

 

 

我们把此项目当做我们项目的父项目,以后我们所有的子项目都应该继承这个项目,来看一下此项目的pom.xml文件都是依赖了什么

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <modelVersion>4.0.0</modelVersion>
  6. <groupId>cn.org.zhixiang</groupId>
  7. <artifactId>spring-cloud-demo</artifactId>
  8. <version>0.0.1-SNAPSHOT</version>
  9. <packaging>pom</packaging>
  10. <parent>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-parent</artifactId>
  13. <version>2.0.3.RELEASE</version>
  14. </parent>
  15. <dependencyManagement>
  16. <dependencies>
  17. <dependency>
  18. <groupId>org.springframework.cloud</groupId>
  19. <artifactId>spring-cloud-dependencies</artifactId>
  20. <version>Finchley.RELEASE</version>
  21. <type>pom</type>
  22. <scope>import</scope>
  23. </dependency>
  24. </dependencies>
  25. </dependencyManagement>
  26. <properties>
  27. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  28. <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  29. <java.version>1.8</java.version>
  30. </properties>
  31. <build>
  32. <plugins>
  33. <plugin>
  34. <groupId>org.springframework.boot</groupId>
  35. <artifactId>spring-boot-maven-plugin</artifactId>
  36. </plugin>
  37. </plugins>
  38. </build>
  39. </project>

 

 

 

  1. 右键项目名称:spring-cloud-demo,选择New–>Module,选择Maven,然后点击next,然后呢artifactId给项目取名为cloud-demo-provider,现在服务提供者项目就创建好了。因为接下来我们测试需要访问程序,所以接着我们引入所需的web依赖。
  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </dependency>
  6. </dependencies>

 

2.在resources文件夹下新建application.properties或者application.yml(二者任选其一),添加如下配置:

properties文件这样写

  1. spring.application.name=provider-demo
  2. server.port=8078

yml这样写

  1. spring:
  2. application:
  3. name: provider-demo
  4. server:
  5. port: 8078

spring.application.name呢,意思是给给项目起个名字叫做provider-demo

server.port呢,指定项目启动时的端口为8078

 

3.在Java文件夹下创建包cn.org.zhixiang(这个包名是我的网站域名的反转,大家可以自行定义),在此包下新建CloudDemoProviderApplication类

  1. package cn.org.zhixiang;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. @SpringBootApplication
  5. public class CloudDemoProviderApplication {
  6. public static void main(String[] args) {
  7. SpringApplication.run(CloudDemoProviderApplication.class, args);
  8. }
  9. }

@SpringBootApplication注解呢是SpringBoot的一个组合注解,主要注解为@Configuration、@EnableAutoConfiguration、@ComponentScan

我们使用SpringBoot启动项目时一般都会使用此注解,一会启动项目的时候我们在这个类中右键选择run CloudDemoProviderApplication 就可以启动了

 

4.在cn.org.zhxiang包下新建包domain,在domain包中创建一个User实体类

  1. public class User{
  2. private long id;
  3. private String name;
  4. private int age;
  5. public long getId() {
  6. return id;
  7. }
  8. public void setId(long id) {
  9. this.id = id;
  10. }
  11. public String getName() {
  12. return name;
  13. }
  14. public void setName(String name) {
  15. this.name = name;
  16. }
  17. public int getAge() {
  18. return age;
  19. }
  20. public void setAge(int age) {
  21. this.age = age;
  22. }
  23. }

 

5.在cn.org.zhxiang包下新建包controller,在controller包中创建一个类UserController

 

  1. @RestController
  2. @RequestMapping("/user")
  3. public class UserController {
  4. @GetMapping(value = "/getUser/{id}")
  5. public User getUser(@PathVariable Long id){
  6. User user=new User();
  7. user.setId(id);
  8. user.setName("张三");
  9. user.setAge(18);
  10. return user;
  11. }
  12. @GetMapping(value = "/getName")
  13. public String getName(){
  14. return "张三";
  15. }
  16. }

 

@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类。不同于提供者的是,这次启动类中需要增加一段代码

  1. @SpringBootApplication
  2. public class CloudDemoConsumerApplication {
  3. @Bean
  4. public RestTemplate restTemplate(){
  5. return new RestTemplate();
  6. }
  7. public static void main(String[] args) {
  8. SpringApplication.run(CloudDemoConsumerApplication.class, args);
  9. }
  10. }

 

RestTemplate类呢,是一个对于HTTP请求封装的一个类,相信大家都知道我们使用原生API访问一个URL需要的代码是很多的,这个呢,就是一个封装简化的版本。

@Bean注解呢,其实就等同于以前在xml中配置的如下代码

 

  1. <beans>
  2. <bean id="restTemplate" class="org.springframework.web.client.RestTemplate"/>
  3. </beans>

 

同样的,在此项目中增加一个User类,与提供者一样。

 

而UserController就不一样了

  1. @RestController
  2. @RequestMapping("/user")
  3. public class UserController {
  4. @Autowired
  5. private RestTemplate restTemplate;
  6. @GetMapping("/getUser/{id}")
  7. public User getUser(@PathVariable Long id){
  8. return restTemplate.getForObject("http://localhost:8078/user/getUser/"+id,User.class);
  9. }
  10. }

它的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

 

 

 

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

版权声明:本文为zhixiang-org-cn原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/zhixiang-org-cn/p/9287444.html