Minikube

# 启动集群服务
minikube start # 查看集群服务状态
minikube status

# 登录集群
minikube ssh # 关闭,暂停,恢复,删除集群服务
minikube stop/pause/unpause/delete # 打开dashboard
minikube dashboard # 操作节点(新增/删除/列表)
minikube node add/delete/list # 插件管理
minikube addons list/enable/disable

minikube的服务暴露到宿主机:

minikube 是一款基于 Kubernetes 的定位于快速验证功能的小型容器编排环境。

由于它的定位特性,我们在使用中会发现 minikube 虚拟出了一个 IP 作为自身的节点 IP,该 IP 和宿主机不同。对于 NodePort 类型的 Service 也没有办法通过 127.0.0.1 访问。

Host 内访问

The minikube VM is exposed to the host system via a host-only IP address, that can be obtained with the minikube ip command.

我们必须通过 minikube ip 找到 minikube 的 IP 并通过它来访问 NodePort 类型的 service

另外可以留意到 LoadBalancer 类型的 service 在默认情况下 external IP 为 <pending>,为了要能够访问到 service,需要通过

 minikube tunnel 

建立隧道和服务通信。在执行 minikube tunnel 后,可以发现 external IP 被设置成和 cluster IP 一样的值,这时候就可以通过 <minikube-ip>:<service-port> 来访问 service 了。

Host 外访问

通过 minikube 可以很方便地在本机访问,同时避免了对宿主机端口的占用。但是也带来了另一个问题:无法直接通过访问宿主机的端口来访问 services 进行调试。

比如我的实验机是一台云服务虚拟机,我在自己的电脑上可以访问这台虚拟机,但是不能访问虚拟机上 minikube 暴露的服务。

虽然没有办法让 minikube 直接通过宿主机端口对外暴露 services,但是如果我们把问题换个角度思考,就很容易找到解决办法:如何将一个 service(不特定类型)暴露到本机。

这时候最简单的办法就是通过 kubectl port-forward 转发端口。

假设我有 service/istio-ingressgateway,service 监听 80 端口,我希望暴露在宿主机的 31303 端口,就可以使用以下命令1:·

kubectl port-forward --address 0.0.0.0 -n istio-system service/istio-ingressgateway 31303:80

常见问题:

1.启动插件发生错误

例如minikube  addons enable ingress, 发生错误

解决方式:  https://github.com/kubernetes/minikube/issues/13872

查看对应的pod启动是否启动, 我的就是因为镜像拉取失败导致

2.切换使用的驱动之后,发生启动服务错误的问题

GUEST_PROVISION: Failed to cache ISO: unable to cache ISO:

minikube.exe config set driver virtualbox

解决:

删除之前创建的minikube实例,

