最新资讯

  • K8S Service 原理、图例——深度好文

K8S Service 原理、图例——深度好文

2025-05-14 09:37:38 1 阅读

一、理论介绍

1.1、3W 法则

1、是什么?

  • Service 是一种为一组功能相同的 pod 提供单一不变的接入点的资源。当 Service 存在时,它的IP地址和端口不会改变。客户端通过IP地址和端口号与 Service 建立连接,这些连接会被路由到提供该 Service 的任意一个pod上。通过这种方式,客户端不需要知道每个单独的pod的地址,这样这些pod就可以在集群中随时被创建或移除。

2、为什么需要?

  • Pod 的 IP 地址经常变化。
  • Pod 的 IP 在集群外无法访问。
  • Pod 实例之间的负载均衡。

3、局限性

  • Service 是一种四层代理。
  • 所谓四层,是针对 OSI 七层网络模型来说的。四层对应的是TCP/UDP协议,也就常说的IP+端口。
  • 因此,所谓四层代理就是基于IP+端口的负载均衡;七层就是基于URL等应用层信息的负载均衡。

1.2、基础信息

kubectl explain svc
# svc 是 service 的缩写

  • apiVersion:当前资源使用的 api 版本,与 VERSION 一致。
  • kind:资源类型,跟 KIND 保持一致。
  • metadata:元数据。定义资源名称、标签、注解等。
  • spec:规范、规约。
  • status:最近观察到的 Service 状态。由系统填充。只读。

1.3、ServiceSpec 规约

kubectl explain svc.spec
allocateLoadBalancerNodePorts    
clusterIP    
clusterIPs    <[]string>
externalIPs    <[]string>
externalName    
externalTrafficPolicy    
healthCheckNodePort    
internalTrafficPolicy    
ipFamilies    <[]string>
ipFamilyPolicy    
loadBalancerClass    
loadBalancerIP    
loadBalancerSourceRanges    <[]string>
ports    <[]ServicePort>端口
publishNotReadyAddresses    
selector    标签选择器
sessionAffinity    
sessionAffinityConfig    
trafficDistribution    
type    类型

1.4、Service 类型

kubectl explain svc.spec.type

type 类型有四种:

  • ClusterIP:虚拟集群IP。通过集群的内部 IP 暴露服务,选择该值时服务只能够在集群内部访问。默认类型。
  • NodePort:节点端口。通过每个节点上的 IP 和静态端口(NodePort)暴露服务。 NodePort 服务会路由到自动创建的 ClusterIP 服务。 通过请求 <节点 IP>:<节点端口>,你可以从集群的外部访问一个 NodePort 服务。
  • ExternalName:外部命名空间。通过返回 CNAME 和对应值,可以将服务映射到 externalName 字段的内容(例如,foo.bar.example.com)。 无需创建任何类型代理。
  • LoadBalancer:负载均衡。使用云提供商的负载均衡器向外部暴露服务。 外部负载均衡器可以将流量路由到自动创建的 NodePort 服务和 ClusterIP 服务上。Kubernetes 不直接提供负载均衡组件; 你必须提供一个,或者将你的 Kubernetes 集群与某个云平台集成。

其中 ClusterIP 为默认方式,只能集群内部访问。NodePort、LoadBalancer 则是向外暴露服务的同时将流量路由到 ClusterIP服务。ExternalName 则是CNAME方式进行服务映射。

1.5、Service 端口

kubectl explain svc.spec.ports
appProtocol    
name    
nodePort    

service 在节点映射的端口。

type 类型是 NodePort 或 LoadBalancer 时才指定。

通常是系统分配,也可以自己指定,范围在 30000-32767

port     -required-Service 将公开的端口。
protocol    协议。协议类型有 SCTP, TCP, UDP。默认 TCP
targetPort    pod 端口

二、镜像准备

2.1、镜像准备

docker pull mirrorgooglecontainers/serve_hostname:latest
docker pull kubedb/mysql-tools:8.0.14
docker pull curlimages/curl

 2.2、镜像导出

docker save -o serve_hostname.tar.gz mirrorgooglecontainers/serve_hostname:latest
docker save -o mysql-tools.tar.gz  mysql-tools:8.0.14
docker save -o curl.tar.gz curlimages/curl

 2.3、镜像导入工作节点 containerd

# k8s31node1 执行
[root@k8s31node1 ~]# ctr -n=k8s.io images import serve_hostname.tar.gz
[root@k8s31node1 ~]# ctr -n=k8s.io images ls|grep serve_hostname
[root@k8s31node1 ~]# ctr -n=k8s.io images import mysql-tools.tar.gz
[root@k8s31node1 ~]# ctr -n=k8s.io images ls|grep mysql-tools
[root@k8s31node1 ~]# ctr -n=k8s.io images import curl.tar.gz
[root@k8s31node1 ~]# ctr -n=k8s.io images ls|grep curl

# k8s31node2 执行
[root@k8s31node2 ~]# ctr -n=k8s.io images import serve_hostname.tar.gz
[root@k8s31node2 ~]# ctr -n=k8s.io images ls|grep serve_hostname
[root@k8s31node2 ~]# ctr -n=k8s.io images import mysql-tools.tar.gz
[root@k8s31node2 ~]# ctr -n=k8s.io images ls|grep mysql-tools
[root@k8s31node2 ~]# ctr -n=k8s.io images import curl.tar.gz
[root@k8s31node2 ~]# ctr -n=k8s.io images ls|grep curl

 2.4、环境准备

 假设有如下三个节点的 K8S 集群:

k8s31master 是控制节点

k8s31node1、k8s31node2 是工作节点

容器运行时是 containerd

三、实践

3.1、创建 ClusterIP 类型 Service

假设有这么一个部署:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: hostnames
spec:
  selector:
    matchLabels:
      app: hostnames
  replicas: 3
  template:
    metadata:
      labels:
        app: hostnames
    spec:
      containers:
      - name: hostnames
        image: mirrorgooglecontainers/serve_hostname
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 9376
          protocol: TCP

mirrorgooglecontainers/serve_hostname 这个应用的作用,就是每次访问 9376 端口时,返回它自己的 hostname。

3.1.1、在不同的节点上访问 PodIP:port

返回了各个 pod 自己的 hostname。

可以看到,在集群内的不同节点上, Pod IP 都能访问。

3.1.2、在不同的容器内访问 PodIP:port

假设现在新起一个 pod:

apiVersion: v1
kind: Pod
metadata:
  name: curl-tools
spec:
  containers:
  - name: curl-tools
    image: curlimages/curl:latest
    imagePullPolicy: IfNotPresent
    command: ["/bin/sh", "-c", "while true; do echo 'Hello from curl-tools'; sleep 30; done"]
  • curlimages/curl 是一个 curl 调试工具。
  • command:容器启动后执行的命令,这里使用一个无限循环,每隔 30 秒输出一次 Hello from curl-tools。
  • 像 Alpine 镜像,或者基于 Alpine 制作的工具镜像,容器内没有运行服务,需要启动后运行一个无限循环,防止容器被 K8S 杀掉。

 进入容器访问 hostnames 服务:

kubectl exec -it curl-tools -- curl 10.244.165.57:9376

可以看到,在集群内的容器之间,Pod IP 都能访问。

3.1.3、在集群外访问 PodIP:port

我们再起一台虚拟机 docker1,IP 地址跟 K8S 集群在一个网段。

