Springcloud_H版-alibaba学习笔记(七) 服务注册中心-Zookeeper

文章介绍了如何在SpringCloud项目中使用Zookeeper作为服务注册中心,替代Eureka。首先,关闭Linux服务器防火墙并启动Zookeeper,然后构建服务提供者——支付服务,通过修改pom.xml文件,添加Zookeeper依赖并排除冲突包。接着,配置yml文件,创建主启动类和业务类,使服务注册到Zookeeper。最后,构建服务消费者——订单服务,通过RestTemplate实现对支付服务的调用,并进行验证测试。

七、服务注册中心-Zookeeper

1.SpringCloud整合Zookeeper替代Eureka

1.注册中心Zookeeper

Zookeeper是一个分布式协调工具,可以实现注册中心功能

关闭Linux服务器防火墙后启动Zookeeper服务器

systemctl stop firewalld
systemctl status firewalld

Zookeeper服务器取代Eureka服务器,zk作为服务注册中心

2.构建服务提供者支付服务

1.新建cloud-provider-payment8004
2.改pom
<dependencies>  
    <!--集成zookeeper-->  
    <dependency>  
        <groupId>org.springframework.cloud</groupId>  
        <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>  
        <exclusions>  
            <!--先排除自带的zookeeper3.5.3-->  
            <exclusion>  
                <groupId>org.apache.zookeeper</groupId>  
                <artifactId>zookeeper</artifactId>  
            </exclusion>  
        </exclusions>  
    </dependency>  
    <!--添加zookeeper3.6.3版本 -->  
    <dependency>  
        <groupId>org.apache.zookeeper</groupId>  
        <artifactId>zookeeper</artifactId>  
        <version>3.6.3</version>  
        <exclusions>  
            <exclusion>  
                <artifactId>slf4j-log4j12</artifactId>  
                <groupId>org.slf4j</groupId>  
            </exclusion>  
        </exclusions>  
    </dependency>  
    <!--引入自定义的cloud-api-common包,可以使用其中的实体-->  
    <dependency>  
        <groupId>com.dt.springcloud</groupId>  
        <artifactId>cloud-api-common</artifactId>  
        <version>1.0.0-SNAPSHOT</version>  
    </dependency>  
    <!--用于页面图形化展示-->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-web</artifactId>  
    </dependency>  
    <!--用于页面图形化展示-->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-actuator</artifactId>  
    </dependency>  
    <!--热部署用到 -->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-devtools</artifactId>  
        <scope>runtime</scope>  
        <optional>true</optional>  
    </dependency>  
    <!-- 省去Get/Set方法 -->  
    <dependency>  
        <groupId>org.projectlombok</groupId>  
        <artifactId>lombok</artifactId>  
        <optional>true</optional>  
    </dependency>  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-test</artifactId>  
        <scope>test</scope>  
    </dependency>  
</dependencies>
3.写yml
server:  
  port: 8004  
  
spring:  
  application:  
    name: cloud-provider-payment  
  
  cloud:  
    zookeeper:  
      connect-string: 192.168.28.25:42181
4.主启动类
package com.dt.springcloud;  
  
  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;  
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;  
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;  
  
/**  
 * zk 支付服务提供者 主启动类  
 */  
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})  
@EnableDiscoveryClient // 该注解用于向使用consul或者zookeeper作为注册中心时注册服务  
public class PaymentMain8004 {  
    public static void main(String[] args) {  
        SpringApplication.run(PaymentMain8004.class, args);  
    }  
}
5.业务类
package com.dt.springcloud.controller;  
  
  
import lombok.extern.slf4j.Slf4j;  
import org.springframework.beans.factory.annotation.Value;  
import org.springframework.web.bind.annotation.RequestMapping;  
import org.springframework.web.bind.annotation.RestController;  
  
import java.util.UUID;  
  
/**  
 * Zk 支付 服务提供者  
 */  
@RestController  
@Slf4j  
public class PaymentController {  
  
    @Value("${server.port}")  
    private String serverPort;  
  
    @RequestMapping("/payment/zk")  
    public String paymentZK() {  
        return "springcloud with zookeeper :" + serverPort + "\t" + UUID.randomUUID().toString();  
    }  
}
6.启动8004注册进zookeeper
7.bug处理

在这里插入图片描述

