K8S-Minikube安装和操作实践

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
简介: Minikube的安装过程和操作实践

本文旨在记录一下自己的安装和更新过程,并记录Minikube的一些操作实践,加深对Minikube的理解。

注:本文提及的操作环境为Ubuntu 18.04

安装过程

1. 获取minikube二进制文件

  • 访问https://github.com/kubernetes/minikube/releases,点开具体版本的Asset, 下载相应的minikube-linux-arm64文件(v1.7.3)
  • 拷贝到/usr/loca/bin/,赋予可执行权限
  • 注:minikube带内置的docker, 所以不采用--vm-duriver=none可以不用单独安装docker

2. 获取kubectl二进制文件

3. 安装virtualbox

  • 因为kubernets的Node需要运行在我的ubuntu的虚拟机上,采用virtualbox作为虚拟机软件
  • sudo apt-get install virtualbox

4. 启动

$ minikube start --vm-driver=virtualbox --image-mirror-contry=cn --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers --iso-url=https://kubernetes.oss-cn-hangzhou.aliyuncs.com/minikube/iso/minikube-v1.7.3.iso  --registry-mirror=https://hub-mirror.c.163.com
  • 注1:需要指定国内镜像,加速镜像下载过程
  • 注2:vm-driver=none的话是使用本机的docker, 不贴近实际的生产环境,不推荐
  • 注3:一开始我选择minikube v1.9.0, 在minikube start时候下载一个500多M的preloaded-images-k8s....tag.lz4, 下载后就一直停在那里,看release history是在v1.8.2修复的bug

Minikube常用命令

Minikube运行状态

$ minikube status
host: Running
kubelet: Running
apiserver: Running
kubeconfig: Configured

虚拟机运行状况

$ vboxmanage list vm

登陆Minikube虚拟机

$ minikube ssh
$ docker ps

可以看到docker ps列出的是kubernetes里的docker, 不是安装minikube的host的docker

显示K8S master和cluster

$ kubectl cluster-info [dump]

Minikube dashboard

$ minikube dashboard

列出所有nodes和pods和services

$ kubectl get nodes 
$ kubectl get pods --all-namespaces
$ kubectl get services

可以看出,minikube的安装会生成一个node,里面运行多个pod, 譬如kube-proxy, apiserver, controller-manager等
初始安装只有kubernetes一个service

使用和撤销与Minikube VM相同的Docker主机

$ eval $(minikube docker-env)
$ eval $(minikube docker-env -u)

在Minikube集群部署应用

参考1:http://docs.kubernetes.org.cn/126.html

创建Node应用

server.js

var http = require('http');

var handleRequest = function(request, response) {
  console.log('Received request for URL: ' + request.url);
  response.writeHead(200);
  response.end('Hello World!');
};
var www = http.createServer(handleRequest);
www.listen(8080);

确保 node server.js 可执行

创建Docker容器镜像

Dockerfile

FROM node:latest
EXPOSE 8080
COPY server.js .
CMD node server.js

使用与Minikube VM相同的Docker主机构建镜像

$ eval $(minikube docker-env)
$ docker build -t hello-node:v1 .

注:如果Dockerfile里的基础镜像不在registry mirror的已有镜像列表里,会导致从官方docker.io下载,下载不下来而构建失败,可以先用docker search image-name命令查看一下已有的基础镜像和版本,然后把本地的Dockerfile更新为此版本

创建Deployment

注:上面中文参考文档的命令是kubectl run, 但在我的Minikube环境只生成了pod没有生成deployment, 所以直接用kubectl create deployment

$ kubectl create deployment hello-node --image=hello-node:v1

创建后可以从一下命令分别查看pod列表,deployment列表,集群events

$ kubectl get pods
$ kubectl get deployments
$ kubectl get events

创建Service

先用kubectl expose将pod暴露的外部环境

$ kubectl expose deployment hello-node --type=LoadBalancer --port=8080

查看刚创建的Service

$ kubectl get services

获取服务的kubernetes URL

$ minikube service hello-node

然后可以通过获得的URL访问server.js提供的服务

最后,可以运行minikube dashboard查看kubernetes集群的整体信息,可以看到新创建的pod/deployment/service等。

通过YAML部署集群

参考:https://www.liammoat.com/blog/2019/using-kubectl-to-generate-kubernetes-yaml

生成YAML

以上创建Pod/Deployment/Service的kubectl命令,都可以通过 --dry-run -o yaml的方式生成部署需要的YAML内容