访问 hostnames 服务:

可以看到,即使 docker1 的 IP 地址跟 K8S 集群在一个网段,但 docker1 没有用类似 kubeadm join 加入过集群,Pod IP 是不能访问的。

3.1.4、误删一个 pod 

kubectl delete pod hostnames-d9d7674f5-2djvf

 可以看到,K8S 又帮我们重新拉起了一个新 pod:hostnames-d9d7674f5-n7mtn,以维持我们 Deployment 控制器希望的副本数 replicas: 3。但是这个新 pod 的 IP,跟原来旧 pod 的 IP 是不一样的。

倘若我们是调用这些 pod 服务的客户端,在 pod 扩缩容期间,维护这些 pod IP 的代价是非常大的。所以我们需要一个稳定的接入层,它的 IP 地址、端口不变,让它来代理后端的一组 pod,而我们程序只需要跟这个接入层打交道就可以。这个接入层,就是 Service。

 3.1.5、新建一个 ClusterIP 类型 Service

apiVersion: v1
kind: Service
metadata:
  name: hostnames-svc
spec:
  type: ClusterIP
  selector:
    app: hostnames
  ports:
  - port: 80
    protocol: TCP
    targetPort: 9376
  • spec.selector:Service 通过标签选择器来查找 app=hostnames 标签的 Pod。
  • port: 80  表示该服务的可用端口。
  • targetPort: 9376 表示服务将连接转发的 Pod 端口。
  • port 跟 targetPort 配合起来表示 这个 Service 的 80 端口,代理的是 Pod 的 9376 端口。
  •  查看 service
kubectl get svc

  •  访问 service

连续三次不断地访问 Service 的 CLUSTER-IP 和 端口 80:

  • 依次返回了三个 Pod 的 hostname。
  • 请求 Service IP:port 跟直接访问 Pod IP:port 的结果一样,这说明 Service 可以把请求代理到它所关联的后端 Pod。
  • 这也印证了 Service 提供的是 Round Robin (轮询) 方式的负载均衡。

  • 查看 endpoints

 K8S 创建 Service 的时候,如果 Service 带有 selector 选择器,则 K8S 会创建一个与 Service 同名的 Endpoints 对象。selector 选中的 Pod 的 IP 和 端口,都会记录在 Endpoints 中。当一个新的 Pod 被创建并且它的标签匹配了某个 Service 的选择器时,该 Pod 的 IP 和端口会被添加到对应的 Endpoints 对象中;同样地,当 Pod 被删除时,它也会从 Endpoints 中移除。Endpoints 通常由 Service 引用, 以定义可以将流量发送到哪些 Pod。

kubectl get ep hostnames-svc
# ep endpoints 缩写
kubectl get ep hostnames-svc -oyaml

 需要注意的是,只有处于 Running 状态,且 readinessProbe 检查通过的 Pod,才会出现在 Service 的 Endpoints 列表里。并且,当某一个 Pod 出现问题时,Kubernetes 会自动把它从 Service 里摘除掉。

 3.1.6、集群外访问 Service ClusterIP:port

 在集群外的虚拟机 192.168.40.111 访问 10.103.168.44:80

可以看到,访问不到 Service。如果希望集群外的机器能访问,需要创建 NodePort 类型的 Service 或 LoadBalancer 类型的 Service。

 3.1.7、通过 FQDN 访问服务

在 Kubernetes (K8S) 环境中,FQDN(Fully Qualified Domain Name,完全限定域名)是指集群内部服务的完整域名,它包含了服务名、命名空间以及可选的服务后缀,用于唯一标识集群中的一个服务。

当你在 Kubernetes 中创建一个服务时,Kubernetes 会为该服务分配一个 FQDN。这个 FQDN 的格式通常是:

..svc.cluster.local
  • service-name 是你给服务起的名字。
  • namespace 是服务所在的命名空间,默认是 default,除非你在创建服务时指定了不同的命名空间。
  • svc 是固定的,代表这是一个服务。
  • cluster.local 是集群的默认域,大多数情况下是这个值,但如果你的集群配置了不同的域名,则会有所不同。

例如,我们上面 hostnames-svc 服务,它的完整域名是:

hostnames-svc.default.svc.cluster.local

我们在集群的其他 pod 中,就可以使用这个域名访问服务:

可以省略命名空间和 svc.cluster.local,因为已经帮我们解析了。

在节点上不能解析这个域名,Kubernetes 的 DNS 服务通常只服务于集群中的 Pod,而节点本身并不自动配置为使用它:

使用 FQDN 可以让 Kubernetes 集群中的其他服务通过 DNS 解析来找到并访问你的服务,而不需要知道服务的具体 IP 地址。这有助于实现服务发现和服务间的通信,并且提高了服务部署的灵活性和可移植性。在 Kubernetes 中,CoreDNS 通常被用来提供这种 DNS 服务发现的功能。

 3.1.8、Service 原理

我们以 3.1.2 小节 curl-tools 容器(假设运行在 node2 上)访问 Service Cluster_IP : port 为例,来讲解 Service 的工作原理。

首先介绍一下几个组件:

  • kube - proxy:是 Kubernetes 集群中每个节点上运行的一个组件。它负责在节点上维护网络规则,实现了 Service 的代理和负载均衡功能,确保客户端可以通过 Service 的 IP 和端口访问到对应的后端 Pod。kube-proxy 会监视 API Server 中 Service 和 Endpoints 对象的变化。当有新的 Service 或 Endpoints 对象创建、更新或删除时,kube-proxy 会收到通知,并相应地更新节点上的网络规则(iptables)。kube-proxy 有 iptables 模式跟 ipvs 模式。

  • Service:是 Kubernetes 提供的一种抽象层,它定义了一组 Pod 的逻辑集合以及访问这些 Pod 的策略。Service 为 Pod 提供了一个稳定的 IP 地址(ClusterIP)和端口号,使得客户端可以通过这个稳定的地址来访问后端的 Pod,而不需要关心具体 Pod 的 IP 地址和生命周期。
  • Endpoints:是 Kubernetes 中的一个资源对象,它记录了 Service 对应的所有后端 Pod 的 IP 地址和端口信息。每当 Pod 的数量或状态发生变化时,Endpoints 对象会自动更新。

curl-tools 容器内访问 Service IP : port 流程:

  1. node2 上的 kube-proxy 监视 API Server 中 Service 和 Endpoints 对象的变化,更新节点上的网络规则(iptables)。
  2. 客户端 curl-tools 请求 Service IP : port,请求包目的地 Destination 初始设置为服务的IP和端口(10.103.168.44:80)。发送到网络之前,node2 的内核会根据配置在该节点上的 iptables 规则处理数据包。内核会检查数据包是否匹配任何这些 iptables 规则。其中有个规则规定如果有任何数据包的目的地IP等于10.103.168.44、目的地端口等于80,那么数据包的目的地IP和端口应该被替换为随机选中的 hostnames pod的IP和端口。
  3. 本例中的数据包满足规则,故而它的IP:端口被改变了。假设 pod hostnames-d9d7674f5-tjwzp 被轮询算法随机选中了,所以数据包的目的地IP变更为 10.244.165.56,端口改为9376(Service中定义的目标端口)。就好像是客户端 curl-tools 直接发送数据包给 hostnames-d9d7674f5-tjwzp 而不是通过 Service。

