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. HTB打靶记录-Infiltrator

    nmap scan nmap -A 10.10.11.31 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-10-15 13:18 CST Nma ...

  2. css flex布局的使用

    felx弹性布局 display:flex; 属性值 flex-direction 属性定义容器要在哪个方向上堆叠 flex 项目.默认为水平方向 row, column 值设置垂直方向.如:flex ...

  3. (系列九)使用Vue3+Element Plus创建前端框架(附源码)

    说明 该文章是属于OverallAuth2.0系列文章,每周更新一篇该系列文章(从0到1完成系统开发). 该系统文章,我会尽量说的非常详细,做到不管新手.老手都能看懂. 说明:OverallAuth2 ...

  4. 安卓微信小程序开发之“蓝牙”

    一.写在前面 在微信当中是支持两种蓝牙模式,分别是"经典蓝牙--BT"和"低功耗蓝牙--BLE".通常在和外围单片机设备进行连接的时候用的是低功耗蓝牙这个模式, ...

  5. Object.assign:对象属性复制,浅拷贝

    Object.assign = Object.assign || function(){ if(arguments.length == 0) throw new TypeError('Cannot c ...

  6. 如何挑选海外4G模组?这里有秘籍!

    今天我会告诉大家如何挑选海外4G模组,我会把优势给贴出作为参考.去过国外的都知道国外4G网络各种状况实在让人无力吐槽,做海外设备的朋友,是时候了解一下Air780EEN/EEU/EEJ系列海外模组-- ...

  7. 使用yt-dlp下载youtube高清2k 60fps视频

    只演示windows下的操作,linux和mac应该差不多的命令行. 首先放上github仓库地址:https://github.com/yt-dlp/yt-dlp 它的介绍: 厉害啊,支持数千个网站 ...

  8. python socket检测端口及ping检测

    python根据socket模块检测端口及vip #!/usr/bin/env python # -*- coding: utf8 -*- from .ping_helper import Pinge ...

  9. Jenkins之插件汇总

    Nodejs: 构建前端项目或Node项目 Build Name and Description Setter Publish over SSH: 远程执行shell命令 Blue Ocean   友 ...

  10. Django之gunicorn部署

    安装: pip install gunicorn 启动应用: gunicorn -w 3 -k gthread -e DJANGO_SETTINGS_MODULE=settings.prod Serv ...