Kubernetes通过HostAliases自定义hosts

Posted saynaihe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Kubernetes通过HostAliases自定义hosts相关的知识,希望对你有一定的参考价值。

背景:

今天突然就有了那么一个需求,记录一下:腾讯云的redis内网地址都是IP的方式。我们的服务注册在了nacos中。小伙伴本地测试链接上nacos(nacos开通了外网访问),获取redis中redis配置都是内网的redis IP故无法加入注册到集群。同事问我能不能将Redis ip设置成域名的方式,那样他本地好歹能做个假的解析做一个欺骗把服务启动起来?(懒得改代码毕竟)
正好就搜到了这两篇文章:Kubernetes之自定义hosts使用 HostAliases 向 Pod /etc/hosts 文件添加条目
故记录一下!

Kubernetes通过HostAliases自定义hosts

初始配置:

nacos中关于redis的配置:

至于腾讯云的redis服务是内网IP的方式,虽然现在也有了可以开启外网地址的途径:


但是如果开通外网地址,还是会涉及到修改代码判断内网外网地址,nacos增加配置,甚至要设置安全组?放弃了。还是老老实实使用host的方式去了

修改host的方式

没有看到那两篇文章的时候我就想到了host的方式:恩 最苯的方法就是修改主机的host配置文件:

基本就是那么一个过程我也测试通过了.紧接着问题有来了,我有四台work节点。难道要每台work节点都要设置Host吗?如果以后修改怎么办?增加机器呢?不想使用这样的方式,还有就是镜像打包的时候直接打进去host?也不现实,我镜像是准备复用的还…然后就找到了前面的两篇文章,采用了HostAliases的方式!

HostAliases自定义hosts

nacos配置

先修改一下nacos中配置文件:

修改发版模板文件

我的ci/cd都直接偷懒用jenkins。反正现在还够用** tpl模板** 发版将表情替换生成yaml文件,然后发布到集群中,使用用的这种的思路:
我的tpl文件:

      hostAliases:                   #配置hosts文件
      - ip: "10.0.4.82"            #配置解析的IP
        hostnames:
        - "qa-xx.xxxx.com"

基本就是那么玩的。jenkins 更新服务,查看pod启动日志没有问题,pod都running了 ,进入pod查看hosts一下:

ok,就到这里了,只是简单记录一下**HostAliases!**以后说不定还能用到…

以上是关于Kubernetes通过HostAliases自定义hosts的主要内容,如果未能解决你的问题,请参考以下文章

Kubernetes通过HostAliases自定义hosts

Kubernetes通过HostAliases自定义hosts

K8s hosts 解析 HostAliases

配置Pod的 /etc/hosts

配置Pod的 /etc/hosts

K8S pod hosts和resolv.conf