zoukankan      html  css  js  c++  java
  • 33、springboot整合springcloud

    Spring Cloud

    Spring Cloud是一个分布式的整体解决方案。Spring Cloud 为开发者提供了在分布式系统
    (配置管理,服务发现,熔断,路由,微代理,控制总线,一次性token,全局琐,leader选举,
    分布式session,集群状态)中快速构建的工具,使用Spring Cloud的开发者可以快速的启
    动服务或构建应用、同时能够快速和云平台资源进行对接。
    SpringCloud分布式开发五大常用组件
    服务发现——Netflix Eureka 
    客服端负载均衡——Netflix Ribbon 
    断路器——Netflix Hystrix 
    服务网关——Netflix Zuul 
    分布式配置——Spring Cloud Config
    新建工程:
    服务发现(注册中心):Eureka

    此时需要引入:

    配置文件

    server.port=8761
    #主机名
    eureka.instance.hostname=server
    #不做高可用不进行设置
    #不把本身注册在注册中心
    eureka.client.register-with-eureka=false
    #不从eureka上获取服务的注册信息
    eureka.client.fetch-registry=false
    #服务中心地址
    eureka.client.service-url.DEFAULT_ZONE=http://localhost:8761/eureka/

    开启服务:

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

    访问网页:

    此时的服务是开启的!!!

     服务提供者:

     

    TicketService.java

    package com.cr.provider.service;
    import org.springframework.stereotype.Service;
    @Service
    public class TicketService {
        public String buyTicket(){
            return "战狼2";
        }
    }

     TicketController.java

    import org.springframework.web.bind.annotation.RestController;
    @RestController
    public class TicketController {
        @Autowired
        TicketService ticketService;
    
        //通过http协议进行发送的
        @GetMapping("/buy")
        public String getTicket(){
            return ticketService.buyTicket();
        }
    }

    配置文件:

    server.port=8081
    #应用起名字spring.application.name=provider
    #注册服务时使用服务的ip地址
    eureka.instance.prefer-ip-address=true
    #服务中心地址
    eureka.client.service-url.DEFAULT_ZONE=http://localhost:8761/eureka/
    启动服务访问:
    @SpringBootApplication
    public class ProviderApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ProviderApplication.class, args);
        }
    
    }

     

    此时查看注册证中心:

     

    此时打包两个jar文件分别未8081、8082端口,分别进行多个服务的注册

    此时:同一个应用的两个实例

    服务消费者:

     

    UserController.java

    package com.cr.consumer.controller;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    import org.springframework.web.client.RestTemplate;
    
    @RestController
    public class UserController {
    
        //用于获取http请求的信息
        @Autowired
        RestTemplate restTemplate;
    
    
        @GetMapping("/buyTicket")
        public  String buyTicket(String name){
    
            String ticket = restTemplate.getForObject("http://PROVIDER/buy", String.class);
            return name + "购买了" + ticket ;
        }
    
    }

    配置文件:

    server.port=8088spring.application.name=consumer
    #注册服务时使用服务的ip地址
    eureka.instance.prefer-ip-address=true
    #服务中心地址
    eureka.client.service-url.DEFAULT_ZONE=http://localhost:8761/eureka/

    主类:

    package com.cr.consumer;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
    import org.springframework.cloud.client.loadbalancer.LoadBalanced;
    import org.springframework.context.annotation.Bean;
    import org.springframework.web.client.RestTemplate;
    
    //开启发现服务功能
    @EnableDiscoveryClient
    @SpringBootApplication
    public class ConsumerApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ConsumerApplication.class, args);
        }
    
    
        //http请求
        @LoadBalanced//使用负载均衡机制
        @Bean
        public RestTemplate restTemplate(){
            return new RestTemplate();
        }
    }

    启动服务:

     

    负载均衡机制,没执行一次就更换一次
  • 相关阅读:
    自动化CodeReview
    10个有关RESTful API良好设计的最佳实践
    ASP.NET Core 获取控制器上的自定义属性
    [转] Autofac创建实例的方法总结
    PetaPoco
    LogViewer
    hdoj:2047
    hdoj:2046
    hdoj:2045
    hdoj:2044
  • 原文地址:https://www.cnblogs.com/Mrchengs/p/10507037.html
Copyright © 2011-2022 走看看