• 如何在kubernetes中使用Spring Cloud微服务



      在kubernetes环境比较特殊,各个容器组pods之间是不能直接访问的,只能通过service、NodePort等方式才能访问,那我们应该怎么在k8s里跑Spring Cloud微服务呢?以下通过Consul和Spring Boot Admin来讲解。

      1、注册中心如何在kubernetes使用?以下以consul为例,当然其它注册中心(如nacos、eruka等)同样也可以的。

      通常在虚拟机或者实体机里的注册中心,就填写host和port就可以了。



      但是会出现以下的报错。





      从上面的错误信息里能看出来,是因为Consul中心直接访问容器,这个当然是访问不了的,我们Pods之间只能通过Service、NodePort等才能访问,那我们应该怎么做才可以了?

      思路很简单,就是把容器名直接指定为Service名就可以了。

      通过

      cloud:
        consul:
          host: consul-consul-server.consul.svc.cluster.local
          port: 8500
          discovery:
            prefer-ip-address: false # 设置为false
            prefer-agent-address: false # 设置为false
            hostname: config-service.xxx.svc.cluster.local # 设置为k8s内部域名,当然你也可以使用服务器.命名空间
            service-name: config-service
            port: 9181
            scheme: http
    

      




      重新跑一下,注册中心就有配置中心的注册服务了。






     

      2、跑一个简单的应用:Spring Boot Admin:

      同样的,和上面一个加入spring.cloud.consul.discovery.prefer-ip-address等配置就可以完成注册





     

      文中提到的consul,大家可以到网上找教程安装,建议大家使用helm安装。

  • 相关阅读:
    for循环删除数组中的元素crash问题
    iOS判断字符串中含不含有汉字
    iOS 拨打电话(解决openURL延迟和不同方法比较)
    ios oc单例宏定义
    iOS UIBezierPath简单实用
    iOS视图切割圆角
    iOS 内购集成与遇到的坑,添加新内购项目
    iOS工程中创建pch文件
    四舍五入的方法
    ScrollView定时器复用
  • 原文地址:https://www.cnblogs.com/javalittleman/p/15497059.html
Copyright © 2020-2023  润新知