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

2021-07-27  本文已影响0人  zhaoolee

最近玩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
wget https://download.docker.com/linux/ubuntu/dists/focal/pool/stable/amd64/docker-ce_20.10.7~3-0~ubuntu-focal_amd64.deb

sudo apt install -y ./docker-ce_20.10.7~3-0~ubuntu-focal_amd64.deb

wget https://download.docker.com/linux/ubuntu/dists/focal/pool/stable/amd64/docker-ce-cli_20.10.7~3-0~ubuntu-focal_amd64.deb

sudo apt install -y ./docker-ce-cli_20.10.7~3-0~ubuntu-focal_amd64.deb

wget https://download.docker.com/linux/ubuntu/dists/focal/pool/stable/amd64/containerd.io_1.4.8-1_amd64.deb

sudo apt install -y ./containerd.io_1.4.8-1_amd64.deb

安装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

cd /opt
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
sudo install minikube-darwin-amd64 /usr/local/bin/minikube
下载minikube-linux-amd64
minikube start

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

重新运行 minikube start

运行成功
minikube kubectl -- get po -A
测试kubectr
minikube dashboard
查看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

创建一个部署 新部署

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

image.png image.png

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

minikube kubectl -- port-forward service/hello-minikube 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 tunnel
开启minikube 网络隧道 获取可通过隧道访问的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
上一篇 下一篇

猜你喜欢

热点阅读