SpringCloud组件:Eureka服务注册是采用主机名还是
我们一直在使用Eureka
进行注册服务,然而你有可能很少关心服务
在注册到Eureka Server
时是采用的主机名
的方式?还是IP地址
的方式?
构建项目
我们把之前章节SpringCloud组件:将微服务提供者注册到Eureka服务中心的源码复制一份修改项目名称为hengboy-spring-cloud-eureka-register-away
,并简单的对application.yml
配置文件进行修改,如下所示:
# 服务名称
spring:
application:
name: hengboy-spring-cloud-eureka-register-away
# 服务提供者端口号
server:
port: 20001
# 配置Eureka Server 信息
eureka:
client:
service-url:
defaultZone: http://localhost:10000/eureka/
# 自定义实例编号
instance:
instance-id: ${spring.application.name}:${server.port}:@project.version@
在上面配置中,并没有对注册方式进行任何修改,如果现在启动当然就是采用的默认方式进行注册,接下来我们来看看默认的方式是采用的哪种?
查看默认方式
我们仍然使用SpringCloud组件:搭建Eureka服务注册中心源码作为服务注册中心
(Eureka Server)来完成本章的测试工作。
测试步骤:
- 启动服务注册中心
- 启动本章项目
- 访问
http://localhost:10000
打开服务注册中心
管理界面- 点击服务列表服务,查看地址栏地址
当我们点击hengboy-spring-cloud-eureka-register-away:20001:v1.0
服务名称后会跳转到服务的监控信息
界面,不过我们并没有添加监控
相关的依赖或者配置,所以这里跳转后是404
访问不到页面,即使是这样我们还是可以看到跳转的网址是http://192.168.1.75:20001/actuator/info
,这也证实了一点Eureka Client
向Eureka Server
进行注册的时候默认采用的是IP Address
方式。
那么如果你想采用主机名的方式进行注册服务
,该怎么配置呢?请继续阅读。
配置使用主机名
我们如果采用主机名的方式进行注册服务
,只需要修改application.yml
配置文件内的eureka.instance.hostname
配置信息即可,如下所示:
# 配置Eureka Server 信息
eureka:
client:
service-url:
defaultZone: http://localhost:10000/eureka/
# 自定义实例编号
instance:
instance-id: ${spring.application.name}:${server.port}:@project.version@
# 配置使用主机名注册服务
hostname: node1
node1
是我本机配置的其中一个主机名
-
OS X
/Linux
系统下修改主机名
我是采用的MAC OS X
系统作为运行环境,所以修改/etc/hosts
文件对应的添加主机名
、IP
地址的映射即可,如下所示:
##
# Host Database
#
# localhost is used to configure the loopback interface
# when the system is booting. Do not change this entry.
##
127.0.0.1 localhost
255.255.255.255 broadcasthost
::1 localhost
127.0.0.1 node1
127.0.0.1 node2
-
Windows
系统下修改主机名
如果你是采用的Windows
系统作为运行环境,你可以修改C:\Windows\System32\drivers\etc\hosts
文件内容并添加映射关系。
修改完成主机名后,一定不要忘记是需要让主机名生效的,修改完成后最有效的办法是
重启你的计算机
可以生效主机名
。
接下来我们需要按照下面的步骤进行测试主机名方式注册
是否已经生效?
- 重启本章项目
- 刷新
Eureka Server
管理平台界面- 点击服务名称查看跳转地址
我们可以发现跳转的路径由原本默认的http://192.168.1.75:20001/actuator/info
方式修改成了http://node1:20001/actuator/info
,可以看到已经是使用了主机名
的方式进行的注册服务
!!!
配置优先使用IP
如果你在部署的时候某种原因导致的无法使用主机名
方式进行部署,当然你可以选择不配置eureka.instance.hostname
参数,如果你配置后仍然想使用IP Address
方式进行服务注册
,这时我们可以通过eureka.instance.prefer-ip-address
参数来进行设置,如果该参数设置为true
,则优先使用IP Address
进行服务注册
。
配置如下所示:
# 配置Eureka Server 信息
eureka:
client:
service-url:
defaultZone: http://localhost:10000/eureka/
# 自定义实例编号
instance:
instance-id: ${spring.application.name}:${server.port}:@project.version@
# 配置使用主机名注册服务
hostname: node1
# 优先使用IP地址方式进行注册服务
prefer-ip-address: true
具体的测试过程与上述配置使用主机名
一致,可以进行尝试运行测试。
既然我们可以优先使用IP
进行注册服务
,我们想根据指定的IP地址
进行注册该怎么配置呢?
配置使用指定IP
配置使用指定IP
也比较简单,我们可以进行设置eureka.instance.ip-address
参数的值来进行修改注册的IP 地址
。
我们基于上面步骤的配置文件进行修改内容如下所示:
# 配置Eureka Server 信息
eureka:
client:
service-url:
defaultZone: http://localhost:10000/eureka/
# 自定义实例编号
instance:
instance-id: ${spring.application.name}:${server.port}:@project.version@
# 配置使用主机名注册服务
hostname: node1
# 优先使用IP地址方式进行注册服务
prefer-ip-address: true
# 配置使用指定IP
ip-address: 127.0.0.1
配置文件修改完成后,进行如下步骤进行测试是否失效:
- 重启本章项目
- 刷新
Eureka Server
管理平台界面- 点击服务名称,查看跳转地址信息
我们发现跳转地址栏的地址已经使用了我们配置的ip-address
参数,地址为:http://127.0.0.1:20001/actuator/info
。
注意:如果配置
ip-address
参数后并没有开启prefer-ip-address: true
,那么仍然使用主机名
或者默认
的注册方式。
总结
我们通过几种不同的服务注册方式
来全面讲解了Eureka Client
在注册到服务注册中心
时使用的主机信息,这几种注册方式也是存在一定的优先级顺序
的,这一知识点我们在下一章结合Eureka
源码进行分别全面剖析这几种注册方式
以及优先级顺序
。
源码位置
本章源码已经上传到恒宇少年的码云
,请结合源码进行学习,感谢阅读。
- SpringBoot配套源码地址:访问码云查看源码、访问GitHub查看源码
- SpringCloud配套源码地址(
本章源码在这
):访问码云查看源码
与恒宇少年面对面
如果你喜欢
恒宇少年
的相关文章,那么就去微信公众号(恒宇少年
)关注我吧!!!
当然你也可以去 SpringCloud码云源码 项目底部扫描微信公众号二维码关注我,感谢阅读!!!
学习目录推荐
- SpringCloud相关系列文章访问:目录:SpringCloud核心技术学习目录
- SpringBoot相关系列文章请访问:目录:SpringBoot学习目录
- QueryDSL相关系列文章请访问:QueryDSL通用查询框架学习目录
- SpringDataJPA相关系列文章请访问:目录:SpringDataJPA学习目录
开源信息
这段时间一直在编写开源的相关框架,致力于公司使用的框架升级以及开源计划,将公司使用到的工具
以及插件
进行升级重构并且开源。
- 代码生成器(Code-Builder)
code-builder
代码生成器根据你提供的模板文件(目前支持freemarker
)自动生成实体类,可以很大很有效的提高开发效率。
Gitee地址
:https://gitee.com/hengboy/code-builder
Github地址
:https://github.com/hengyuboy/code-builder - 持久化框架(MyBatis-Enhance)
mybatis-enhance
是一个对mybatis
框架的增强封装,提供一系列的内部方法来完成单表数据的操作,多表数据提供DSL
方式进行操作。
Gitee地址
:https://gitee.com/hengboy/mybatis-enhance
Github地址
:https://github.com/hengyuboy/mybatis-enhance - 自动分页插件
MyBatis-Pageable
是一款自动化分页的插件,基于MyBatis
内部的插件Interceptor
拦截器编写完成,拦截Executor.query
的两个重载方法计算出分页的信息以及根据配置的数据库Dialect
自动执行不同的查询语句完成总数量的统计。
Gitee地址
:https://gitee.com/hengboy/mybatis-pageable