码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • springcloud05——Zookeeper实现支付微服务


    在这里插入图片描述

    前 言
    ?? 作者简介:,长跑型选手,立志坚持写10年博客,专注于java后端
    专栏简介:深入、全面、系统的介绍springcloud与springcloud Alibaba微服务常用技术栈
    ?? 文章简介:本文将使用zookeeper作为集群注册组件,建议收藏备用,创作不易,敬请三连哦
    ??文章推荐:
    zookeeper入门到精通01——zookeeper入门
    zookeeper入门到精通02——zookeeper的本地安装操作
    zookeeper入门到精通03——zookeeper集群搭建
    zookeeper入门到精通04——zookeeper集群选举与集群操作
    Zookeeper入门到精通05——Zookeeper客户端命令行操作
    zookeeper入门到精通06——zookeeper客户端API创建节点
    zookeeper入门到精通07——zookeeper客户端API节点操作与原理

    微服务架构与springcloud 01——微服务入门
    微服务架构与springcloud02——父工程构建及支付模块实现
    微服务架构与springcloud03——项目热部署与消费者订单模块
    微服务架构与springcloud04——Eureka服务注册与发现
    大厂面试真题|面经

    文章目录

    • 一、准备工作
      • 1.1 技术架构
      • 1.2 集群启动
      • 1.3 网络检测
    • 二、支付服务进zookeeper
      • 2.1 新建项目
      • 2.2 pom文件
      • 2.3 yml文件
      • 2.4 主启动类
      • 2.5 controller
      • 2.6 测试

    一、准备工作

    1.1 技术架构

    使用Zookeeper服务注册与发现与使用Eureka基本上是一致的,其技术架构如图
    在这里插入图片描述

    1.2 集群启动

    笔者为了贴近实际生产,使用了zookeeper集群。如果您还没有zookeeper集群,推荐参考下面两个博客进行安装与搭建。当然,您要是只使用一台zookeeper服务器也是可以的,后面我就不再赘述了。

    zookeeper入门到精通02——zookeeper的本地安装操作
    zookeeper入门到精通03——zookeeper集群搭建

    关闭防火墙。

    systemctl stop firewalld
    systemctl status firewalld
    
    • 1
    • 2

    依次开启zookeeper集群的服务器。

    zkServer.sh start
    
    • 1

    如果您参考了我的博客编写了一键启动的脚本,也可以这样。

    zk.sh start
    
    • 1

    依次查看状态,确定是否启动成功。

    zkServer.sh status
    
    • 1

    或者使用j脚本一键查看。

    zk.sh status
    
    • 1

    在这里插入图片描述

    1.3 网络检测

    查看网络通信是否正常。先在虚拟机服务器上使用如下命令查看ip。

    ifconfig
    
    • 1

    在这里插入图片描述

    然后在客户端主机ping一下zookeeper集群的各台主机,确保网络畅通。
    在这里插入图片描述

    二、支付服务进zookeeper

    2.1 新建项目

    为了区分,中间空个8003。新建工程cloud-provider-payment8004。
    在这里插入图片描述

    2.2 pom文件

    pom文件。其实就是替换下eureka就行,其它的与8001微服务是一致的。注意和数据库有关的依赖不要引入,因为我们接下来不使用数据库,也不会进行数据库的配置,如果引入就会出错哟。

    
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
        
            org.projectlombok
            lombok
            true
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
        
        
            com.wangzhou.springcloud
            cloud-api-commons
            ${project.version}
        
    
        
        
        
            org.springframework.cloud
            spring-cloud-starter-zookeeper-discovery
            
                
                
                    org.apache.zookeeper
                    zookeeper
                
            
        
    
        
        
            org.apache.zookeeper
            zookeeper
            3.4.10
            
                
                    org.slf4j
                    slf4j-log4j12
                
            
        
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52

    服务器下载的zookeeper的jar包版本要与自己下载的zookeeper软件版本一致哦,如下图可以查看到服务器使用的zookeeper版本,不一致就可以排除掉原来的,再替换添加对应版本(上面就做了这件事)。
    在这里插入图片描述

    2.3 yml文件

    application.yml文件也搞好。很简单,写端口号,以及zookeeper的ip,记住这样的核心理念。

    #端口号
    server:
      port: 8004
    
    
    spring:
      application:
        #服务别名——注册到zookeeper注册中心的名称
        name: cloud-provider-payment
      cloud:
        zookeeper:
          connect-string: 192.168.106.43:2182,192.168.106.44:2182,192.168.106.45:2182 #linux的ip加暴露的端口号
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    2.4 主启动类

    @EnableDiscoveryClient
    @SpringBootApplication
    public class PaymentMain8004 {
        public static void main(String[] args) {
            SpringApplication.run(PaymentMain8004.class, args);
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.5 controller

    我们前面已经按照mvc的框架写过很多次了,这里主要介绍spring boot对zookeeper的集成。因此我们就直接在controller中对业务进行处理了。

    @RestController
    @Slf4j
    public class PaymentController {
    
        @Value("${server.port}")
        private String serverPort;
    
        @RequestMapping("/payment/zk")
        public String paymentzk() {
            return "springcloud with zookeeper:" + serverPort + "	" + UUID.randomUUID().toString();
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    2.6 测试

    启动zookeeper客户端(笔者修改过端口号,修改为2182,如未修改可以不指定ip与端口号,直接使用./zkCli.sh)

    ./zkCli.sh -server ip:port
    
    • 1

    在这里插入图片描述
    查看节点信息

    [zk: localhost:2182(CONNECTED) 0] ls /
    [sanguo1, sanguo2, zookeeper]
    
    • 1
    • 2

    启动8004模块。在这里插入图片描述
    访问下:http://localhost:8004/payment/zk
    在这里插入图片描述
    zookeeper就正式整合到支付微服务咯。在zookeeper客户端使用命令查看下,可以看到注册的详细信息哟。
    在这里插入图片描述
    这篇文章就介绍到这里咯,如果小伙伴在准备秋招,可以多背背面试题,刷刷算法,推荐:大厂面试真题|面经,真的超级全哦

  • 相关阅读:
    【FPGA教程1】Verilog基础语法
    【学习笔记】《Python深度学习》第六章:深度学习用于文本和序列
    C++笔记之通用多态函数包装器std::function
    C++设计模式之单例模式、模板模式、状态模式、原型模式、CRTP 模式、组件模式、观察者模式、发布-订阅模式、访问者模式
    运维监控系统 PIGOSS BSM 拓扑自动发现原理
    逻辑漏洞之越权漏洞
    C#面:请解释ASP.NET中的web页面与其隐藏类之间的关系
    SpringBoot整合websockt实现消息对话
    算法题:分发饼干
    VW ware安装Ubuntu虚拟机及环境配置
  • 原文地址:https://blog.csdn.net/drhrht/article/details/126041577
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号