如何在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安裝。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM