国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

【Spring Cloud Kubernetes】使用k8s原生service實(shí)現(xiàn)服務(wù)注冊(cè)和發(fā)現(xiàn)

這篇具有很好參考價(jià)值的文章主要介紹了【Spring Cloud Kubernetes】使用k8s原生service實(shí)現(xiàn)服務(wù)注冊(cè)和發(fā)現(xiàn)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

@TOC

背景

現(xiàn)在微服務(wù)開(kāi)發(fā)模式應(yīng)用的越來(lái)越廣泛,注冊(cè)中心Eureka也逐漸被其它注冊(cè)中心產(chǎn)品替代,比如阿里出品的Nacos。隨著云原生相關(guān)技術(shù)的普及,k8s迅猛發(fā)展,我們把K8s中的Pod暴露給外部訪問(wèn),通過(guò)少了Service,這也是今天的主角。

有沒(méi)有發(fā)現(xiàn),其實(shí)Service已經(jīng)解決了Pod的注冊(cè)與發(fā)現(xiàn)的問(wèn)題,并且也實(shí)現(xiàn)了負(fù)載,我們?cè)诨谠圃_(kāi)發(fā)微服務(wù)的時(shí)候,可以利用Service的能力,獲取后面的Pod列表,通過(guò)Ribbon等客戶端負(fù)載對(duì)Pod發(fā)起調(diào)用,也可以直接利用Service的負(fù)載能力進(jìn)行調(diào)用。k8s內(nèi)部會(huì)使用ETCD服務(wù)維護(hù)這些信息的變化。Spring官網(wǎng)也為k8s提供了一套原生的支持子項(xiàng)目,那就是Spring Cloud Kubernetes。

本地開(kāi)發(fā)環(huán)境說(shuō)明

開(kāi)發(fā)依賴 版本
Spring Boot 3.1.0
Spring Cloud 2022.0.3
JDK 20

本地非K8s環(huán)境如何進(jìn)行開(kāi)發(fā)調(diào)試

在傳統(tǒng)的微服務(wù)開(kāi)發(fā)中,會(huì)借助Nacos注冊(cè)中心,現(xiàn)在沒(méi)有Nacos了,本地通過(guò)Fabric8,底層與k8s的API Server進(jìn)行交互,獲取集群內(nèi)的資源信息

主要pom.xml依賴

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-kubernetes-fabric8-all</artifactId>
        </dependency>
    </dependencies>

啟動(dòng)類

  • 使用@EnableDiscoveryClient開(kāi)啟服務(wù)發(fā)現(xiàn)注冊(cè)功能
  • 使用@EnableFeignClients啟用@FeignClient功能
package com.wen3.springcloudk8s.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication
public class DemoSpringCloudKubernetesApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoSpringCloudKubernetesApplication.class, args);
    }
}

寫一個(gè)Feign的調(diào)用

  • 如果多個(gè)微服務(wù)都是部署在集群內(nèi),可以通過(guò)service相互調(diào)用
  • 如果是本地調(diào)集群內(nèi)的微服務(wù),可以指定url參數(shù),優(yōu)級(jí)級(jí)比name要高,url可以指定為集群內(nèi)service暴露的外部端點(diǎn)
package com.wen3.springcloudk8s.demo.feign;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.Map;

@FeignClient(name = "springboot-min", url = "${springboot-min.url:}")
public interface SpringMinFeignClient {

    @RequestMapping(path = "/hello")
    String hello(@RequestBody(required = false) Map<String,Object> bodyMap);
}

寫一個(gè)Controller

package com.wen3.springcloudk8s.demo.controller;

import com.wen3.springcloudk8s.demo.feign.SpringMinFeignClient;
import io.fabric8.kubernetes.api.model.ConfigMap;
import io.fabric8.kubernetes.api.model.ConfigMapList;
import io.fabric8.kubernetes.client.KubernetesClient;
import io.fabric8.kubernetes.client.dsl.ApiextensionsAPIGroupDSL;
import io.fabric8.kubernetes.client.dsl.MixedOperation;
import jakarta.annotation.Resource;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.cloud.kubernetes.commons.KubernetesClientProperties;
import org.springframework.cloud.kubernetes.fabric8.discovery.KubernetesDiscoveryClient;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*;

import java.util.Enumeration;
import java.util.List;
import java.util.Map;

@RequestMapping(path = "/k8s")
@RestController
public class K8sController {

    @Resource
    private DiscoveryClient discoveryClient;
    @Resource
    private SpringMinFeignClient springMinFeignClient;
    @Resource
    private KubernetesClientProperties kubernetesClientProperties;

    @GetMapping("/services")
    public List<String> getServices() {
        return discoveryClient.getServices();
    }

    @RequestMapping(path = "/hello")
    public String hello(@RequestBody(required = false) Map<String,Object> bodyMap) {
        return springMinFeignClient.hello(bodyMap);
    }
}

