前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Ubuntu20.04试水k8s单机版minikube部署实录

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

作者头像
zhaoolee
发布2021-07-29 12:14:34
1.7K0
发布2021-07-29 12:14:34
举报
文章被收录于专栏:木子昭的博客木子昭的博客

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

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

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

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

安装Docker

代码语言:javascript
复制
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io
  • 离线安装包方式
代码语言:javascript
复制
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

代码语言:javascript
复制
sudo apt-get  update -y
sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils -y

安装 VirtualBox

代码语言:javascript
复制
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

代码语言:javascript
复制
. /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二进制文件
代码语言:javascript
复制
cd /opt
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64

下载minikube-linux-amd64

  • 运行minikube
代码语言:javascript
复制
minikube start
  • 修复VT-X/AMD-v 未增强的错误

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

重新运行 minikube start

运行成功

  • 测试kubectr
代码语言:javascript
复制
minikube kubectl -- get po -A

测试kubectr

  • 运行dashboard, 通过浏览器访问即可看到网页版管理页面
代码语言:javascript
复制
minikube dashboard
  • 查看k8s版本

查看k8s版本

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

  • 在终端新开一个窗口, 创建一个部署
代码语言:javascript
复制
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端口

代码语言:javascript
复制
minikube kubectl -- port-forward service/hello-minikube 7080:8080

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

  • 可以通过本地的7080端口访问成功
  • 创建负载均衡部署, 也是运行在新容器的8080端口
代码语言:javascript
复制
minikube kubectl -- create deployment balanced --image=k8s.gcr.io/echoserver:1.4  
minikube kubectl -- expose deployment balanced --type=LoadBalancer --port=8080

窗口负载均衡部署

创建成功

  • 开启新窗口,运行以下命令, 开启minikube 网络隧道
代码语言:javascript
复制
minikube tunnel

开启minikube 网络隧道

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

获取可通过隧道访问的ip

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

kubectl实用技巧

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

代码语言:javascript
复制
alias kubectl="minikube kubectl --"

使用kubectl

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

代码语言:javascript
复制
kubectl pause

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

代码语言:javascript
复制
kubectl stop

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

代码语言:javascript
复制
kubectl get pods

容器

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

代码语言:javascript
复制
kubectl --help

kubectl

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装Docker
  • 安装KVM2
  • 安装 VirtualBox
  • 安装Podman
  • 安装运行minikube
  • kubectl实用技巧
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档