分类
公众号「0加1」

Ubuntu20.04试水k8s单机版minikube部署实录


title: Ubuntu20.04试水k8s单机版minikube部署实录

最近玩Discourse论坛程序,由于资源消耗过于严重,这个月主机崩了好几次,我打算配合frp内网穿透,把个人服务器做成主从分布的架构,为了便于管理, 我选择采用目前最流行的k8s集群管理技术,对已有服务进行集群式管理,今天先本地Ubuntu20.04搭建一个单机版k8s,也就是minikube,试一下水。

k8s全称 Kubernetes , 是谷歌的一款开源框架, 作用是以集群的方式管理Docker容器,集群方式的好处是,即使部分服务器挂掉,也可以稳定地提供对外服务。

理论上,k8s是用来管理集群的,需要多台机器才能玩的转,但minikube 比较特别, 它可以利用virtualbox虚拟机技术,在一台机器上,模拟多台虚拟机,让我们更简单地体验k8s的魅力。

本文是探索k8s的第一篇文章,选了minikube 作为入门,后续会更新k8s多机部署的文章,以及各种深入研究使用的文章, 做成一个系列~

安装Docker

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io

安装KVM2

sudo apt-get  update -y
sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils -y

安装 VirtualBox

wget https://download.virtualbox.org/virtualbox/6.1.24/virtualbox-6.1_6.1.24-145767~Ubuntu~eoan_amd64.deb

sudo apt install  ./virtualbox-6.1_6.1.24-145767~Ubuntu~eoan_amd64.deb  -y

安装Podman

. /etc/os-release
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_${VERSION_ID}/ /" | sudo tee /etc/apt/sources.list.d/devel:kubic:libcontainers:stable.list
curl -L "https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_${VERSION_ID}/Release.key" | sudo apt-key add -
sudo apt-get update
sudo apt-get -y upgrade
sudo apt-get -y install podman

安装运行minikube

  • 进入/opt文件夹, 下载minikube二进制文件
cd /opt
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64

下载minikube-linux-amd64

  • 运行minikube
minikube start
  • 修复VT-X/AMD-v 未增强的错误

关闭虚拟机,启用虚拟化, 然后开机

重新运行 minikube start

运行成功

  • 测试kubectr
minikube kubectl -- get po -A

测试kubectr

  • 运行dashboard, 通过浏览器访问即可看到网页版管理页面
minikube dashboard

  • 查看k8s版本

查看k8s版本

至此k8s的单机版 minikube, 算是正式跑起来了

  • 在终端新开一个窗口, 创建一个部署
minikube kubectl -- create deployment hello-minikube --image=k8s.gcr.io/echoserver:1.4
minikube kubectl -- expose deployment hello-minikube --type=NodePort --port=8080

创建一个部署

  • 打开Service中的Services , 可以看到新建的部署

新部署

虽然部署显示运行8080端口, 但是现在访问 8080 是不通的, 这个8080端口是运行在自身的容器里, 想要外部访问,需要在外部端口和容器的8080端口之间做一个映射

image.png

image.png

我们可以使用外部的7080端口映射到容器的8080端口

minikube kubectl -- port-forward service/hello-minikube 7080:8080

我们可以使用外部的7080端口映射到容器的8080端口

  • 可以通过本地的7080端口访问成功

  • 创建负载均衡部署, 也是运行在新容器的8080端口
minikube kubectl -- create deployment balanced --image=k8s.gcr.io/echoserver:1.4  
minikube kubectl -- expose deployment balanced --type=LoadBalancer --port=8080

窗口负载均衡部署

创建成功

  • 开启新窗口,运行以下命令, 开启minikube 网络隧道
minikube tunnel

开启minikube 网络隧道

  • 获取可通过隧道访问的ip

获取可通过隧道访问的ip

启用 minikube tunnel 后, 我们也可以在web版services中, 直接看到找到访问的ip和端口

kubectl实用技巧

我们可以使用alias语法将 minikube kubectl -- 使用 kubectl 进行代替

alias kubectl="minikube kubectl --"

使用kubectl

我们安装完成minikube后, 默认会开机自启动, 如果你想临时暂停minikube集群可以运行

kubectl pause

如果想停止集群, 可以运行

kubectl stop

如果我们想查看集群内, 各个容器的状态

kubectl get pods

容器

如果想查阅更多kubectl命令,可以运行

kubectl --help

kubectl

本文永久更新地址(欢迎来读留言,写评论):

https://www.v2fy.com/p/2021-07-26-k8s-1627292526000

发表评论

电子邮件地址不会被公开。


The maximum upload file size: 2 MB.
You can upload: image, audio, video, document, spreadsheet, interactive, text, archive, code, other.
Links to YouTube, Facebook, Twitter and other services inserted in the comment text will be automatically embedded.