Spring Cloud服务注册中心双节点集群,使用Eureka实现,以IP方式配置,基于Spring Cloud的Camden SR5版本
来源:互联网 发布:java自己写一个线程池 编辑:程序博客网 时间:2024/05/21 09:55
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 作为服务注册功能的服务器,它是服务注册中心。而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server,并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。Spring Cloud 的一些其他模块(比如Zuul)就可以通过 Eureka Server 来发现系统中的其他微服务,并执行相关的逻辑。
综上所述,在一个分布式系统中,服务注册中心是最重要的基础部分,理应随时处于可以提供服务的状态。为了维持其可用性,使用集群是很好的解决方案。
这篇文章给出了一个 Eureka Server 双节点集群的例子。并且最后部署到 Docker,并在 linux 服务器上运行。linux 系统使用的是 ubuntu 14.04。
假设节点1的服务器的内网IP是 192.168.1.1 ,外网IP是 160.5.5.1。
假设节点2的服务器的内网IP是 192.168.1.2 ,外网IP是 160.5.5.2。
节点 1 的 JAVA 项目
节点1的 java 项目名称是 F-EurekaServer1。我使用了 Maven 管理项目。
pom.xml:
- 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
src/main/resources/application.properties:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
其中 eureka.instance.preferIpAddress=true 表示使用IP进行配置。
eureka.instance.ipAddress=192.168.1.1 指定本节点的IP。
新建一个名为 zhangchao 的包,然后新建zhangchao.Application1 类,代码如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
节点 2 的 JAVA 项目
节点2的 java 项目名称是 F-EurekaServer2。同样使用 Maven管理项目。
pom.xml:把节点 1 的 pom.xml 复制粘贴过来,把 <artifactId>F-EurekaServer1</artifactId>
修改成 <artifactId>F-EurekaServer2</artifactId>
即可。
src/main/resources/application.properties:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
新建一个名为 zhangchao 的包,然后新建zhangchao.Application2 类,代码如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
打包
eclipse 中,在项目上右键 → Run As → Maven build … → Edit Configuration 对话框中的 Goals 文本框中输入 clean package → 点击对话框中的 Run 按钮。等两个节点的 java 项目打包完毕。可以在 项目文件夹/target
路径下找到打包好的 jar 文件。
节点 1 Docker 部署
新建 EurekaServer1-v1 文件夹。文件夹内容如下所示:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
Dockerfile:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
把文件夹上传至 ubuntu 服务器,cd 命令进入EurekaServer1-v1目录,执行 docker build -t zc/eureka1:v1 .
编译成 Docker 镜像。
再执行 docker run --name eureka1 -p 8761:8761 -d zc/eureka1:v1
创建容器并运行。
节点 2 Docker 部署
新建 EurekaServer2-v1 文件夹。文件夹内容如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
Dockerfile:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
把文件夹上传至 ubuntu 服务器,cd 命令进入EurekaServer2-v1目录,执行 docker build -t zc/eureka2:v1 .
编译成 Docker 镜像。
再执行 docker run --name eureka2 -p 8761:8761 -d zc/eureka2:v1
创建容器并运行。
效果
如果你的电脑不在服务器的内网,你可以访问外网ip。我们假设节点 1 和节点 2 的外网 IP 分别是 160.5.5.1 和 160.5.5.2。直接用浏览器访问访问 http://160.5.5.1:8761/ 或者 http://160.5.5.2:8761/ 就能看到管理页面。如果你可以访问到内网,直接把上面的 IP 替换成内网 IP 即可。
下面是访问节点 1 的监控页面:
节点 2 的页面和节点 1 的类似,只不过把 IP 地址做了一下互换。
- Spring Cloud服务注册中心双节点集群,使用Eureka实现,以IP方式配置,基于Spring Cloud的Camden SR5版本
- Spring Cloud服务注册中心双节点集群,使用Eureka实现,以IP方式配置,基于Spring Cloud的Camden SR5版本
- Spring Cloud 基于eureka 服务注册中心
- 【Spring Cloud】Eureka服务注册中心搭建
- Spring Cloud 注册中心Eureka
- Spring-cloud注册中心 Eureka
- Spring Cloud---注册中心Eureka的高可用配置
- springboot填坑之 -- spring cloud基于ip的discovery服务注册中心配置
- springboot填坑之 -- spring cloud基于ip的discovery服务注册中心配置
- spring cloud-实现Eureka注册中心的HA
- spring cloud-实现Eureka注册中心的HA
- 基于spring-cloud实现eureka注册服务小案例
- 基于spring-cloud实现eureka注册服务小案例
- 【Spring Cloud学习】 搭建简单的服务注册中心Spring cloud Eureka
- spring cloud 实现Eureka注册服务
- Spring Cloud Eureka-服务注册
- Spring Cloud Eureka——注册中心集群
- Spring Cloud(九)高可用的分布式配置中心 Spring Cloud Config 集成 Eureka 服务
- spark筑基篇-01-Eclipse开发Spark HelloWorld
- [Leetcode][python]Decode Ways
- Poj 2406 Power Strings
- ubuntu14.04安装oh-my-zsh
- hadoop学习之hadoop2.8.0完全分布式集群安装
- Spring Cloud服务注册中心双节点集群,使用Eureka实现,以IP方式配置,基于Spring Cloud的Camden SR5版本
- 图与例解读Async/Await
- Hadoop2.7.3+HBase1.2.5+ZooKeeper3.4.6搭建分布式集群环境
- as 下载地址总汇
- [2017纪中10-28]图 最小生成树+LCT
- RDLC 报表 引用外部图片 file用相对路径 开发工具vs2015
- BBR与CoDel
- Xcode9学习笔记19
- 对抗攻击最新研究:仅修改「一个像素」即可骗过神经网络!