学好SpringCloud从搭建项目开始

学好SpringCloud从搭建项目开始

1、什么是SpringCloud

Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的开发便利性简化了分布式系统的开发,比如服务发现、服务网关、服务路由、链路追踪等。Spring Cloud 并不重复造轮子,而是将市面上开发得比较好的模块集成进去,进行封装,从而减少了各模块的开发成本。换句话说:Spring Cloud 提供了构建分布式系统所需的“全家桶”。

2、SpringCloud各组件配置使用运行流程
  • 1、请求统一通过API网关(Zuul)来访问内部服务.

  • 2、网关接收到请求后,从注册中心(Eureka)获取可用服务

  • 3、由Ribbon进行均衡负载后,分发到后端具体实例

  • 4、微服务之间通过Feign进行通信处理业务

  • 5、Hystrix负责处理服务超时熔断

  • 6、Turbine监控服务间的调用和熔断相关指标

搭建项目,创建服务注册中心

3.1 一个web-app的maven工程。此处命名为:springcloud

3.2 在该工程下创建module。

在这里插入图片描述
在这里插入图片描述
3.3 勾上Eureka Server。以便自动导入包
在这里插入图片描述
3.4 点击next,创建项目后,检查相应的pom文件

<dependencies>

    <!--eureka server -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka-server</artifactId>
        <version>1.4.2.RELEASE</version>
    </dependency>

    <!-- spring boot test-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>

</dependencies>

3.5 在application中加入注解**@EnableEurekaServer**,申明此处为服务注册中心。
在这里插入图片描述

3.6 yml中的加入如下配置:registerWithEureka 和fetchRegistry 设置为false,表明自己属于服务中心主体

server:
  port: 8761

eureka:
  instance:
    hostname: localhost
  client:
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

3.7 启动服务,登陆浏览器查看。http://localhost:8761/
在这里插入图片描述

4、创建生产者

4.1 检查一下pom文件,这里提供依赖如下:

<dependencies>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka</artifactId>
        <version>1.4.4.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

4.2 application中加入注解**@EnableEurekaClient**,表明自己属于一个生产者。

这里为了方便测试,直接使用**@RestController**获取返回值。

@SpringBootApplication
@EnableEurekaClient
@RestController
public class ServiceHiApplication
{
    public static void main(String[] args)
    {
        SpringApplication.run(ServiceHiApplication.class, args);
    }

    @Value("${server.port}")
    String port;

    @RequestMapping("/hi")
    public String home(@RequestParam String name)
    {
        return "hi " + name + ",i am from port:" + port;
    }
}

4.3 yml配置

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8763
spring:
  application:
    name: service-hi

注意:端口不能与上面的相同。这里的服务name:service-hi 可以根据自己情况定义。

4.4 运行服务,登陆环境 http://localhost:8765/hi?name=fys

可以看到如下信息。这里用postman进行测试:
在这里插入图片描述

4.5 在8761这个端口中,也能看到,该信息已经在服务中心进行了注册。名字为我们yml中进行配置的名字。
在这里插入图片描述

5、创建消费者

5.1 创建消费者modul,流程如上述工程创建流程。

5.2 查看pom.xml文件

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.2.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>serviceribbon</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>serviceribbon</name>
<description>Demo project for Spring Boot</description>

<properties>
    <java.version>1.8</java.version>
    <spring-cloud.version>Greenwich.RC2</spring-cloud.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka</artifactId>
        <version>1.4.4.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-ribbon</artifactId>
        <version>1.4.2.RELEASE</version>
    </dependency>
    <!--断路器-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-hystrix</artifactId>
        <version>1.4.4.RELEASE</version>
    </dependency>
</dependencies>

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

5.3 yml文件配置

eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
server:
port: 8764
spring:
application:
name: service-ribbon

在工程的配置文件指定服务的注册中心地址为http://localhost:8761/eureka/ 。

5.4 编写启动类

@EnableDiscoveryClient表明标注类是消费者,加入restTemplate以消费相关的服务

@SpringBootApplication
@EnableDiscoveryClient
public class ServiceribbonApplication {

  public static void main(String[] args) {

    SpringApplication.run(ServiceribbonApplication.class, args);
  }
@Bean
@LoadBalanced
RestTemplate restTemplate()
{
    return new RestTemplate();
}
}
6、创建service和controlle

6.1 service层:

@Service
public class HelloService {
@Autowired
RestTemplate restTemplate;
public String hiService(String name)
{
    return restTemplate.getForObject("http://SERVICE-HI/hi?name=" + name, String.class);
}
}

6.2 controller层:

@RestController
public class HelloControler {
@Autowired
HelloService helloService;
@RequestMapping(value = "/hi")
public String hi(@RequestParam String name)
{
    return helloService.hiService(name);
}
}

6.3 运行服务,在浏览器中输入http://localhost:8764/hi?name=admin
在这里插入图片描述

6.4 输入http://localhost:8761/
在这里插入图片描述

equestMapping(value = "/hi")
public String hi(@RequestParam String name)
{
    return helloService.hiService(name);
}
}

``

6.5 运行服务,在浏览器中输入http://localhost:8764/hi?name=admin

在这里插入图片描述

6.6输入http://localhost:8761/

在这里插入图片描述
看到上面那张图就说明你的SpringCloud框架已经搭建成功了!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值