$ echo "---" > deployment.yaml
$ kubectl create deployment hello-node --image=hello-node:v1 --dry-run -o yaml >> deployment.yaml
$ echo "---" >> deployment.yaml
$ kubectl expose deployment hello-node --type=LoadBalancer --port=8080 --dry-run -o yaml >> deployment.yaml

生成的YAML示例:

---
apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  labels:
    app: hello-node
  name: hello-node
spec:
  replicas: 2
  selector:
    matchLabels:
      app: hello-node
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
      labels:
        app: hello-node
    spec:
      containers:
      - image: hello-node:v1
        name: hello-node
        resources: {}
status: {}
---
apiVersion: v1
kind: Service
metadata:
  creationTimestamp: null
  labels:
    app: hello-node
  name: hello-node
spec:
  ports:
  - port: 8080
    protocol: TCP
    targetPort: 8080
  selector:
    app: hello-node
  type: LoadBalancer
status:
  loadBalancer: {}

注:我把Deployment.spec.replicas改成了2, 验证是否能自动创建2个pod

通过YAML部署

$ kubectl create -f deployment.yaml
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
3月前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
148 2
|
2月前
|
人工智能 运维 监控
阿里云ACK容器服务生产级可观测体系建设实践
本文整理自2024云栖大会冯诗淳(花名:行疾)的演讲,介绍了阿里云容器服务团队在生产级可观测体系建设方面的实践。冯诗淳详细阐述了容器化架构带来的挑战及解决方案,强调了可观测性对于构建稳健运维体系的重要性。文中提到,阿里云作为亚洲唯一蝉联全球领导者的容器管理平台,其可观测能力在多项关键评测中表现优异,支持AI、容器网络、存储等多个场景的高级容器可观测能力。此外,还介绍了阿里云容器服务在多云管理、成本优化等方面的最新进展,以及即将推出的ACK AI助手2.0,旨在通过智能引擎和专家诊断经验,简化异常数据查找,缩短故障响应时间。
阿里云ACK容器服务生产级可观测体系建设实践
|
2月前
|
Kubernetes 应用服务中间件 nginx
二进制安装Kubernetes(k8s)v1.32.0
本指南提供了一个详细的步骤,用于在Linux系统上通过二进制文件安装Kubernetes(k8s)v1.32.0,支持IPv4+IPv6双栈。具体步骤包括环境准备、系统配置、组件安装和配置等。
477 10
|
2月前
|
运维 Kubernetes 调度
阿里云容器服务 ACK One 分布式云容器企业落地实践
阿里云容器服务ACK提供强大的产品能力,支持弹性、调度、可观测、成本治理和安全合规。针对拥有IDC或三方资源的企业,ACK One分布式云容器平台能够有效解决资源管理、多云多集群管理及边缘计算等挑战,实现云上云下统一管理,提升业务效率与稳定性。
|
3月前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
3月前
|
Kubernetes 持续交付 开发者
探索并实践Kubernetes集群管理与自动化部署
探索并实践Kubernetes集群管理与自动化部署
69 1
|
3月前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
91 1
|
3月前
|
Kubernetes 监控 负载均衡
深入云原生:Kubernetes 集群部署与管理实践
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术以其弹性、可扩展性成为企业IT架构的首选。本文将引导你了解如何部署和管理一个Kubernetes集群,包括环境准备、安装步骤和日常维护技巧。我们将通过实际代码示例,探索云原生世界的秘密,并分享如何高效运用这一技术以适应快速变化的业务需求。
82 1
|
3月前
|
Kubernetes 负载均衡 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第27天】Kubernetes(简称K8s)是云原生应用的核心容器编排平台,提供自动化、扩展和管理容器化应用的能力。本文介绍Kubernetes的基本概念、安装配置、核心组件(如Pod和Deployment)、服务发现与负载均衡、网络配置及安全性挑战,帮助读者理解和实践Kubernetes在容器编排中的应用。
128 4
|
3月前
|
Kubernetes 监控 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第26天】随着云计算技术的发展,容器化成为现代应用部署的核心趋势。Kubernetes(K8s)作为容器编排领域的佼佼者,以其强大的可扩展性和自动化能力,为开发者提供了高效管理和部署容器化应用的平台。本文将详细介绍Kubernetes的基本概念、核心组件、实践过程及面临的挑战,帮助读者更好地理解和应用这一技术。
87 3

热门文章

最新文章