小編給大家分享一下在AWS中國區(qū)如何使用kops安裝k8s,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了海西免費建站歡迎大家使用!
我們建議使用一臺低配服務(wù)器作為k8s的管理機,在上面安裝kops等管理工具。
從github上下載已經(jīng)編譯好的二進制文件
wget -O kops https://github.com/kubernetes/kops/releases/download/$(curl -s https://api.github.com/repos/kubernetes/kops/releases/latest | grep tag_name | cut -d '"' -f 4)/kops-linux-amd64 chmod +x ./kops sudo mv ./kops /usr/local/bin/
kubectl是管理和操作Kubernetes集群的CLI工具。
從kubernetes官方kubectl獲取發(fā)布版本:
wget -O kubectl https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl chmod +x ./kubectl sudo mv ./kubectl /usr/local/bin/kubectl
awscli是用Python寫的,安裝Python和pip后直接運行下面命令就可以了。
pip install awscli
在 1.6.2 版本之前,通過 kops 部署 K8s 集群,需要使用 AWS 的 Route53 來提供 DNS 服務(wù)的功能。但從 1.6.2 版本開始,kops 支持部署基于 gossip 的集群,不再依賴 Route53,這讓部署操作變得更加簡單。
配置AWS 賬號,使用該賬號為kops創(chuàng)建專用賬號:
$ aws configure AWS Access Key ID [None]: <your-accesskeyID> AWS Secret Access Key [None]: <your-secretAccessKey> Default region name [None]: cn-north-1 Default output format [None]: json
為了使用 kops 部署集群,還需要為 kops 創(chuàng)建一個 IAM 用戶kops
,并分配相應(yīng)的權(quán)限:
$ aws iam create-group --group-name kops $ aws iam attach-group-policy --policy-arn arn:aws:iam::aws:policy/AmazonEC2FullAccess --group-name kops $ aws iam attach-group-policy --policy-arn arn:aws:iam::aws:policy/AmazonRoute53FullAccess --group-name kops $ aws iam attach-group-policy --policy-arn arn:aws:iam::aws:policy/AmazonS3FullAccess --group-name kops $ aws iam attach-group-policy --policy-arn arn:aws:iam::aws:policy/IAMFullAccess --group-name kops $ aws iam attach-group-policy --policy-arn arn:aws:iam::aws:policy/AmazonVPCFullAccess --group-name kops $ aws iam create-user --user-name kops $ aws iam add-user-to-group --user-name kops --group-name kops
為kops
用戶創(chuàng)建密鑰:
$ aws iam create-access-key --user-name kops
上面的命令會返回kops
用戶的AccessKeyID
和SecretAccessKey
。接著我們就可以更新awscli
的配置,讓它使用新創(chuàng)建的kops
用戶的密鑰:
$ aws configure AWS Access Key ID [None]: <accesskeyID-of-kops-user> AWS Secret Access Key [None]: <secretAccessKey-of-kops-user> Default region name [None]: cn-north-1 Default output format [None]: json
同時還需要將kops
用戶的密鑰導(dǎo)出到命令行的環(huán)境變量:
$ export AWS_ACCESS_KEY_ID=$(aws configure get aws_access_key_id) $ export AWS_SECRET_ACCESS_KEY=$(aws configure get aws_secret_access_key) $ export AWS_REGION=$(aws configure get region)
最后是生成 SSH 密鑰:
$ ssh-keygen
需要注意,為了讓 kops 創(chuàng)建基于 gossip 的集群,集群的命名需要使用.k8s.local
作為后綴,例如,這里我們將集群命名為cluster.k8s.local
:
$ export NAME=cluster.k8s.local
接著創(chuàng)建一個 S3 bucket,用戶存儲集群的數(shù)據(jù),例如,這里我們將這個 bucket 命名為cluster.k8s.local-state.ym
:
$ aws s3api create-bucket --bucket ${NAME}-state-store --create-bucket-configuration LocationConstraint=$AWS_REGION $ export KOPS_STATE_STORE=s3://cluster.k8s.local-state-store
我們必須建立自己的AMI,因為AWS中國地區(qū)沒有官方的kops ami。
下面的命令會創(chuàng)建集群的配置文件,并不會真正地創(chuàng)建集群:
注意:kops-1.8.1不支持中國寧夏區(qū),只支持北京區(qū),
$ kops create cluster \ --name=${NAME} \ --image=ami-089b06f993df09d53 \ --zones=cn-north-1a \ --master-count=1 \ --master-size="t2.micro" \ --node-count=1 \ --node-size="t2.micro" \ --vpc=<your vpc id> \ --subnets=<stringSlice> \ --networking=calico \ --ssh-public-key="~/.ssh/id_rsa.pub"
對于網(wǎng)絡(luò)模型,使用calico,因為在線上都會自己進行網(wǎng)絡(luò)規(guī)劃,當使用k8s默認的kubenet時,k8s會修改AWS路由表,這意味著k8s需要有自己的路由表所有需要有自己的子網(wǎng),如果在生產(chǎn)環(huán)境已經(jīng)做好了網(wǎng)絡(luò)規(guī)劃,使用指定subnet,k8s網(wǎng)絡(luò)將無法正常運行。
在創(chuàng)建集群之前,可以檢查集群的配置文件是否正確:
$ kops edit cluster ${NAME}
在AWS上我們通常使用自己的密鑰連接服務(wù)器
... spec: sshKeyName: <your ssh key name> ...
因為一些網(wǎng)站被墻,因此建議使用代理搭建集群。
... spec: egressProxy: httpProxy: host: http-proxy port: port excludes: amazonaws.com.cn,amazonaws.cn,aliyun.cn,aliyuncs.com ...
還可以指定docker版本
... spec: docker: logDriver: json-file version: 17.03.2-ce ...
如果確認沒問題,就可以使用下面的命令創(chuàng)建集群:
$ kops update cluster ${NAME} --yes
創(chuàng)建集群之后,需要一段時間等待集群的初始化,等待集群起來之后,可以驗證集群的狀況:
$ kops validate cluster
前面已經(jīng)安裝好了kubectl
工具,這里也可以使用kubectl
檢查集群狀況:
$ kubectl get nodes
在銷毀集群之前,需要先確認一下 kops 會刪除哪些資源:
$ kops delete cluster --name ${NAME}
如果確認沒問題,就可以真正刪除集群:
$ kops delete cluster --name ${NAME} --yes
以上是“在AWS中國區(qū)如何使用kops安裝k8s”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)頁名稱:在AWS中國區(qū)如何使用kops安裝k8s
本文鏈接:http://aaarwkj.com/article14/ipdhge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、網(wǎng)站收錄、網(wǎng)站策劃、服務(wù)器托管、手機網(wǎng)站建設(shè)、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)