处理:
由于slf4j包版本冲突, 在pom中移除zookeeper.3.6.3中的slf4j-log4j12包

  <dependency>  
        <groupId>org.apache.zookeeper</groupId>  
        <artifactId>zookeeper</artifactId>  
        <version>3.6.3</version>  
        <exclusions>  
            <exclusion>  
                <artifactId>slf4j-log4j12</artifactId>  
                <groupId>org.slf4j</groupId>  
            </exclusion>  
        </exclusions>  
    </dependency>  
8.验证测试。

访问路径:http://localhost:8004/payment/zk
在这里插入图片描述

9.验证测试2.查看zk中临时保存的内容。

进入zookeeper客户端, 由于更换了zk的端口,所以命令要指定端口。

./zkCli.sh -server 127.0.0.1:42181

查询服务

ls /services

在这里插入图片描述

查看zk中的内容
在这里插入图片描述

10.服务节点是临时节点还是持久节点

临时节点。

3.构建服务消费者订单服务

1.新建cloud-consumerzk-order80
2.改POM
<dependencies>  
    <!--集成zookeeper-->  
    <dependency>  
        <groupId>org.springframework.cloud</groupId>  
        <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>  
        <exclusions>  
            <!--先排除自带的zookeeper3.5.3-->  
            <exclusion>  
                <groupId>org.apache.zookeeper</groupId>  
                <artifactId>zookeeper</artifactId>  
            </exclusion>  
        </exclusions>  
    </dependency>  
    <!--添加zookeeper3.6.3版本 -->  
    <dependency>  
        <groupId>org.apache.zookeeper</groupId>  
        <artifactId>zookeeper</artifactId>  
        <version>3.6.3</version>  
        <exclusions>  
            <exclusion>  
                <artifactId>slf4j-log4j12</artifactId>  
                <groupId>org.slf4j</groupId>  
            </exclusion>  
        </exclusions>  
    </dependency>  
    <!--引入自定义的cloud-api-common包,可以使用其中的实体-->  
    <dependency>  
        <groupId>com.dt.springcloud</groupId>  
        <artifactId>cloud-api-common</artifactId>  
        <version>1.0.0-SNAPSHOT</version>  
    </dependency>  
    <!--用于页面图形化展示-->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-web</artifactId>  
    </dependency>  
    <!--用于页面图形化展示-->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-actuator</artifactId>  
    </dependency>  
    <!--热部署用到 -->  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-devtools</artifactId>  
        <scope>runtime</scope>  
        <optional>true</optional>  
    </dependency>  
    <!-- 省去Get/Set方法 -->  
    <dependency>  
        <groupId>org.projectlombok</groupId>  
        <artifactId>lombok</artifactId>  
        <optional>true</optional>  
    </dependency>  
    <dependency>  
        <groupId>org.springframework.boot</groupId>  
        <artifactId>spring-boot-starter-test</artifactId>  
        <scope>test</scope>  
    </dependency>  
</dependencies>
3.写yml
server:  
  port: 80  
  
spring:  
  application:  
    name: cloud-consumerzk-order80  
  
  cloud:  
    zookeeper:  
      connect-string: 192.168.28.25:42181
4.主启动类
package com.dt.springcloud.controller;  
  
import lombok.extern.slf4j.Slf4j;  
import org.springframework.beans.factory.annotation.Value;  
import org.springframework.web.bind.annotation.GetMapping;  
import org.springframework.web.bind.annotation.RequestMapping;  
import org.springframework.web.bind.annotation.RestController;  
import org.springframework.web.client.RestTemplate;  
  
import javax.annotation.Resource;  
  
@RestController  
@Slf4j  
public class OrderController {  
    @Value("${server.port}")  
    private String serverPort;  
    public static final String PAYMENT_URL = "http://cloud-provider-payment";//zk中注册的服务名称  
  
    @Resource  
    private RestTemplate restTemplate;  
  
    @RequestMapping("/consumerzk/paymentinfo")  
    public String paymentInfo() {  
        String result = this.restTemplate.getForObject(PAYMENT_URL + "/payment/zk", String.class);  
        return result;  
    }  
}
5.配置类
package com.dt.springcloud.config;  
  
import org.springframework.cloud.client.loadbalancer.LoadBalanced;  
import org.springframework.context.annotation.Bean;  
import org.springframework.context.annotation.Configuration;  
import org.springframework.web.client.RestTemplate;  
  
@Configuration  
public class ApplicationContextConfig {  
  
  
    /**  
     * 使用@LoadBalanced注解赋予RestTemplate负载均衡的能力  
     */  
    @Bean  
    @LoadBalanced    public static RestTemplate getRestTemplate() {  
        return new RestTemplate();  
    }  
}
6.验证测试
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值