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
minikube start
- 修复VT-X/AMD-v 未增强的错误
关闭虚拟机,启用虚拟化, 然后开机
重新运行 minikube start
- 测试kubectr
minikube kubectl -- get po -A
- 运行dashboard, 通过浏览器访问即可看到网页版管理页面
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
- 打开Service中的Services , 可以看到新建的部署
虽然部署显示运行8080端口, 但是现在访问 8080 是不通的, 这个8080端口是运行在自身的容器里, 想要外部访问,需要在外部端口和容器的8080端口之间做一个映射
我们可以使用外部的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 网络隧道
minikube tunnel
- 获取可通过隧道访问的ip
启用 minikube tunnel 后, 我们也可以在web版services中, 直接看到找到访问的ip和端口
kubectl实用技巧
我们可以使用alias语法将 minikube kubectl --
使用 kubectl
进行代替
alias kubectl="minikube kubectl --"
我们安装完成minikube后, 默认会开机自启动, 如果你想临时暂停minikube集群可以运行
kubectl pause
如果想停止集群, 可以运行
kubectl stop
如果我们想查看集群内, 各个容器的状态
kubectl get pods
如果想查阅更多kubectl命令,可以运行
kubectl --help
本文永久更新地址(欢迎来读留言,写评论):
https://www.v2fy.com/p/2021-07-26-k8s-1627292526000
- 点赞
- 收藏
- 关注作者
评论(0)