本文档旨在介绍如何在aws上搭建k8s集群
在aws上搭建k8s集群主要有以下两个步骤:
1.购买跳板机
首先需要购买一个ec2实例作为跳板机来控制k8s集群,这个实例不需要很高的配置
2.部署集群
用上一步购买的跳板机创建集群,集群的配置可以自行调整
下面对每一步进行详细介绍。
用户可以在EC2控制台购买想要的实例作为跳板机。
具体的操作如下:
- 打开 Amazon EC2 控制台,从控制台控制面板中,点击启动实例按钮。
- 选择合适的AMI,建议选用Amazon Linux 2 AMI。
- 选择实例类型,建议选用默认的t2.micro,选好后点击审核和启动
- 在审核界面,在核查实例启动页面上的安全组栏中点击编辑安全组,然后在配置安全组界面中点击选择一个现有的安全组,点击名称为default的安全组,再点击审核和启动。
- 在审核界面点击启动,在弹出的密钥对窗口中选择创建新密钥对,自定义密钥名称后下载密钥对,请一定保存好密钥对文件,因为丢失后无法再次下载。以上操作完成后点击启动实例即可完成跳板机购买。
请注意:密钥对文件下载之后请修改权限为400。
在上一步购买的实例启动后会显示公网ip和DNS,连接到实例进行部署,连接需要用到刚才下载的密钥对文件(后缀为.pem),连接指令如下:
ssh -i ec2key.pem ec2-user@12.23.34.123
或
ssh -i ec2key.pem ec2-user@ec2-12-23-34-123.us-west-2.compute.amazonaws.com
连接到跳板机后,需要安装一系列操控组件,具体如下:
- 安装pip
sudo yum -y install python-pip
- 安装或升级 AWS CLI
sudo pip install --upgrade awscli
- 安装 eksctl
curl --silent \
--location "https://github.com/weaveworks/eksctl/releases/download/latest_release/eksctl_$(uname -s)_amd64.tar.gz" \
| tar xz -C /tmp
sudo mv /tmp/eksctl /usr/local/bin
- 安装 kubectl
curl -o kubectl https://amazon-eks.s3-us-west-2.amazonaws.com/1.11.5/2018-12-06/bin/linux/amd64/kubectl
chmod +x ./kubectl
mkdir -p $HOME/bin && cp ./kubectl $HOME/bin/kubectl && export PATH=$HOME/bin:$PATH
- 安装 aws-iam-authenticator
curl -o aws-iam-authenticator https://amazon-eks.s3-us-west-2.amazonaws.com/1.11.5/2018-12-06/bin/linux/amd64/aws-iam-authenticator
chmod +x aws-iam-authenticator
cp ./aws-iam-authenticator $HOME/bin/aws-iam-authenticator && export PATH=$HOME/bin:$PATH
- 安装 ksonnet
export KS_VER=0.13.1
export KS_PKG=ks_${KS_VER}_linux_amd64
wget -O /tmp/${KS_PKG}.tar.gz https://github.com/ksonnet/ksonnet/releases/download/v${KS_VER}/${KS_PKG}.tar.gz
mkdir -p ${HOME}/bin
tar -xvf /tmp/$KS_PKG.tar.gz -C ${HOME}/bin
sudo mv ${HOME}/bin/$KS_PKG/ks /usr/local/bin
安装好这些组件后,用户可以购买集群并部署,指令如下:
eksctl create cluster paddle-cluster \
--version 1.13 \
--nodes 2 \
--node-type=m5.2xlarge \
--timeout=40m \
--ssh-access \
--ssh-public-key ec2.key \
--region us-west-2 \
--auto-kubeconfig
其中:
--version 指k8s版本,目前aws支持1.12, 1.13 和 1.14
--nodes 指节点数量
--node-type 指节点实例型号,用户可以挑选自己喜欢的实例套餐
--ssh-public-key 用户可以使用之前购买跳板机时定义的密钥名称
--region 指节点所在地区
部署集群所需时间较长,请耐心等待,当部署成功后,用户可以测试集群,具体方法如下:
- 输入以下指令查看节点信息:
kubectl get nodes -o wide
- 验证集群是否处于活动状态:
aws eks --region <region> describe-cluster --name <cluster-name> --query cluster.status
应看到如下输出:
"ACTIVE"
- 如果在同一跳板机中具有多个集群设置,请验证 kubectl 上下文:
kubectl config get-contexts
如果未按预期设置该上下文,请使用以下命令修复此问题:
aws eks --region <region> update-kubeconfig --name <cluster-name>
以上是AWS搭建k8s集群的全部步骤,用户接下来可以再自行在aws上搭建hdfs,并在跳板机上部署elastic ctr2.0