1. 前期准备

一台安装了Ubuntu或CentOS的机器(可以是虚拟机),本文中使用的是Ubuntu 19.10虚拟机,内存为2g

配置基础网络、更新源、SSH登录等

2. 下载并安装kubeasz

# 下载工具脚本easzup,举例使用kubeasz版本2.0.2

export release=2.0.2

curl -C- -fLO --retry 3 https://github.com/easzlab/kubeasz/releases/download/${release}/easzup

chmod +x ./easzup

# 使用工具脚本下载

./easzup -D

在最后一步会等待较长的时间,最终结果显示成功即可进行下一步。

3. 配置 ssh 免密登录

首先允许PermitRootLogin:

vim /etc/ssh/sshd_config

找到PermitRootLogin,将该行配置修改为:

PermitRootLogin yes

随后生成密钥:

ssh-keygen -t rsa -b 2048 -N '' -f ~/.ssh/id_rsa

ssh-copy-id $IP # $IP 为所有节点地址包括自身,按照提示输入 yes 和 root 密码

此处我的宿主机的IP为192.168.1.109,即:

ssh-copy-id 192.168.1.109

4. 安装集群

使用工具脚本容器化运行 kubeasz:

./easzup -S

此处也会需要较长的时间,依然是最后显示成功即可继续下一步:

docker exec -it kubeasz easzctl start-aio

完成后,可以验证一下安装情况:

kubectl version # 验证集群版本

kubectl get componentstatus # 验证 scheduler/controller-manager/etcd等组件状态

kubectl get node # 验证节点就绪 (Ready) 状态

kubectl get pod --all-namespaces # 验证集群pod状态,默认已安装网络插件、coredns、metrics-server等

kubectl get svc --all-namespaces # 验证集群服务状态

5. 安装部署Dashboard

部署dashboard 主yaml配置文件:

kubectl apply -f /etc/ansible/manifests/dashboard/kubernetes-dashboard.yaml

创建可读可写admin Service Account:

kubectl apply -f /etc/ansible/manifests/dashboard/admin-user-sa-rbac.yaml

创建只读 read Service Account:

kubectl apply -f /etc/ansible/manifests/dashboard/read-user-sa-rbac.yaml

然后,验证安装情况:

# 查看pod 运行状态

kubectl get pod -n kube-system | grep dashboard

kubernetes-dashboard-7c74685c48-9qdpn 1/1 Running 0 22s

# 查看dashboard service

kubectl get svc -n kube-system|grep dashboard

kubernetes-dashboard NodePort 10.68.219.38 443:24108/TCP 53s

# 查看集群服务

kubectl cluster-info|grep dashboard

kubernetes-dashboard is running at https://192.168.1.1:6443/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy

# 查看pod 运行日志

kubectl logs kubernetes-dashboard-7c74685c48-9qdpn -n kube-system

6. Dashboard访问控制(不可跳过)

新版的Dashboard 有两步访问控制:

通过api-server本身安全认证流程

通过dashboard自带的登录流程

如果不设置访问控制,我们是无法进入UI界面的,虽然我们只是想尝试使用一下kubernetes,但这一步不可跳过。

我们先从第一步开始。

api-server安全认证

官方文档提供了两种认证方法,用户名+密码访问,以及,证书访问。

证书访问是最安全、也是最可靠的方法,但是其配置十分复杂,为了快速上手使用,我们这次先用用户名+密码访问的方式。

首先是用户名和密码的配置,配置文件在/etc/kubernetes/ssl/basic-auth.csv,在这里面可以看到初始的账号密码,如果有需要也可以进行修改:

vim /etc/kubernetes/ssl/basic-auth.csv

接着,我们开启访问控制:

docker exec -it kubeasz easzctl basic-auth -s

Dashboard安全认证

Dashboard支持两种登录方式:Kubeconfig、令牌(Token),我们这次直接使用令牌登录:

# 创建Service Account 和 ClusterRoleBinding

kubectl apply -f /etc/ansible/manifests/dashboard/admin-user-sa-rbac.yaml

# 获取 Bearer Token,找到输出中 ‘token:’ 开头那一行

kubectl -n kube-system describe secret $(kubectl -n kube-system get secret | grep admin-user | awk '{print $1}')

现在可以通过浏览器访问Dashboard了,url可以用如下命令获取:

kubectl cluster-info|grep dashboard

输入令牌,即可完成登录。

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