【后端】k8s

1. 命令

1.1 获取service服务

  • 获取集群内所有命名空间 的service服务
    sudo kubectl get service --all-namespaces

  • 获取集群内指定 命名空间的service服务
    sudo kubectl get service -n命名空间

  • 当权限限制到一个命名空间 时,只能使用下面这个
    sudo kubectl -n 命名空间 get service

  • 获取集群内当前 命名空间的service服务
    sudo kubectl get service

1.2 获取pod节点

  • 获取集群所有命名空间 的pod
    sudo kubectl get pod --all-namespaces

  • 获取集群内指定 命名空间的pod
    sudo kubectl get pod -n命名空间

  • 当权限限制到一个命名空间 时,只能使用下面这个
    sudo kubectl -n 命名空间 get pod

  • 获取集群内当前 命名空间的pod
    sudo kubectl get pod

1.3 网络

在Kubernetes中,通过Ingress 资源和直接通过 http://servicename.namespace.svc.cluster.local 访问服务(Service)的方式虽然都涉及到服务名(serviceName),但它们的使用场景和目的有所不同,因此不完全等同。
Ingress 资源
Ingress 是 Kubernetes 中的一个 API 对象,它允许你将外部 HTTP(S) 流量路由到你的集群中。Ingress 控制器负责实现这个路由,具体实现方式可能依赖于你的集群配置(例如 Nginx, Traefik, Istio 等)。在 Ingress 资源中,serviceName 字段用于指定将流量路由到的后端服务 的名称。这个 serviceName 指的是 Kubernetes 内部的服务(Service)名称,而不是外部域名或URL。
直接通过 Cluster DNS 访问服务

在 Kubernetes 集群中,每个服务(Service)都会被分配一个集群内部的 DNS 名称,格式为 servicename.namespace.svc.cluster.local。集群中的 Pod 可以通过这个 DNS 名称直接访问服务。这种方式不依赖于 Ingress,它主要用于集群内部的服务发现和通信。

1.4 复制文件

shell 复制代码
##当权限限制命名空间
sudo kubectl -n 命名空间 cp pod-name:/usr/local/logs/error.log  ./error.log

1.5 查看容器日志

shell 复制代码
##当权限限制命名空间
sudo kubectl -n 命名空间 logs -f pod-name #滚动输出 (有点问题)
sudo kubectl -n 命名空间 logs --tail 10 pod-name #查看最后10行
相关推荐
金刚猿15 分钟前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
JH_Kong42 分钟前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
陈桴浮海2 小时前
Kustomize实战:从0到1实现K8s多环境配置管理与资源部署
云原生·容器·kubernetes
张小凡vip3 小时前
Kubernetes--k8s中部署redis数据库服务
redis·kubernetes
Hello.Reader4 小时前
Flink Kubernetes HA(高可用)实战原理、前置条件、配置项与数据保留机制
贪心算法·flink·kubernetes
ShiLiu_mtx5 小时前
k8s - 7
云原生·容器·kubernetes
MonkeyKing_sunyuhua8 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
醇氧9 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
匀泪12 小时前
云原生(LVS NAT模式集群实验)
服务器·云原生·lvs
70asunflower13 小时前
用Docker创建不同的容器类型
运维·docker·容器