1. 安装 / 卸载

1 .1 前提条件

  • homebrew安装kubectl

  • docker本身设置镜像加速

  • 以下操作如果失败,开启ssr的全局模式进行再次操作

1.2 安装方式

  • homebrew【不好使】

  • 二进制【参照如下的链接】

Minikube - Kubernetes本地实验环境

1.3 卸载

# 停止集群
minikube stop

# 清理minikube本地状态
minikube delete # 通过homebrew卸载
brew uninstall minikube

2. 通过 minikube 学习 k8s 实操基础

2.1 创建集群

# 二进制安装minikube
curl -Lo minikube https://github.com/kubernetes/minikube/releases/download/v1.9.2/minikube-darwin-amd64 \
&& chmod +x minikube && sudo mv minikube /usr/local/bin/ # 创建minikube集群【使用阿里的镜像】
# !!这一句之后,kubectl还会被配置为默认使用minikube!!
minikube start --image-mirror-country cn \
--iso-url=https://kubernetes.oss-cn-hangzhou.aliyuncs.com/minikube/iso/minikube-v1.9.0.iso \
--registry-mirror=https://rnbhv8m8.mirror.aliyuncs.com # 完成后,查看minikube状态
minikube status # 打开本地dashboard
minikube dashboard

2.2 部署应用

  • deployment会帮我们创建pod

  • pod运行在一个私有的,隔离的网络上。默认情况下可以被同一个集群的其他【pod】和【service】所访问到,但是外部网络无法访问,需要通过service来暴露给外部

# 创建第一个deployment【deployment会自动创建一个pods】
kubectl create deployment codepie --image=lzw5399/codepiefe:20200423. # 获取deployments信息
kubectl get deploy【或者全称deployments】 # 获取deploy创建的pod信息
kubectl get pods # 临时地,允许通过api访问api-server
# 通过以下链接访问具体的pod:
# [http://localhost:8001/api/v1/namespaces/default/pods/具体的pod_name/proxy/](http://localhost:8001/api/v1/namespaces/default/pods/具体的pod_name/proxy/)
kubectl proxy
【Starting to serve on 127.0.0.1:8001】

2.3 探索当前应用【故障排除】

1 # 获取资源
2 kubectl get pods
3 # 显示当前pod的详细状态信息
4 kubectl describe pods
5 # 显示当前pod的日志
6 kubectl logs codepie-677c5c9c56-wk4qn【pod名字】
7 # 针对某个pod执行一个命令
8 # 显示当前pod内部的环境变量
9 kubectl exec codepie-677c5c9c56-wk4qn -- env
10 # 进入到pod内部
11 kubectl exec -ti codepie-677c5c9c56-wk4qn -- bash

2.4 公开暴露应用

  • 思路就是创建service来将pod转发出去

  • 创建service的方式

  1. kubectl expose deployment/{depoly_name} --type="NodePort" --port 80【这个port是docker容器内部的端口】
  2. kubectl create service nodeport codepie --tcp=80: 80 【create这个 80 : 80 】
  3. kubectl create -f xxx.yaml 【不推荐】
  4. kubectl apply -f xxx.yaml【推荐】
# 通过上面的方式之一来建立起service

# 访问, 或者直接在浏览器中直接访问下面的地址
# minikube ip是minikube帮我们创建的虚拟机的ip,对应着正式k8s中的pod所在node的外网ip
curl $(minikube ip):{向外暴露的端口}

2.5 使用label

# 打label
kubectl label pod {pod_name} {key}={value} # 根据label来获取
kubectl get po -l {key}={value}

2.6 扩容应用

  • 适用于无状态应用,将一个应用扩容多个实例

  • 扩容后,service会有一个均衡负载的功能,将请求发送到相同实例的不同的pod

  • 还支持自动缩放,但是超出了本教程的范围

  • 一旦运行了多个应用程序的多个实例,就可以在不停机的情况下滚动更新

# 获取所有的deploy部署的容器实例个数
# 【DESIRED】期望的个数 【CURRENT】实际的个数
kubectl get rs 【ReplicaSet】 # 将deploy/codepie 的实例扩容成四个
# 缩容就改一下 replicas 的数值就好了
kubectl scale deploy/codepie --replicas= 4 # 以下几个都可以查看到实例变成四个
kubectl get po -o wide
kubectl get rs
kubectl get deploy

2.7 更新应用

  • 多个实例的情况下可以滚动不停机更新,且允许以下操作:
  1. 通过更新docker image,更新应用程序
  2. 回顾到以前的版本
  3. CI/CD, 停机时间为 0
  • 默认情况下,在更新过程中的【不可用pod的最大数量】和【可以创建新的pod的最大数量】都为 1。这两个选项都可以配置为数字或者百分比
  • 更新过程中,service会仅将流量负载到【可用的pod】
# 更新deploy对应的image
# 格式 kubectl set image deploy/{depoly_name} {docker镜像的后半部分名字}={新的image} kubectl set image deploy/codepie codepiefe=lzw5399/codepiefe:20200410. # 打印滚动更新中的状态信息
kubectl rollout status deploy/codepie # 回滚到指定版本,不加--to-version则回滚到上一个版本
kubectl rollout undo deploy/codepie --to-revision= 2 # 查看状态
kubectl describe po

其他章节

Kubernetes系列(一) - kubernetes入门基本概念