3.1.9、iptables Or IPVS

kube-proxy 通过 iptables 处理 Service 的过程,其实需要在宿主机上设置相当多的 iptables 规则。而且,kube-proxy 还需要在控制循环里不断地刷新这些规则来确保它们始终是正确的。

当宿主机上有大量 Pod 的时候,成百上千条 iptables 规则不断地被刷新,很明显会影响到整体性能。

IPVS 模式的工作原理,其实跟 iptables 模式类似。区别只在于当我们创建了前面的 Service 之后,kube-proxy 首先会在宿主机上创建一个虚拟网卡(叫作:kube-ipvs0),并为它分配 Service VIP 作为 IP 地址,如下所示:

 

而接下来,kube-proxy 就会通过 Linux 的 IPVS 模块,为这个 IP 地址设置三个 IPVS 虚拟主机,并设置这三个虚拟主机之间使用轮询模式 (rr) 来作为负载均衡策略。我们可以通过 ipvsadm 查看到这个设置,如下所示:

ipvsadm -ln
-l:这是 ipvsadm 命令的一个选项,代表 “list”,即列出当前 IPVS 规则。使用该选项可以查看已经配置的虚拟服务器(Virtual Server)及其对应的真实服务器(Real Server)信息。
-n:同样是 ipvsadm 命令的选项,代表 “numeric”,表示以数字形式显示地址和端口,而不是将 IP 地址解析为域名、端口号解析为服务名。使用这个选项可以避免 DNS 解析和服务名查找的过程,更直观地显示规则信息。

可以看到,这三个 IPVS 虚拟主机的 IP 地址和端口,对应的正是三个被代理的 Pod。rr 表示轮询 round robin。

这时候,任何发往 10.103.168.44:80 的请求,就都会被 IPVS 模块转发到某一个后端 Pod 上了。 而相比于 iptables,IPVS 在内核中的实现其实也是基于 Netfilter 的 NAT 模式,所以在转发这一层上,理论上 IPVS 并没有显著的性能提升。但是,IPVS 并不需要在宿主机上为每个 Pod 设置 iptables 规则,而是把对这些“规则”的处理放到了内核态,从而极大地降低了维护这些规则的代价。

不过需要注意的是,IPVS 模块只负责上述的负载均衡和代理功能。而一个完整的 Service 流程正常工作所需要的包过滤、SNAT 等操作,还是要靠 iptables 来实现。

 3.1.10、Endpoints 与 readinessProbe 就绪探针

  • 编写服务 svc-hellok8s.yaml
apiVersion: v1
kind: Service
metadata:
  name: hellok8s-svc
spec:
  type: ClusterIP
  selector:
    app: hellok8s
  ports:
  - port: 80
    protocol: TCP
    targetPort: 8080
  •  执行并监控
kubectl apply -f svc-hellok8s.yaml
# -w 表示持续监控,注意这个时候不要关闭终端
kubectl get ep hellok8s-svc -w

  • 编写部署  deploy-hellok8s.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: hellok8s
spec:
  replicas: 3
  selector:
    matchLabels:
      app: hellok8s
      version: "1.0"
  template:
    metadata:
      labels:
        app: hellok8s
        version: "1.0"
    spec:
      containers:
      - name: hellok8s
        image: hellok8s:1.0
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 8080
        readinessProbe:
          httpGet:
            path: /
            port: 8080
          initialDelaySeconds: 15
          periodSeconds: 10

initialDelaySeconds: 表示容器启动后延迟多少秒,开始就绪探测。这里特意设置成 15 秒,为了观察就绪探针没有完成时, Endpoints 的列表里,会不会有 pod 的 IP。

  •  在另一个终端运行部署