bootstrap.yaml

debug: true
logging:
  level:
    root: debug

spring:
  application:
    name: spring-cloud-k8s-demo
  cloud:
    kubernetes:
      client:
        namespace: demo
        master-url: https://k8s-cluster-ip:6443
        trust-certs: true
        oauth-token: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
      discovery:
        enabled: true
        # all-namespaces為true,代表在整個(gè)集群范圍查找資源,可能沒(méi)有權(quán)限
        all-namespaces: false
        namespaces:
          - cop
      reload:
        enabled: true
        mode: event
#        mode: polling
#        period: 5000
      loadbalancer:
        enabled: true
        mode: service
        clusterDomain: cluster.local
        portName: rest


springboot-min:
  url: http://10.79.193.64:8880

k8s部署springboot-min

寫一個(gè)最簡(jiǎn)單的微服務(wù),提供一個(gè)/hello接口,部署到k8s,這一步直接省略。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-531492.html

到了這里,關(guān)于【Spring Cloud Kubernetes】使用k8s原生service實(shí)現(xiàn)服務(wù)注冊(cè)和發(fā)現(xiàn)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 云原生Kubernetes:阿里云托管k8s集群ACK創(chuàng)建和使用

    云原生Kubernetes:阿里云托管k8s集群ACK創(chuàng)建和使用

    目錄 ? 一、理論 1.容器服務(wù)Kubernetes版 2.ACK Pro版集群概述 3.ACK版本說(shuō)明 二、實(shí)驗(yàn) 1.創(chuàng)建專有版Kubernetes集群 三、問(wèn)題 1.依賴檢查未通過(guò) ? (1)概念 阿里云容器服務(wù)Kubernetes版(Alibaba Cloud Container Service for Kubernetes,簡(jiǎn)稱容器服務(wù)ACK)是全球首批通過(guò)Kubernetes一致性認(rèn)證的服務(wù)平

    2024年02月13日
    瀏覽(36)
  • 【云原生 | Kubernetes 系列】K8s 實(shí)戰(zhàn) 使用 Kustomize 對(duì) Kubernetes 對(duì)象進(jìn)行聲明式管理

    【云原生 | Kubernetes 系列】K8s 實(shí)戰(zhàn) 使用 Kustomize 對(duì) Kubernetes 對(duì)象進(jìn)行聲明式管理

    Kustomize 是一個(gè)用來(lái)定制 Kubernetes 配置的工具。它提供以下功能特性來(lái)管理應(yīng)用配置文件: 從其他來(lái)源生成資源 為資源設(shè)置貫穿性(Cross-Cutting)字段 組織和定制資源集合 ConfigMap 和 Secret 包含其他 Kubernetes 對(duì)象(如 Pod)所需要的配置或敏感數(shù)據(jù)。 ConfigMap 或 Secret 中數(shù)據(jù)的來(lái)

    2024年01月17日
    瀏覽(102)
  • Kubernetes技術(shù)--k8s核心技術(shù)Service服務(wù)

    Kubernetes技術(shù)--k8s核心技術(shù)Service服務(wù)

    1.service概述 ? ? ? ? Service 是 Kubernetes 最核心概念, 通過(guò)創(chuàng)建 Service,可以為一組具有相同功能的容器應(yīng)用提供一個(gè)統(tǒng)一的入口地址,并且將請(qǐng)求負(fù)載分發(fā)到后端的各個(gè)容器應(yīng)用上 。 2.service存在的意義 -1: 防止pod失聯(lián)(服務(wù)發(fā)現(xiàn)) 我們先說(shuō)一下什么叫pod失聯(lián)。 ?? ?-2:

    2024年02月10日
    瀏覽(23)
  • Kubernetes(k8s)服務(wù)service:service的發(fā)現(xiàn)和service的發(fā)布

    目錄 一.系統(tǒng)環(huán)境 二.前言 三.Kubernetes service簡(jiǎn)介 四.使用hostPort向外界暴露應(yīng)用程序 4.1 創(chuàng)建deploy 4.2 使用hostPort向外界暴露pod的端口 五.使用service服務(wù)向外界暴露應(yīng)用程序 5.1 使用service服務(wù)向外界暴露pod 5.1.1 創(chuàng)建service服務(wù) 5.1.2 測(cè)試svc的負(fù)載均衡 六.service服務(wù)的發(fā)現(xiàn) 6.1 使用

    2024年02月08日
    瀏覽(21)
  • 【云原生 | Kubernetes 系列】—K8s-Service 的概念

    【云原生 | Kubernetes 系列】—K8s-Service 的概念

    Service能夠提供負(fù)載均衡的能力,但是在使用上有以下限制: ClusterIp :默認(rèn)類型,自動(dòng)分配一個(gè)僅 Cluster 內(nèi)部可以訪問(wèn)的虛擬 IP NodePort :在 ClusterIP 基礎(chǔ)上為 Service 在每臺(tái)機(jī)器上綁定一個(gè)端口,這樣就可以通過(guò) : NodePort 來(lái)訪 問(wèn)該服務(wù) LoadBalancer :在 NodePort 的基礎(chǔ)上,借助 c

    2024年01月23日
    瀏覽(95)
  • 【云原生-K8s】Kubernetes安全組件CIS基準(zhǔn)kube-beach安裝及使用

    【云原生-K8s】Kubernetes安全組件CIS基準(zhǔn)kube-beach安裝及使用

    為了保證集群以及容器應(yīng)用的安全,Kubernetes 提供了多種安全機(jī)制,限制容器的行為,減少容器和集群的攻擊面,保證整個(gè)系統(tǒng)的安全性。 互聯(lián)網(wǎng)安全中心(CIS,Center for Internet Security),是一個(gè)非盈利組織,致力為互聯(lián)網(wǎng)提供免費(fèi)的安全防御解決方案 官網(wǎng) :https://www.cisecu

    2024年02月06日
    瀏覽(54)
  • Spring Cloud 使用 k8s 作為注冊(cè)中心 開(kāi)發(fā)環(huán)境 和 生產(chǎn)環(huán)境

    Spring Cloud 使用 k8s 作為注冊(cè)中心 開(kāi)發(fā)環(huán)境 和 生產(chǎn)環(huán)境

    因?yàn)?k8s 本身就有擁有注冊(cè)中心,和配置中心的功能。如果還是用 Nacos、Eureka、Consul 之類的注冊(cè)中心組件,就有點(diǎn)冗余了。當(dāng)然這些組件還是可以繼續(xù)用的。 所以,本教程,教授 Spring Cloud 使用 k8s 的注冊(cè)中心。在開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境 的教程! 下面以一個(gè)最簡(jiǎn)單的 服務(wù)消費(fèi)

    2024年02月15日
    瀏覽(112)
  • 云原生Kubernetes:K8S概述

    云原生Kubernetes:K8S概述

    目錄 一、理論 1.云原生 2.K8S 3.k8s集群架構(gòu)與組件 4.K8S網(wǎng)絡(luò) 二、總結(jié) (1)概念 云原生是一種基于容器、微服務(wù)和自動(dòng)化運(yùn)維的軟件開(kāi)發(fā)和部署方法。它可以使應(yīng)用程序更加高效、可靠和可擴(kuò)展,適用于各種不同的云平臺(tái)。 如果要更直接通俗的來(lái)解釋下上面的概念,云原生更

    2024年02月10日
    瀏覽(34)
  • 【云原生 ? Kubernetes】認(rèn)識(shí) k8s、k8s 架構(gòu)、核心概念點(diǎn)介紹

    【云原生 ? Kubernetes】認(rèn)識(shí) k8s、k8s 架構(gòu)、核心概念點(diǎn)介紹

    目錄 一、Kubernetes 簡(jiǎn)介 二、Kubernetes 架構(gòu) 三、Kunbernetes 有哪些核心概念? 1. 集群 Cluster 2. 容器 Container 3. POD 4. 副本集 ReplicaSet 5. 服務(wù) service 6. 發(fā)布 Deployment 7. ConfigMap/Secret 8. DaemonSet 9. 核心概念總結(jié) Kubernetes 簡(jiǎn)稱 k8s,是支持云原生部署的一個(gè)平臺(tái),起源于谷歌。谷歌早在十幾

    2024年02月03日
    瀏覽(859)
  • 【云原生 ? Kubernetes】認(rèn)識(shí) k8s 網(wǎng)絡(luò)、外部網(wǎng)絡(luò)訪問(wèn) k8s 內(nèi)部服務(wù)

    【云原生 ? Kubernetes】認(rèn)識(shí) k8s 網(wǎng)絡(luò)、外部網(wǎng)絡(luò)訪問(wèn) k8s 內(nèi)部服務(wù)

    目錄 一、認(rèn)識(shí) Kubernetes 網(wǎng)絡(luò) 二、外部網(wǎng)絡(luò)如何訪問(wèn) k8s 內(nèi)部服務(wù) 1. NodePort 2. Load Balancer 3. Ingress Kubernetes 最底層的網(wǎng)絡(luò)為節(jié)點(diǎn)網(wǎng)絡(luò),用來(lái)保證 k8s 集群的節(jié)點(diǎn)(master 和 worker、worker 節(jié)點(diǎn)之間)能夠做正常的 IP 尋址和通訊。 Kubernetes 第二層網(wǎng)絡(luò)就是 Pod 網(wǎng)絡(luò),構(gòu)建于節(jié)點(diǎn)網(wǎng)絡(luò)之上

    2024年01月16日
    瀏覽(106)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包