kubernetes系列(二) - kubectl的入门操作的更多相关文章

  1. kubernetes系列05—kubectl应用快速入门

    本文收录在容器技术学习系列文章总目录 1.使用kubectl 1.1 介绍 kubectl用于运行Kubernetes集群命令的管理工具. 1.2 语法 kubectl [command] [TYPE ...

  2. JAVA通信系列二:mina入门总结

    一.学习资料 Mina入门实例(一) http://www.cnblogs.com/juepei/p/3939119.html Mina入门教程(二)----Spring4 集成Mina http:/ ...

  3. Kubernetes系列(二)Service

    作者: LemonNan 原文地址: https://juejin.im/post/6863704173931593736 Service Kubernetes 的 Service 可以为一组具有相同 ...

  4. Kubernetes系列二: 使用kubeadm安装k8s环境

    环境 三台主机,一台master,两台node 作为master 作为node节点 作为node节点 每台主机Centos版本使用 CentOS Linux release 7.6.1810 (Cor ...

  5. 【Kubernetes 系列二】从虚拟机讲到 Kubernetes 架构

    目录 什么是虚拟机? 什么是容器? Docker Kubernetes 架构 Kubernetes 对象 基础设施抽象 在认识 Kubernetes 之前,我们需了解下容器,在了解容器之前,我们得先知 ...

  6. DBProxy 入门到精通系列(二):DBProxy快速入门教程

    这里主要用来了解有关DBProxy方面的部署及基本的配置,以及模拟架构 1 DBProxy方面的安装部署 1)基础环境的部署 # .x86_64 Percona-Server-client-.x86_ ...

  7. 消息中间件系列二:RabbitMQ入门(基本概念、RabbitMQ的安装和运行)

    一.基本概念 1. AMQP AMQP,即Advanced Message Queuing Protocol,一个提供统一消息服务的应用层标准高级消息队列协议.支持不同语言和不同的产品 2. 生产者 ...

  8. Kubernetes系列(五) Ingress

    作者: LemonNan 原文地址: https://juejin.im/post/6878269825639317517 Kubernetes 系列 Kubernetes系列(一) Pod Kube ...

  9. Kubernetes系列(三) Deployment

    作者: LemonNan 原文地址: https://juejin.im/post/6865672466939150349/ Kubernetes 系列 Kubernetes系列(一) Pod Kub ...

  10. Kubernetes系列(四) StatefulSet

    作者: LemonNan 原文地址: https://juejin.im/post/6870071267438329869 Kubernetes系列(四) StatefulSet Kubernetes ...

随机推荐

  1. 使用 Cursor 和 Devbox 快速开发并上线 Gin 项目

    作为开发者,最让我们头疼的事情是什么?那必须是环境配置.版本控制以及各种部署配置等等繁琐的工作. 想象一下,如果你只需点击几下鼠标,就能拥有一个完全配置好的开发环境,支持从 Java 到 Python ...

  2. CF939 D

    CF939 D 让你把区间分成 \(k\) 段, 段内用 \(xor\) 连接, 段之间用 \(or\) 连接,问你在结果不大于 \(x\) 的前提下, \(k\) 的最大值 \(1 \leq n \ ...

  3. 访问浪潮带外BMC界面的远程控制台重定向(KVM)无法访问,提示JViewer未签名,mac电脑安装JDK8

    报错截图: 安装JDK8 下载JDK1.8的安装包 Java Downloads | Oracle 下载的安装包双击按提示流程安装: 按照完成以后.我们可以查看JDK的安装路径.在资源库/Librar ...

  4. 鸿蒙Navigation入门使用

    Navigation组件适用于模块内和跨模块的路由切换,通过组件级路由能力实现更加自然流畅的转场体验,并提供多种标题栏样式来呈现更好的标题和内容联动效果.一次开发,多端部署场景下,Navigation ...

  5. 4G模组AT指令 | MQTT应用指南!

    今天,老师傅讲的是关于4G模组AT指令之MQTT应用,以4G模组Air780E为例: 一.MQTT 协议简介 1.1 MQTT 概述 MQTT 是一种轻量级的消息传输协议,旨在在物联网(IoT)应用中 ...

  6. P4253 SCOI2015 小凸玩密室

    P4253 SCOI2015 小凸玩密室 一道紫色的 dp. 思路 首先读题: 要保证任意时刻所有被点亮的灯泡必须连通 在点亮一个灯泡后必须先点亮其子树所有灯泡才能点亮其他灯泡 考虑设 \(g[u][ ...

  7. elementUI中的级联选择器,默认赋值不起作用

    今天遇到再使用element的级联选择器功能的时候,是多选,默认赋值不起作用. 后来查到是因为少了multiple属性,但是multiple属性要放在props绑定的对象中,而不是直接放在标签上 &l ...

  8. Lambda【1】-- List相关Lambda表达式使用(上篇)

    Lambda在jdk1.8里面已经很好用了,在这里不讲底层的实现,只有简单的用法,会继续补全. 首先一个list我们要使用lambda的话,需要使用它的stream()方法,获取流,才能使用后续的方法 ...

  9. mac通过网线连接主机(fnOS)

    一.mac端 mac是typec的,用了个转接头+网线直连主机,初始化的时候跟下面一致,默认都是自动的 点击详细信息,配置IPv4选择使用DHCP 二.主机端 主机端是最麻烦的,刚开始的时候怎么也找不 ...

  10. maven 分离打包的技术

    1.概要 我们在构建springboot 程序的时候,可以将所有的文件打包成一个大的文件,这个使用起来还是很方便的,但是有些情况下不是很方便,比如 程序需要经常更新的时候,通过网络传输就比较慢,还有比 ...