kubectl apply -f deploy-hellok8s.yaml

    可以看到,在 pod 还没就绪前,endpoints 列表里面是不会有 pod IP 的。

    • 删除部署
    kubectl delete -f deploy-hellok8s.yaml

    可以看到 pod 被删除,endpoints 列表也会移除 pod IP。

     3.1.11、原理图

    3.2、创建 NodePort 类型 Service

    假设我们现在有如下 三个 pod:

    kubectl get pod -l app=hostnames -owide

     IP 分别是 10.244.9.57、10.244.9.59、10.244.165.3

    3.2.1、编写服务

    apiVersion: v1
    kind: Service
    metadata:
      name: hostnames-nodeport
    spec:
      type: NodePort
      selector:
        app: hostnames
      ports:
      - port: 80
        protocol: TCP
        targetPort: 9376
        nodePort: 32000
    • spec.type:NodePort 通过每个节点上的 IP 和静态端口(NodePort)暴露服务。
    • spec.ports.nodePort:指定节点上暴露的端口 32000。

     3.2.2、访问服务

    在浏览器中、或者任何能访问到集群三个节点的机器上,访问 节点IP:32000

    curl 192.168.40.10:32000
    curl 192.168.40.20:32000
    curl 192.168.40.30:32000

    3.2.3、原理

    每一个节点的防火墙规则里面,都有一条 节点IP:32000 的转发规则。转发到三个 pod上。

    创建 NodePort 类型的 Service 会默认帮我们创建 Cluster_IP

    它的数据转发方式,跟 3.1 节讲的是一样的,走 kube-ipvs0 虚拟网桥。

    如果节点上有安装 docker,NodePort 不会走节点IP端口,会默认走 docker0 网桥,然后数据再通过 docker0 转发给 pod。

    3.3、创建 ExternalName 类型 Service

    3.3.1、场景分析

    Service,是无法代理到不同名称空间下的 Pod 的。

    假设我们默认名称空间下,有三个这样的 Pod:

    kubectl get pod -l app=hostnames -A --show-labels

    在名称空间 external-demo 下,有这样一个 Service:

    apiVersion: v1
    kind: Service
    metadata:
      name: external-svc-a
      namespace: external-demo
    spec:
      type: ClusterIP
      selector:
        app: hostnames
      ports:
      - port: 80
        protocol: TCP
        targetPort: 9376

     Service 在 external-demo 名称空间下,它的标签选择器选择了上面的三个 Pod。

     查看 Service 详情:

    kubectl describe svc external-svc-a -n=external-demo

    可以看到它并没有代理到任何 Pod。

     此时,不管是在节点上直接访问 Service ClusterIP 10.100.211.127:80

    还是在 external-demo 名称空间下的 Pod:

    apiVersion: v1
    kind: Pod
    metadata:
      name: curl-tools
      namespace: external-demo
    spec:
      containers:
      - name: curl-tools
        image: curlimages/curl:latest
        imagePullPolicy: IfNotPresent
        command: ["/bin/sh", "-c", "while true; do echo 'Hello from curl-tools'; sleep 30; done"]
    kubectl exec -it -n=external-demo curl-tools -- /bin/sh

    都访问不到任何 Pod。

    那么,external-demo 名称空间下的 Pod 要如何通过 Service 访问 default 名称空间下的 Pod 呢?

    3.3.2、ExternalName 类型 Service

    在 external-demo 名称空间下新建一个 Service:

    apiVersion: v1
    kind: Service
    metadata:
      name: external-svc-b
      namespace: external-demo
    spec:
      type: ExternalName
      externalName: hostnames-svc.default.svc.cluster.local
      selector:
        app: hostnames
      ports:
      - port: 80
        protocol: TCP
    • type: ExternalName。
    • externalName:指定 default 名称空间下的完全限定服务名。

    相当于给 hostnames-svc 服务创建了一个软连接。

    • targetPort:在这种情况下可以忽略。
    kubectl get svc -n=external-demo

    此时,在 external-demo 名称空间下的 curl-tools 就可以直接访问这个服务,请求会被代理到 default 名称空间下的 Pod:

    3.4、使用自定义 Endpoints 连接集群外部服务

    假设集群外的服务器 192.168.40.111 上运行着一个 mysql,端口 3306。

    集群内的 pod 要如何使用服务名来连接这台 mysql?

    3.4.1、创建没有选择器的服务

    apiVersion: v1
    kind: Service
    metadata:
      name: mysql-svc
    spec:
      type: ClusterIP
      ports:
      - port: 3306

     定义⼀个名为 mysql-svc 的服务,它将接收 3306 端口传入的连接。并没有为服务定义⼀个pod 选择器。

     3.4.2、为没有选择器的服务创建 Endpoints 资源

    Endpoints 是⼀个单独的资源并不是服务的⼀个属性。由于创建的 Service 中并不包含选择器,相关的 Endpoints 资源并没有自动创建,所以必须手动创建。

    apiVersion: v1
    kind: Endpoints
    metadata: 
      name: mysql-svc
    subsets:
    - addresses:
      - ip: 192.168.40.111
      ports:
      - port: 3306
    

    Endpoints 对象需要与服务具有相同的名称 mysql-svc,并包含该服务的目标 IP 地址和端口列表。服务和 Endpoints 资源都发布到服务器后,这样服务就可以像具有 pod 选择器那样的服务正常使用。

     3.4.3、启动 mysql-tools 工具

    apiVersion: v1
    kind: Pod
    metadata:
      name: mysql-tools
    spec:
      containers:
      - name: mysql-tools
        image: kubedb/mysql-tools:8.0.14
        imagePullPolicy: IfNotPresent
        command: ["/bin/sh", "-c", "while true; do echo 'Hello from curl-tools'; sleep 30; done"]
    

    3.4.4、进入 mysql-tools pod 内部连接服务

    kubectl exec -it mysql-tools -- /bin/sh
    mysql -h mysql-svc -uroot -p123456

     3.5、CoreDNS 介绍

    CoreDNS 是 Kubernetes 集群中的关键组件,负责提供 DNS 服务。

    3.5.1、镜像准备

    docker pull mkrishnamurthy/nslookup
    docker save -o nslookup-tools.tar.gz mkrishnamurthy/nslookup:latest

     3.5.2、镜像导入工作节点 containerd

    # k8s31node1 执行
    [root@k8s31node1 ~]# ctr -n=k8s.io images import nslookup-tools.tar.gz
    [root@k8s31node1 ~]# ctr -n=k8s.io images ls|grep nslookup-tools
    
    # k8s31node2 执行
    [root@k8s31node2 ~]# ctr -n=k8s.io images import nslookup-tools.tar.gz
    [root@k8s31node2 ~]# ctr -n=k8s.io images ls|grep nslookup-tools
    

     3.5.3、启动 nslookup 工具

    apiVersion: v1
    kind: Pod
    metadata:
      name: nslookup-tools
    spec:
      containers:
      - name: nslookup-tools
        image: mkrishnamurthy/nslookup:latest
        imagePullPolicy: IfNotPresent
        command: ["/bin/sh", "-c", "while true; do echo 'Hello from nslookup-tools'; sleep 30; done"]
    

    mkrishnamurthy/nslookup 镜像安装了 nslookup 命令。nslookup 是一个用于查询 DNS 记录的命令行工具,它可以帮助用户检查域名解析是否正常。

     进入 pod 执行命令:

    [root@k8s31master]# kubectl exec -it nslookup-tools -- /bin/bash
    bash-4.2# nslookup hostnames-svc

     10.103.168.44 是 hostnames-svc 服务的 ClusterIP

    Server 10.96.0.10 是 K8S 集群 DNS 服务的 ClusterIP

    这个 Service 后面代理着两个 Pod

    这两个 Pod 就是实际提供 DNS 解析服务的 Pod

    • 在 Kubernetes 集群中,CoreDNS 的服务(kube-dns)是一个 ClusterIP 类型的服务,背后由多个 CoreDNS Pod 提供支持。
    • 当集群中的 Pod 发起 DNS 查询时,Kubernetes 会通过 Service 的负载均衡机制,将请求分发到后端的 CoreDNS Pod 上。多个 CoreDNS 实例可以分担查询负载,避免单个实例因流量过大而成为性能瓶颈。

    四、参考资料

    官网:虚拟 IP 和服务代理

    Kubernetes教程(五)---Service 的几种访问方式

    本文地址:https://www.vps345.com/10449.html

    搜索文章

    Tags

    PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP docker 容器 运维 java-rabbitmq java 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 服务器 linux 游戏 云计算 网络工程师 网络管理 软考 2024 2024年上半年 下午真题 答案 物联网 ubuntu Deepseek Deepseek-R1 大模型 私有化部署 推理模型 deepseek DeepSeek-R1 API接口 c语言 RTSP xop RTP RTSPServer 推流 视频 Ollama Qwen2.5-coder 离线部署 人工智能 redis 英语 DNS ddos android 网络安全 web安全 网络 tcp/ip 网络协议 ip协议 进程 操作系统 进程控制 Ubuntu 数据库系统 mysql adb 游戏引擎 学习 javascript 前端 chrome edge YOLO conda pytorch vscode python yolov5 macos windows ai nlp php 开发语言 django 神经网络 深度学习 计算机视觉 卷积神经网络 阿里云 llama 算法 opencv 自然语言处理 语言模型 CH340 单片机 嵌入式硬件 串口驱动 CH341 uart 485 centos gcc centos 7 ssh 经验分享 harmonyos 华为 vue.js spring boot nginx MCP jvm 虚拟机 AIGC 人工智能生成内容 Dify 笔记 学习方法 pycharm ide 负载均衡 tomcat 部署 arm开发 架构 计算机外设 bug 数据库 oracle 关系型 安全 分布式 机器学习 网络结构图 模型联网 API CherryStudio 开发环境 https 自动化 c++ 并查集 leetcode 智能路由器 外网访问 内网穿透 端口映射 outlook 错误代码2603 无网络连接 2603 udp 本地环回 bind kafka AI大模型 大模型技术 本地部署大模型 ubuntu 18.04 安装教程 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 云原生 ip 科技 个人开发 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 kubernetes springsecurity6 oauth2 授权服务器 前后端分离 mcu asm typescript 计算机网络 gnu 目标跟踪 目标检测 OpenVINO 推理应用 高级IO epoll dify prometheus grafana jenkins gitee fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse debian PVE live555 rtsp rtp virtualenv 策略模式 node.js 知识库 本地化部署 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 数据分析 C 环境变量 进程地址空间 后端 ui vnc eureka grub 版本升级 扩容 ffmpeg 音视频 视频编解码 pip jellyfin nas fstab apache 鸿蒙 USB转串口 windows 服务器安装 dell服务器 IIS .net core Hosting Bundle .NET Framework vs2022 c# 安卓模拟器 mac perf EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 spring cloud dubbo 面试 课程设计 聚类 程序 编程 内存 性能分析 json 开源 github 实时音视频 实时互动 maven svn 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 快捷键 旋转屏幕 自动操作 compose 持续部署 kylin audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 VMware zotero WebDAV 同步失败 代理模式 ubuntu20.04 Linux 开机黑屏 AI编程 数据结构 链表 虚拟现实 JAVA Java LDAP Alexnet xcode ollama llm HarmonyOS Next 腾讯云 ue4 着色器 ue5 虚幻 cron crontab日志 devops elasticsearch git 思科 react.js 前端面试题 AI vim qt arm uni-app 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 机器人 大数据 spark hive 运维开发 Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 cursor transformer 集成学习 集成测试 sublime text 编辑器 rag ragflow 大模型部署 华为云 spring pillow protobuf 序列化和反序列化 安装 websocket oracle fusion oracle中间件 UEFI Legacy MBR GPT U盘安装操作系统 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 opengl C# MQTTS 双向认证 emqx QT 5.12.12 QT开发环境 Ubuntu18.04 TCP WebServer ip命令 新增网卡 新增IP 启动网卡 多线程 进程优先级 调度队列 进程切换 虚拟显示器 远程控制 matplotlib fonts-noto-cjk pygame yum docker-compose docker compose axure 富文本编辑器 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn cpu 实时 使用 Linux 维护模式 媒体 Ubuntu20.04 GLIBC 2.35 Linux PID 监控k8s集群 集群内prometheus ssh漏洞 ssh9.9p2 CVE-2025-23419 openvpn server openvpn配置教程 centos安装openvpn 性能优化 linux内核 shell 缓存 powerpoint SRS 流媒体 直播 DeepSeek .netcore DevEco Studio openEuler GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 华为od http gateway Clion Nova ResharperC++引擎 Centos7 远程开发 电脑 flask 1024程序员节 nftables 防火墙 intellij-idea iftop 网络流量监控 lvm 磁盘挂载 磁盘分区 区块链 命令 C语言 rust腐蚀 bash webrtc 云电竞 云电脑 todesk ssl 私有化 本地部署 jupyter 前端框架 java-ee html CPU 主板 电源 网卡 政务 分布式系统 监控运维 Prometheus Grafana 互信 vSphere vCenter 软件定义数据中心 sddc MacOS录屏软件 matlab unix 远程桌面 rdp 远程服务 stm32项目 stm32 ocr agi 大语言模型 LLMs 深度求索 私域 CPU 使用率 系统监控工具 linux 命令 jmeter 软件测试 golang 7z 主从复制 etcd 数据安全 RBAC 报错 软件工程 软件构建 硬件架构 系统架构 TrueLicense wsl 沙盒 Kali Linux 黑客 渗透测试 信息收集 安卓 远程连接 实验 vite vue3 远程工作 灵办AI elk 程序人生 AI-native Docker Desktop flutter Google pay Apple pay jar milvus intellij idea rpc centos-root /dev/mapper yum clean all df -h / du -sh 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 软件需求 读写锁 open webui VMware创建虚拟机 源码剖析 rtsp实现步骤 流媒体开发 微信小程序 3d 数学建模 计算生物学 生物信息学 生物信息 基因组 创意 社区 ruoyi 多层架构 解耦 国产数据库 瀚高数据库 数据迁移 下载安装 gpu算力 sql IM即时通讯 QQ 微信 企业微信 剪切板对通 HTML FORMAT 串口服务器 微信分享 Image wxopensdk 大模型入门 大模型教程 GPU onlyoffice gitlab unity Hyper-V WinRM TrustedHosts vue 嵌入式 linux驱动开发 notepad ESP32 camera Arduino 电子信息 eclipse 热榜 KylinV10 麒麟操作系统 Vmware MacMini Mac 迷你主机 mini Apple 进程信号 hadoop 压测 ECS chatgpt oneapi numpy 离线部署dify 智慧农业 开源鸿蒙 团队开发 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 pdf 华为认证 交换机 信息与通信 ros 话题通信 服务通信 k8s 驱动开发 postgresql WSL2 上安装 Ubuntu webdav 游戏程序 ios vr ecmascript nextjs react reactjs 指令 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 Cursor 教程 环境搭建 Maven remote-ssh tcp C++ WSL2 Ubuntu22.04 虚拟化 开发人员主页 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 redhat Mac内存不够用怎么办 升级 CVE-2024-7347 漏洞 vmware 卡死 odoo 服务器动作 Server action deepseek-r1 大模型本地部署 VMware安装mocOS macOS系统安装 Dell R750XS 虚拟局域网 统信 NFS iot WLAN WebUI DeepSeek V3 oceanbase 传统数据库升级 银行 rabbitmq maxkb ARG 温湿度数据上传到服务器 Arduino HTTP efficientVIT YOLOv8替换主干网络 TOLOv8 list 多线程服务器 Linux网络编程 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 postman 测试工具 VMware安装Ubuntu Ubuntu安装k8s gpt 产品经理 microsoft aws Agent LLM CrewAI edge浏览器 fork wait waitpid exit ipython rust Hive环境搭建 hive3环境 Hive远程模式 YOLOv8 NPU Atlas800 A300I pro asi_bench rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 硬件工程 嵌入式实习 python2 ubuntu24.04 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 Trae IDE AI 原生集成开发环境 Trae AI visual studio code Cline database 浪潮信息 AI服务器 rancher ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 burp suite 抓包 copilot linux环境变量 系统安全 termux 搜索引擎 全文检索 图搜索算法 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 IIS服务器 IIS性能 日志监控 环境配置 通信工程 毕业 yolov8 Mermaid 可视化图表 自动化生成 服务器配置 wireshark 显示过滤器 ICMP Wireshark安装 低代码 iperf3 带宽测试 ansible 数据挖掘 高效I/O 爬虫 实战案例 Redis Desktop export import save load 迁移镜像 rime zabbix mariadb systemctl ci/cd composer Docker Compose 毕设 拓扑图 客户端 kamailio sip VoIP openstack Xen KVM 大数据平台 无人机 rc.local 开机自启 systemd 麒麟 Ubuntu 22.04 MySql 算家云 算力租赁 一切皆文件 nac 802.1 portal .net 命名管道 客户端与服务端通信 sqlserver TRAE ping++ 文件系统 路径解析 diskgenius Chatbox Invalid Host allowedHosts 功能测试 自动化测试 yaml Ultralytics 可视化 银河麒麟 samba nvm selete excel 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 框架搭建 jdk dns Mac软件 ESXi 大模型应用 云服务 tcpdump MCP server C/S npm c/c++ 串口 kali 共享文件夹 计算机系统 网络编程 rocketmq next.js 部署next.js 个人博客 模拟实现 交互 大屏端 腾讯云大模型知识引擎 网络用户购物行为分析可视化平台 大数据毕业设计 H3C bcompare Beyond Compare shell脚本免交互 expect linux免交互 移动云 SSH 密钥生成 SSH 公钥 私钥 生成 安防软件 宝塔面板无法访问 selenium 网络爬虫 Linux的基础指令 Python threejs 3D okhttp docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 html5 firefox 云原生开发 K8S k8s管理系统 zip unzip P2P HDLC 浏览器自动化 开发 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos 监控 自动化运维 linux安装配置 云桌面 微软 AD域控 证书服务器 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia CUPS 打印机 Qt5 王者荣耀 asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 visual studio 豆瓣 追剧助手 迅雷 Docker Kubernetes cuda web3.py CLion unity3d 中兴光猫 换光猫 网络桥接 自己换光猫 YOLOv12 kylin v10 麒麟 v10 ubuntu24.04.1 Cookie 硬件 设备 PCI-Express ux 鲲鹏 昇腾 npu nohup 异步执行 fpga开发 鸿蒙系统 Samba NAS string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap HCIE 数通 ros1 Noetic 20.04 apt 安装 sysctl.conf vm.nr_hugepages 代码调试 ipdb adobe top Linux top top命令详解 top命令重点 top常用参数 firewalld AutoDL db seatunnel 键盘 压力测试 中间件 iis MQTT协议 消息服务器 代码 视觉检测 图像处理 自动驾驶 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer 直播推流 sqlite3 mongodb rsyslog 机柜 1U 2U glibc 嵌入式系统开发 ragflow 源码启动 Qualcomm WoS QNN AppBuilder DIFY 远程看看 远程协助 Reactor 设计模式 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 国产操作系统 虚拟机安装 kind cudnn anaconda 微服务 springcloud chatbox 版本 IO springboot r语言 云耀服务器 匿名管道 网易邮箱大师 OpenManus React Next.js 开源框架 物联网开发 MQTT DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 tar x64 SIGSEGV SSE xmm0 雨云 NPS 程序员 计算机 css less 统信UOS bonding 链路聚合 隐藏文件 隐藏目录 管理器 通配符 miniapp 真机调试 调试 debug 断点 网络API请求调试方法 HiCar CarLife+ CarPlay QT RK3588 宠物 毕业设计 免费学习 宠物领养 宠物平台 IPMI 大模型微调 GCC aarch64 编译安装 HPC CentOS ollama下载加速 HP Anyware 消息队列 SSH Xterminal ROS2 iBMC UltraISO windows日志 域名服务 DHCP 符号链接 配置 磁盘清理 AI写作 程序员创富 设置代理 实用教程 visualstudio GameFramework HybridCLR Unity编辑器扩展 自动化工具 Windsurf 权限 磁盘监控 retry 重试机制 netty go 智能手机 gitea DevOps 软件交付 数据驱动 应用场景 armbian u-boot frp 大模型压力测试 EvalScope minicom 串口调试工具 MS Materials 飞牛nas fnos file server http server web server webstorm log4j 状态管理的 UDP 服务器 Arduino RTOS 远程 执行 sshpass 操作 WSL win11 无法解析服务器的名称或地址 n8n 工作流 加解密 Yakit yaklang 硅基流动 ChatBox gradle 镜像下载 freebsd arkUI qps 高并发 强制清理 强制删除 mac废纸篓 RustDesk自建服务器 rustdesk服务器 docker rustdesk mybatis 5G 3GPP 卫星通信 回显服务器 UDP的API使用 mq ROS 软链接 硬链接 执法记录仪 智能安全帽 smarteye xml vscode1.86 1.86版本 ssh远程连接 UOS 统信操作系统 LLM Web APP Streamlit ArkTs ArkUI Linux的权限 flash-attention android studio xrdp 正则表达式 llama3 Chatglm 开源大模型 端口号 开放端口 访问列表 Docker Hub docker pull 镜像源 daemon.json 环境迁移 监控k8s 监控kubernetes burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 系统 黑苹果 服务器扩容没有扩容成功 ebpf uprobe CosyVoice 内网渗透 靶机渗透 alias unalias 别名 数据集 Ubuntu共享文件夹 共享目录 Linux共享文件夹 视频平台 录像 视频转发 性能测试 视频流 存储 基础环境 僵尸进程 流水线 脚本式流水线 矩阵 ufw PX4 MAVROS 四旋翼无人机 VSCode playbook 剧本 mysql离线安装 ubuntu22.04 mysql8.0 FTP 服务器 智能体 autogen openai coze su sudo WebVM windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 工具 clickhouse 工业4.0 KingBase c 博客 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 linux上传下载 kotlin iphone JDK LInux Windows v10 软件 vmamba Termux 自动化编程 显示器 curl wget openwrt 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 express p2p Kylin-Server 服务器安装 RAGFLOW 信号 内核 docker run 数据卷挂载 交互模式 SWAT 配置文件 服务管理 网络共享 harmonyOS面试题 ros2 moveit 机器人运动 googlecloud Web服务器 多线程下载工具 PYTHON mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 安装MySQL 迁移指南 Xinference HarmonyOS nuxt3 Kali telnet 远程登录 边缘计算 桥接模式 windows虚拟机 虚拟机联网 多产物 半虚拟化 硬件虚拟化 Hypervisor Linux24.04 deepin 免密 登录 公钥 私钥 能力提升 面试宝典 技术 IT信息化 Web应用服务器 dity make 行情服务器 股票交易 速度慢 切换 股票量化接口 股票API接口 eNSP 网络规划 VLAN 企业网络 Reactor反应堆 micropython esp32 mqtt mosquitto wps 单例模式 dash 数据可视化 服务器管理 宝塔面板 配置教程 网站管理 网络文件系统 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm Linux Vim searxng openssl 密码学 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 业界资讯 python3.11 模拟退火算法 田俊楠 ajax UDP UOS1070e perl cfssl 联网 easyconnect 代理 代码托管服务 向日葵 Linux权限 权限命令 特殊权限 产测工具框架 IMX6ULL 管理框架 scapy pyside6 界面 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 ueditor导入word ueditor导入pdf ueditor导入ppt AISphereButler hibernate rclone AList fnOS NVML nvidia-smi firewall make命令 makefile文件 ukui 麒麟kylinos openeuler 镜像 W5500 OLED u8g2 TCP服务器 论文阅读 chfs ubuntu 16.04 Typore FTP服务器 桌面环境 健康医疗 互联网医院 Carla 智能驾驶 Java Applet URL操作 服务器建立 Socket编程 网络文件读取 历史版本 下载 智能电视 nacos etl rustdesk RAID RAID技术 磁盘 Pyppeteer Playwright 信息可视化 echarts 技能大赛 web 火绒安全 ArkTS 移动端开发 VPS safari 玩游戏 具身智能 强化学习 uniapp Attention NLP nvidia 恒源云 换源 国内源 Debian 小智 ceph 反向代理 mamba 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 OD机试真题 华为OD机试真题 服务器能耗统计 Vmamba AI代码编辑器 DeepSeek行业应用 Heroku 网站部署 网络攻击模型 big data 蓝桥杯 lb 协议 可信计算技术 安全架构 显卡驱动 openjdk macbook 大模型训练/推理 推理问题 mindie 交叉编译 beautifulsoup 智能音箱 智能家居 gpt-3 文心一言 RAG 检索增强生成 文档解析 大模型垂直应用 IPMITOOL BMC 硬件管理 kernel netlink libnl3 用户缓冲区 金融 支付 微信支付 开放平台 Kylin OS 国产化 XCC Lenovo 模拟器 容器技术 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 繁忙 服务器繁忙 解决办法 替代网站 汇总推荐 AI推理 宝塔 序列化反序列化 CDN fd 文件描述符 jina 数据采集 Crawlee IPv4 子网掩码 公网IP 私有IP 终端工具 远程工具 token sas dba 端口测试 医疗APP开发 app开发 ruby IP 地址 MobaXterm 文件传输 线程 wsgiref Web 服务器网关接口 nfs cocoapods SSL 域名 skynet SenseVoice 计算机科学与技术 Xshell 底层实现 代码规范 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 embedding 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 Netty 工具分享 渗透 stable diffusion AI作画 autoware 双系统 GRUB引导 Linux技巧 java-rocketmq 机架式服务器 1U工控机 国产工控机 Jellyfin 同步 备份 建站 LORA 安全威胁分析 阻塞队列 生产者消费者模型 服务器崩坏原因 多端开发 智慧分发 应用生态 鸿蒙OS 内网环境 京东云 lio-sam SLAM 图形化界面 uv 黑客技术 URL api pyqt 新盘添加 partedUtil WebRTC CORS 跨域 kvm 多进程 华为OD 可以组成网络的服务器 单元测试 cpp-httplib 网工 opensearch helm trea idea 服务器主板 AI芯片 MI300x rnn 游戏服务器 TrinityCore 魔兽世界 zerotier fast 聊天服务器 套接字 Socket workflow linuxdeployqt 打包部署程序 appimagetool vasp安装 图片增强 增强数据 minio 办公自动化 pdf教程 code-server SVN Server tortoise svn wsl2 群晖 文件分享 pppoe radius arcgis tensorflow trae 雨云服务器 Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 银河麒麟操作系统 服务器部署ai模型 pyautogui 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 ShenTong DBeaver ACL 流量控制 基本ACL 规则配置 网页设计 saltstack 开机自启动 相差8小时 UTC 时间 代理服务器 risc-v 分子对接 autodock mgltools PDB PubChem 三级等保 服务器审计日志备份 prompt 分析解读 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 laravel bot bootstrap VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 EMQX 通信协议 DeepSeek r1 Open WebUI 其他 cd 目录切换 conda配置 conda镜像源 联想开天P90Z装win10 ollama api ollama外网访问 宕机切换 服务器宕机 稳定性 看门狗 photoshop 生活 Linux find grep NLP模型 自学笔记 小米 澎湃OS Android 孤岛惊魂4 apt 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? Node-Red 编程工具 流编程 大文件秒传跨域报错cors RTMP 应用层 小艺 Pura X java-zookeeper Minecraft opcua opcda KEPServer安装 DOIT 四博智联 IMM 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 数码 联机 僵尸毁灭工程 游戏联机 开服 xpath定位元素 信号处理 bat Claude Desktop Claude MCP Windows Cli MCP idm Obsidian Dataview 源代码 单一职责原则 树莓派 VNC AD域 thingsboard linux 命令 sed 命令 笔灵AI AI工具 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 iDRAC R720xd powerbi 跨平台 管道 VR手套 数据手套 动捕手套 动捕数据手套 自定义客户端 SAS pyicu XFS xfs文件系统损坏 I_O error SSH 服务 SSH Server OpenSSH Server 输入法 k8s部署 MySQL8.0 高可用集群(1主2从) ftp服务 文件上传 av1 电视盒子 机顶盒ROM 魔百盒刷机 自动化任务管理 Linux环境 日志分析 系统取证 职场和发展 命令行 基础入门 easyui langchain neo4j 数据仓库 数据库开发 推荐算法 蓝耘科技 元生代平台工作流 ComfyUI FunASR ASR Docker快速入门 蓝桥杯C++组 keepalived yum源切换 更换国内yum源 音乐服务器 Navidrome 音流 MAC SecureCRT sonoma 自动更新 流式接口 ftp Wi-Fi Ardupilot chrome devtools chromedriver vpn RAGFlow Spring Security EasyConnect 大版本升 升级Ubuntu系统 Isaac Sim 虚拟仿真 ArcTS ArcUI GridItem 远程过程调用 Windows环境 服务网格 istio 金仓数据库 2025 征文 数据库平替用金仓 AimRT js docker命令大全 Office DocFlow css3 ssrf 失效的访问控制 sublime text3 jetty undertow ELF加载 SysBench 基准测试 服务器时间 免费域名 域名解析 Ark-TS语言 语音识别 MNN Qwen cmos SSL证书 initramfs Linux内核 Grub OpenHarmony es6 qt6.3 g726 相机 深度优先 图论 并集查找 换根法 树上倍增 sdkman ShapeFile GeoJSON Nginx gaussdb llama.cpp 影刀 #影刀RPA# Dell HPE 联想 浪潮 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口服务器 图形渲染 cmake 小游戏 五子棋 重启 排查 系统重启 日志 原因 思科模拟器 Cisco HarmonyOS NEXT 原生鸿蒙 测试用例 .net mvc断点续传 实习 聊天室 localhost 大模型面经 大模型学习 AnythingLLM AnythingLLM安装 动静态库 华为证书 HarmonyOS认证 华为证书考试 rpa LVM lvresize 磁盘扩容 pvcreate 算力 系统开发 binder 车载系统 framework 源码环境 cnn DenseNet 微信公众平台 VPN wireguard muduo X11 Xming 源码 qemu libvirt 飞牛 HistoryServer Spark YARN jobhistory 混合开发 环境安装 银河麒麟服务器操作系统 系统激活 考研 在线office 空间 查错 can 线程池 社交电子 考试 本地部署AI大模型 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 webgl 电视剧收视率分析与可视化平台 ssh远程登录 SEO virtualbox 实时内核 显示管理器 lightdm gdm nohup后台启动 ubuntu24 vivado24 vscode 1.86 网站搭建 serv00 Echarts图表 折线图 柱状图 异步动态数据 鸿蒙开发 可视化效果 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 服务器部署 本地拉取打包 直流充电桩 充电桩 微信开放平台 微信公众号配置 7-zip banner sudo原理 su切换 Webserver 异步 CNNs 图像分类 NAT转发 NAT Server k8s集群资源管理 网络穿透 Nuxt.js CentOS Stream grep env 变量 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 邮件APP 免费软件 软件卸载 系统清理 常用命令 文本命令 目录命令 网卡的名称修改 eth0 ens33 毕昇JDK deep learning Ubuntu Server Ubuntu 22.04.5 致远OA OA服务器 服务器磁盘扩容 蓝牙 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 游戏机 scikit-learn 即时通信 NIO iTerm2 终端 飞牛NAS 飞牛OS MacBook Pro 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 iNode Macos 弹性服务器 网页服务器 web服务器 查询数据库服务IP地址 SQL Server 分布式训练 pthread kerberos 教育电商 智能合约 哈希算法 deepseek r1 sqlite pgpool qt项目 qt项目实战 qt教程 PPI String Cytoscape CytoHubba deekseek Zoertier 内网组网 银河麒麟高级服务器 外接硬盘 Kylin xfce 根服务器 WINCC TCP协议 抗锯齿 postgres Dify重启后重新初始化 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 论文笔记 多路转接 知识图谱 服务器ssl异常解决 whistle chromium dpi Logstash 日志采集 需求分析 规格说明书 navicat deepseak 豆包 KIMI 腾讯元宝 内网服务器 内网代理 内网通信 OpenCore dock 加速 web3 proxy模式 servlet ranger MySQL8.0 MDK 嵌入式开发工具 飞书 IP配置 netplan 智能体开发 Apache Beam 批流统一 案例展示 数据分区 容错机制 OpenSSH shard 动态规划 webpack Headless Linux 程序化交易 量化交易 高频交易 wpf 软考设计师 中级设计师 SQL 软件设计师 mcp服务器 client close zookeeper llamafactory 微调 flink seleium EVE-NG Anolis nginx安装 linux插件下载 卸载 列表 System V共享内存 进程通信 嵌入式Linux IPC junit 对比 meld DiffMerge 配置原理 分布式账本 信任链 共识算法 EMUI 回退 降级 ai工具 阿里云ECS ldap 安全漏洞 信息安全 ubuntu安装 linux入门小白 mac设置host h.264 支持向量机 我的世界服务器搭建 minecraft 项目部署 项目部署到linux服务器 项目部署过程 超融合 GRE 用户管理 文件存储服务器组件 open Euler dde IO模型 软负载 视频监控 网站 NVM Node Yarn PM2 打不开xxx软件 无法检查其是否包含恶意软件 Alist mount 挂载 网盘 arkTs 端口 查看 ss deployment daemonset statefulset cronjob Charles g++ g++13 NFC 近场通讯 智能门锁 crosstool-ng 崖山数据库 YashanDB 商用密码产品体系 k8s二次开发 集群管理 搭建个人相关服务器 IMX317 MIPI H265 VCU WireGuard 异地组网 运维监控 可用性测试 无桌面 钉钉 做raid 装系统 Radius 进程间通信 Trae叒更新了? GPU训练 端口聚合 windows11 swoole wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 达梦 DM8 材料工程 抓包工具 多个客户端访问 IO多路复用 TCP相关API 语法 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 架构与原理 IDEA 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 gunicorn tailscale derp derper 中转 autodl triton 模型分析 线性代数 电商平台 docker desktop image C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 可执行程序 内存管理 Unity Dedicated Server Host Client 无头主机 欧标 OCPP 软件开发 lua vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 查看显卡进程 fuser ArtTS NVIDIA 源代码管理 kubeless mysql安装报错 windows拒绝安装 word 锁屏不生效 音乐库 post.io 企业邮箱 搭建邮箱 显卡驱动持久化 GPU持久化 docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 开源软件 sentinel 星河版 僵尸世界大战 游戏服务器搭建 es vsxsrv 企业网络规划 华为eNSP midjourney Qwen3 qwen3 32b vllm iventoy VmWare OpenEuler 信创 信创终端 中科方德 SystemV IPv6 IPv6测试 IPv6测速 IPv6检测 IPv6查询 GeneCards OMIM TTD 佛山戴尔服务器维修 佛山三水服务器维修 GIS 遥感 WebGIS Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 c/s client-go xshell termius iterm2 comfyui comfyui教程 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 干货分享 黑客工具 密码爆破 技术共享 我的世界 我的世界联机 glm4 MacOS qt5 客户端开发 hosts massa sui aptos sei 子系统 流量运营 linux子系统 忘记密码 合成模型 扩散模型 图像生成 ISO镜像作为本地源 移动开发 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 Erlang OTP gen_server 热代码交换 事务语义 机械臂 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 rtc csrf AI员工 dns是什么 如何设置电脑dns dns应该如何设置 xss 捆绑 链接 谷歌浏览器 youtube google gmail docker部署Python Ubuntu 24.04.1 轻量级服务器 hugo Python基础 Python教程 Python技巧 docker search VGG网络 卷积层 池化层 Claude 券商 股票交易接口api 类型 特点 prometheus数据采集 prometheus数据模型 prometheus特点 AI agent uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 状态模式 授时服务 北斗授时 冯诺依曼体系 figma 国标28181 监控接入 语音广播 流程 SIP SDP regedit 开机启动 Qwen2.5-VL VS Code 增强现实 沉浸式体验 技术实现 案例分析 AR GoogLeNet IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 resolv.conf 游戏开发 虚幻引擎 hdc hexo ecm bpm 玩机技巧 软件分享 软件图标 负载测试 小智AI服务端 xiaozhi TTS 问题解决 AD 域管理 USB网络共享 react native nosql 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 区块链项目 浏览器开发 AI浏览器 rsync csrutil mac恢复模式进入方法 恢复模式 Sealos HTTP 服务器控制 ESP32 DeepSeek 备选 调用 示例 银河麒麟桌面操作系统 计算机学习路线 编程语言选择 烟花代码 烟花 元旦 性能调优 安全代理 本地知识库部署 DeepSeek R1 模型 极限编程 Helm k8s集群 win服务器架设 windows server 移动魔百盒 飞腾处理器 UFW solidworks安装 lrzsz 粘包问题 authing finebi 输入系统 ABAP 海康 存储维护 NetApp存储 EMC存储 设备树 watchtower MVS 海康威视相机 Bug解决 Qt platform OpenCV 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 大模型推理 macOS 网络原理 西门子PLC 通讯 北亚数据恢复 oracle数据恢复 cpolar Python 视频爬取教程 Python 视频爬取 Python 视频教程 Qt QModbus HAProxy 线程同步 线程互斥 条件变量 大大通 第三代半导体 碳化硅 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 ardunio BLE paddle Masshunter 质谱采集分析软件 使用教程 科研软件 元服务 应用上架 node brew 搜狗输入法 中文输入法 AI Agent 字节智能运维 tidb hosts文件管理工具 pycharm安装 Maxkb RAG技术 本地知识库 火山引擎 框架 yashandb RDP 风扇控制软件 Putty 花生壳 RK3568 充电桩平台 充电桩开源平台 caddy 物理地址 页表 虚拟地址 mvc 接口优化 qwen2vl 桌面快捷方式 百度云 矩池云 数据下载 数据传输 免费 Unity插件 数字证书 签署证书 华为机试 解决方案 静态IP AzureDataStudio 带外管理 李心怡 sequoiaDB vm 服务器正确解析请求体 fiddler yum换源 金仓数据库概述 金仓数据库的产品优化提案 solr 创业创新 计算虚拟化 弹性裸金属 easyTier 组网 PyQt PySide6 mybase Linux的基础开发工具 三次握手 android-studio 鸿蒙NEXT DrissionPage 向量数据库 安装部署 milvus安装 archlinux kde plasma AWS 知行EDI 电子数据交换 知行之桥 EDI 华为昇腾910b3 gru 网络库 d3d12 logstash pythonai PlaywrightMCP webview MinIO 设计规范 CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 Github加速 Mac上Github加速 Chrome浏览器插件 跨域请求 win向maOS迁移数据 STL 命令模式 cocos2d 3dcoat 零售 VM虚拟机 homeassistant element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 脚本 anythingllm open-webui docker国内镜像 harmonyosnext 提示词 deepseek-v3 ktransformers web开发 #STC8 #STM32 finalsheel ECS服务器 PTrade QMT 量化股票 fpga 欧拉系统 Metastore Catalog miniconda 接口返回 swift 进程池实现 gitee go SoC OS bigdata 红黑树封装map和set Bandizip Mac解压 Mac压缩 压缩菜单 java毕业设计 微信小程序医院预约挂号 医院预约 医院预约挂号 小程序挂号 GRANT REVOKE 智能问答 Spring AI Milvus pxe bert mapreduce 定义 核心特点 优缺点 适用场景 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 qtcreator 导航栏 数据库管理 AI提示词优化 动态库 GCC编译器 -fPIC -shared mcp协议 go-zero mujoco 漏洞报告生成 aac