zoukankan      html  css  js  c++  java
  • springboot分布式之springcloud-Eureka注册中心

    1、新建一个空项目,新建一个module,命名eureka-server,选中eureka server。新建一个Module,命名provider-ticket,选中eureka discovery client。新建一个Module,命名consumer-user,选中eureka discovery client。

    2、设置服务注册中心。在eureka-server的application.properties中配置:

    server.port=8761
    #主机名
    eureka.instance.hostname=eureka-server
    #不将自己注册到eureka上
    eureka.client.register-with-eureka=false
    #不从eureka上来获取服务的注册信息
    eureka.client.fetch-registry=false
    eureka.client.service-url.defaultZone=http://localhost:8761/eureka/

    同时在其启动入口上加上@EnableEurekaServer注解。启动服务器输入localhost:8761

    3、注册服务

    需要再引入spring-boot-starter-web启动器。在provider-ticket中的application.properties配置:

    server.port=8001
    spring.application.name=provider-ticket
    #注册服务的时候使用服务的ip地址
    eureka.instance.prefer-ip-address=true
    eureka.client.service-url.defaultZone=http://localhost:8761/eureka/

    新建一个controller包:

    package com.gong.providerticket.controller;
    
    import com.gong.providerticket.service.TicketService;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    public class TicketController {
        @Autowired
        TicketService ticketService;
    
        @GetMapping("/ticket")
        public String getTicket(){
            return ticketService.getTicket();
        }
    }

    新建一个service包:

    package com.gong.providerticket.service;
    
    import org.springframework.stereotype.Service;
    
    @Service
    public class TicketService {
    
        public String getTicket(){return "唐人街探案3";
        }
    }

    然后利用maven进行打包。将打好的包复制出来放在一个文件夹中,并加上后缀8001。修改port=8002,再进行打包,将打好的包复制出来放在一个文件夹中,并加上后缀8002。进入到放置的文件夹中,分别用java -jar 运行。

    再刷新:http://localhost:8761/

    两个服务都注册进来了。

    4、发现服务并消费

    需要再引入spring-boot- starter-web启动器。首先是consumer-user中的application.properties

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

    然后是启动入口文件中:

    package com.gong.consumeruser;
    
    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 ConsumerUserApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ConsumerUserApplication.class, args);
        }
    
        @LoadBalanced//使用负载均衡机制
        @Bean
        public RestTemplate restTemplate(){
            return new RestTemplate();
        }
    }

    接着新建一个controller包:

    package com.gong.consumeruser.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 {
    
        @Autowired
        RestTemplate restTemplate;
    
        @GetMapping("/buy")
        public String buyTicket(String name){
            return name+"购买了"+restTemplate.getForObject("http://PROVIDER-TICKET/ticket",String.class);
        }
    }

    启动服务器:输入localhost:8200

    说明是启动成功了,再看下http://localhost:8761/ 

    也成功注册到注册中心了。

    接着我们去访问:localhost:8200/buy?name=张三

    成功的从provider-ticket那里获取到了信息。

    由于使用了负载均衡,所以每次请求都会轮流访问8001端口和8002端口。

  • 相关阅读:
    leetcode 203. Remove Linked List Elements 删除链表中的某个值 ---------- java
    leetcode 202. Happy Number 判断一个数是否是“Happy Number” ---------- java
    leetcode 201. Bitwise AND of Numbers Range 求范围中,每一位都是1的数 ---------- java
    js获取Html元素的实际宽度高度
    jquery中this与$this的区别
    find()与children()方法的区别
    jquery创建动态的div
    兼容性问题
    bootstrap插件小记
    禁掉a链接的几种方法
  • 原文地址:https://www.cnblogs.com/xiximayou/p/12303140.html
Copyright © 2011-2022 走看看