SpringCloud自学入门-服务提供者创建和服务中心高可用

1.创建client服务提供者,与创建server项目步骤相同

2.在启动类上面加@EnableDiscoveryClient注解表明自己是服务端,向注册中心注册

 

@EnableDiscoveryClient
@SpringBootApplication
public class EurekaClientApplication {

   public static void main(String[] args) {
      SpringApplication.run(EurekaClientApplication.class, args);
   }
}

 

 

 

3.修改application.properties配置文件

 

#指定服务中心地址
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
#指定服务端口号
server.port=8762
#服务名,服务与服务之间相互调用一般都是根据这个name
spring.application.name=hello-service

4.编写hello控制器

 

 

@RestController
public class HelloControler {
    private final Logger logger = Logger.getLogger(getClass());

    @Autowired
    private DiscoveryClient client;

    @RequestMapping("/hello")
    public String sayHello(){
        ServiceInstance instance = client.getLocalServiceInstance();
        logger.info("/hello,host"+instance.getHost()+",server_id:"+instance.getServiceId());
        return "hello world";
    }
}

 这里注入了一个DiscoveryClient对象来打印服务相关内容

 

5.我们启动server项目和client项目,打开http://localhost:8761/,已经有hello的项目注册

访问http://localhost:8762/hello,控制台打印

2018-01-25 11:32:17.428  INFO 5260 --- [nio-8762-exec-1] z.e.controller.HelloControler            : /hello,hostDESKTOP-1NHDBBI,server_id:hello-service

至此,我们服务项目和注册中心已经搭建完毕,接下来我们实现服务注册中心的高可用

6.在server项目中创建application-peer1.properties和application-peer2.properties两个配置文件,分别作为peer1和peer2两个注册中心的配置,将peer1的serviceurl指向peer2,peer2的serviceURL指向peer1

peer1:

 

server.port=8761
spring.application.name=eureka-server
eureka.instance.hostname=localhost
eureka.client.service-url.defaultZone=http://peer2:8861/eureka/

peer2:

 

 

server.port=8861
spring.application.name=eureka-server
eureka.instance.hostname=peer2
eureka.client.service-url.defaultZone=http://peer1:8761/eureka/

7.修改系统host文件,否则在本地将访问不到。在最后添加下面两行

 

 127.0.0.1 peer1
 127.0.0.1 peer2

8.通过spring.profiles.active属性来分别启动peer1和peer2

 java -jar E:\ideaWork\cloudLearn\eureka-server\target\eureka-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1

 java -jar E:\ideaWork\cloudLearn\eureka-server\target\eureka-server-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2

启动完成后我们打开peer1的注册中心

已经有peer2的服务,同样peer2服务注册中心也有peer1的服务

修改client项目配置文件中

 

eureka.client.serviceUrl.defaultZone=http://peer1:8761/eureka/

然后启动我们的client项目,会发现两个服务中心都有hello-service项目注册,这样在有一个注册服务器宕机的情况下另一个注册中心也可以正常运行,这样就实现了注册中心的高可用

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值