先删除~/.minikube/*  然后再重新启动即可

Kubectl

[集群]

# 查看集群信息
kubectl cluster-info

[Node]

# 查看节点
kubectl.exe get node/nodes

[Pod]

# 查看Pod
kubectl get po/pod/pods
-A: 全部
-n: 指定命名空间; kube-system
-o: 输出格式(json/yaml/wide ...), 查看更多信息,例如端口信息可使用wide
-w: 检测观察
-l: 指定标签 key1=value1,key2=values 默认是不显示kube-system下的Pod # 显示详细信息
kubectl describe pod_name
# 打印Pod中容器的日志
kubectl logs pod_name
# 在Pod中容器上执行命令
kubectl exec pod_name

# 进入Pod内的容器
kubectl exec -it nginx-pod /bin/bash

# 删除Pod
kubectl.exe delete -f .\nginx.yaml
kubectl delete pod nginx-pod

# 将本地端口与指定Pod进行端口映射
kubectl.exe port-forward nginx-pod 4000:80

[Service]

# 查看Service
kubectl.exe get service/services
# 清理
kubectl delete service service_name # 查看集群时间
kubectl get events # 查看kubectl配置
kubectl config view # 支持同时指定多个
kubectl get pod,svc -n kube-system

[Deployment]

# 查看Deployment
kubectl.exe get deployment/deployments

# 发布
kubectl apply -f deployment.yaml

# 回滚
kubectl rollout undo deployment [deployment名称]

在 deployment 的资源定义中, spec.strategy.type 有两种选择:

  • RollingUpdate: 逐渐增加新版本的 pod,逐渐减少旧版本的 pod。
  • Recreate: 在新版本的 pod 增加前,先将所有旧版本 pod 删除。

大多数情况下我们会采用滚动更新 (RollingUpdate) 的方式,滚动更新又可以通过 maxSurge 和 maxUnavailable 字段来控制升级 pod 的速率,具体可以详细看官网定义。:

  • maxSurge: 最大峰值,用来指定可以创建的超出期望 Pod 个数的 Pod 数量。
  • maxUnavailable: 最大不可用,用来指定更新过程中不可用的 Pod 的个数上限。


# 查看历史版本

kubectl rollout history deployment hellok8s-deployment

# 回滚到指定版本
kubectl rollout undo deployment/hellok8s-deployment --to-revision=2



# 暴露端口
kubectl expose deployment hello-node --type=LoadBalancer --port=8080

[Namespace]

# 查看命名空间列表
kubectl.exe get ns

[Yaml]

# 查看不同的资源类型对应的apiVersion版本是多少
kubectl api-resources -o wide
列出对应的资源的简写和对应的版本信息
NAME:资源名称
SHORTNAMES:资源名称简写
APIGROUP:就是apiVersion
NAMESPACED:是否需要指定名称空间
KIND:资源类型
VERBS:可用的方法 # 获取指定api组的api资源
kubectl api-resources --api-group apps # 查看支持的所有api
kubectl api-versions # 获取指定资源的版本信息
kubectl explain deployment

Kubelet

Kubeadm

k8s之常用命令的更多相关文章

  1. k8s的常用命令(一)

    常用的kubectl命令   kubectl run kubia --image=luksa/kubia --port=8080 --generator=run/v1   --image 指定镜像 - ...

  2. k8s维护常用命令

    k8s维护 1. 不可调度 kubectl cordon k8s-node-1 kubectl uncordon k8s-node-1 #取消 2.驱逐已经运行的业务容器 kubectl drain ...

  3. K8s (常用命令)

    查看集群信息: [root@kubernetes-master pods]# kubectl cluster-infoKubernetes master is running at http://lo ...

  4. k8s~kubectl常用命令

    查看所有 pod 列表, -n 后跟 namespace, 查看指定的命名空间 kubectl get pod kubectl get pod -n kube kubectl get pod -o w ...

  5. kubernetes(k8s) 的常用命令

    1.查询副本[root@master ~]# kubectl get pods2.删除一个副本[root@master ~]# kubectl get pods 3.启动一个容器副本[root@mas ...

  6. [转帖] K8S 常用命令

    k8s常用命令  原贴地址 查看集群信息: [root@kubernetes-master pods]# kubectl cluster-info kubectl cluster-info展示结果 k ...

  7. k8s常用命令记录

    目录 kubectl常用命令 kubectl get pod -n dev 查看日志 查看pod详情 删除pod 删除job 进入pod里面 查看namespace 创建namespace 删除nam ...

  8. K8s常用命令操作

    K8s常用命令操作 一.kubectl命令补全 1.master安装命令补全,并临时生效 yum install -y bash-completion source /usr/share/bash-c ...

  9. 使用kubectl管理Kubernetes(k8s)集群:常用命令,查看负载,命名空间namespace管理

    目录 一.系统环境 二.前言 三.kubectl 3.1 kubectl语法 3.2 kubectl格式化输出 四.kubectl常用命令 五.查看kubernetes集群node节点和pod负载 5 ...

  10. k8s介绍与常用命令

    kubernetes基础与常用命令 原文地址 https://blog.csdn.net/footless_bird/article/details/125798691 官方文档 https://ku ...

随机推荐

  1. vue router路由配置,元信息meta的使用-登录拦截验证

    原文来自 vue router路由配置,元信息meta的使用-登录拦截验证_shenroom的博客-CSDN博客 看原文排版更舒服,我只是记录一下 路由基本配置1.在router文件夹中找到 inde ...

  2. CCIA数安委等组织发布PIA星级标识名单,合合信息再次通过数据安全领域权威评估

    CCIA数安委等组织发布PIA星级标识名单,合合信息再次通过数据安全领域权威评估   近期,"中国网络安全产业联盟(CCIA)数据安全工作委员会"."数据安全共同体计划( ...

  3. CSS – 实战 Font

    前言 这篇想整理一下在网页开发中, 字体是如果被处理的. 先看完: 平面设计 – 字体 CSS – Font / Text 属性 CSS – Font Family CSS – word-break, ...

  4. Angular 学习笔记 (Typescript 高级篇)

    由于 typescript 越来越复杂. 所以特意开多一个篇幅来记入一些比较难的, 和一些到了一定程度需要知道的基础. 主要参考 https://basarat.gitbook.io/typescri ...

  5. Go runtime 调度器精讲(五):调度策略

    原创文章,欢迎转载,转载请注明出处,谢谢. 0. 前言 在 第四讲 我们介绍了 main goroutine 是如何运行的.其中针对 main goroutine 介绍了调度函数 schedule 是 ...

  6. JAVAEE——idea安装

    一.安装idea 1.点击这里下载jar包 2.点击这里下载idea2019    提取码:1234 (也可自行官网下载付费版自行寻找破解) 3.下载后jar压缩包后解压,把里面那个jar文件随意放在 ...

  7. Scala编程语言基本常识

    ​ 本文参考来源: Scala编程语言基本常识 – 萌面人博客 ​ 一 基本常识 Scala被称为大数据的黄金语言,它的发明人是马丁奥德斯基(Martin Odersky) 2001年诞生,融合了Ja ...

  8. Maya 无法选中坐标轴 的 解决办法

    事件起因: 有项目组某同事在使用maya时,无法选中坐标轴,导致在拖动东西的时候总是无法对准坐标轴线. 解决办法: maya软件中设置: Windows -> Settings/Preferen ...

  9. 墨天轮国产数据库沙龙 | 张玮绚:TDengine,高性能、分布式、支持SQL的时序数据库

    分享嘉宾:张玮绚(Wade Zhang)北京涛思数据科技有限公司(TDengine)研发VP 整理:墨天轮 导读 TDengine 是一款高性能.分布式.支持 SQL 的时序数据库,让大量设备.数据采 ...

  10. amfe-flexible 包设置rem的基本值 vue 移动端适配方案

    下载 安装 :npm i -S amfe-flexible gw:GitHub - amfe/lib-flexible: 可伸缩布局方案 下载 2 个第三方包即可实现移动端适配 amfe-flexib ...