Google Cloud 在 Next 19 大会上发布了 Anthos,这项服务可以在云端实现对 Kubernetes集群的管理,可用于企业的私有部署,或者其他的公有云比如 AWS 和 Azure 上。使用 Anthos ,能够通过这一个端口实现所有的 Kubernetes 集群的管理。
这篇文章将会介绍如何实现这些功能。
1 启用服务
在使用该功能之前,需要确保启用了 Google Cloud 的相关功能。下面这些 Gcloud 的命令可以开启这些服务。
gcloud services enable
–project=[project-name]
cloudresourcemanager.googleapis.com
container.googleapis.com
gkeconnect.googleapis.com
gkehub.googleapis.com
serviceusage.googleapis.com
2 创建服务账户和 IAM 授权
2.1 创建服务账号
Using Gcloud command to create a service account:
使用如下 Gcloud 命令创建账户:
gcloud iam service-accounts create anthos-connect
2.2 IAM 授权
Using the following command to do IAM authorization:
使用如下命令行完成 IAM 授权:
gcloud projects add-iam-policy-binding
hengwei-project01
–member=“serviceAccount:anthos-connect@hengwei-project01.iam.gserviceaccount.com”
–role=“roles/gkehub.admin”
gcloud projects add-iam-policy-binding
hengwei-project01
–member=“serviceAccount:anthos-connect@hengwei-project01.iam.gserviceaccount.com”
–role=“roles/serviceusage.serviceUsageViewer”
gcloud projects add-iam-policy-binding
hengwei-project01
–member=“serviceAccount:anthos-connect@hengwei-project01.iam.gserviceaccount.com”
–role="roles/gkehub.connect
2.3 创建服务账户秘钥
Using following command to create the Service Account key:
使用以下命令创建秘钥:
gcloud iam service-accounts keys create sa-key.json
–iam-account=anthos-connect@hengwei-project01.iam.gserviceaccount.com
–key-file-type=json
3. 在微软 Azure 上创建 AKS 服务
3.1 创建 AKS cluster
On Azure Portal, chose All Services -> Compute -> Kubernetes:
在 Azure 网页上,选择 All Services -> Compute -> Kubernetes:
data:image/s3,"s3://crabby-images/7ea82/7ea82fe4d27adc517d84e28f2c2ee116ee5c7b03" alt=""
Click add to create a new AKS cluster:
点击添加 (add )以创建一个新的 AKS cluster:
data:image/s3,"s3://crabby-images/aa9a3/aa9a3bbab053f3656521c8303299569869d59794" alt=""
然后点击 Review+create完成 AKS cluster 的创建。
data:image/s3,"s3://crabby-images/1bc6e/1bc6e1d47c8d94bedb43ae2f4b287d0baa679639" alt=""
3.2 使用 Kubectl 连接到 AKS cluster
3.2.1 打开 Cloud Shell
data:image/s3,"s3://crabby-images/24ff5/24ff5b650837eaaf2bd72c72aa8d874ab3d1da58" alt=""
3.2.2 配置 kubectl
使用 bash 命令配置 kubectl:
data:image/s3,"s3://crabby-images/196f9/196f9cb9534240c04a277b293b12257b24cf505e" alt=""
之后,可以使用 kubectl 命令得到 cluster 的具体信息:
data:image/s3,"s3://crabby-images/6c5e4/6c5e40df9022ac4e2a68ebe96b1a62d2c8f3bbfc" alt=""
4.将 kubernetes cluster 注册到 Anthos
项目中添加完白名单后,在 Kubernetes Engine 页面上,有一个新增的按钮:REGISTER CLUSTER.
data:image/s3,"s3://crabby-images/97aca/97acac67eafc3d73738bcb401ab25204f7f845bb" alt=""
点击这个按钮,完成 Azure 上的 AKS cluster 注册。
4.1 配置
在配置页面,输入集群的名字为 aks , 并将服务帐户的密钥以 Json 格式粘贴到服务帐户密钥字段中:
data:image/s3,"s3://crabby-images/3edae/3edaeeb8ded25dfffee82ba2b610759f1a07b143" alt=""
点击 CONTINUE 继续
4.2 连接
data:image/s3,"s3://crabby-images/0fb51/0fb51506498f914fff4a4bb7a182e92a88b21a8c" alt=""
将 GKE 连接 MINIFEST 下载到本地,粘贴到 Azure 云的 shell, 并将此 yaml 文件部署到 AKS 集群以创建名称空间,集群角色绑定,以及配置映射和部署。
kubectl 命令是:
kubectl apply -f aks-gkeconnect-config.yaml
data:image/s3,"s3://crabby-images/fcafd/fcafddcc597e65efcece5e1fe3b835825bb5ed9e" alt=""
可以找到为 GKE 连接的两个端口:
data:image/s3,"s3://crabby-images/5fe2e/5fe2ebf0e6134a6c25723949b16c1b91bdf80f8a" alt=""
回到 Google Cloud 控制界面,可以发现集群已经实现了连接:
data:image/s3,"s3://crabby-images/9ab32/9ab32dff5bc4968649456e5b0710e76578ccd111" alt=""
4.3 标记
标记位置和提供者:
data:image/s3,"s3://crabby-images/0285f/0285f1a8ad902138c0f16f4173a2ca80e99ce78f" alt=""
点击完 REGISTER 按钮,cluster 就被编入到了 Anthos:
data:image/s3,"s3://crabby-images/96f70/96f704c1ab4dd9b568eb5aac3d643150812fe0c9" alt=""
5 登录到 AKS
5.1 在 AKS 集群 中创建服务账户
为了获得 AKS 的特权,我们需要用以下命令,创建 AKS 服务帐户来实现:
kubectl create serviceaccount my-ksa
kubectl create clusterrolebinding my-view-binding
–clusterrole view --serviceaccount default:my-ksa
kubectl create clusterrolebinding my-node-reader-binding
–clusterrole node-reader --serviceaccount default:my-ksa
kubectl create clusterrolebinding my-cluster-admin-binding
–clusterrole cluster-admin --serviceaccount default:my-ksa
SECRET_NAME=(kubectl get serviceaccount my-ksa -o jsonpath=’{.secrets[0].name}’)
kubectl get secret {SECRET_NAME} -o jsonpath=’{.data.token}’ | base64 -d
使用以下命令得到令牌:
data:image/s3,"s3://crabby-images/2196b/2196bef5f83c9a2f609d49ec9735dcb17c624a76" alt=""
复制得到的令牌。
5.2 输入令牌登录 AKS 集群
在 Google Cloud 上,点击登录(login):
data:image/s3,"s3://crabby-images/5363a/5363a1c60385f7ba49dd1054edc3a21ba2642f1c" alt=""
使用 Token 模式,并粘贴上一步得到的令牌:
之后,就可以看到 AKS 集群在线。
data:image/s3,"s3://crabby-images/3af33/3af33981db6fe2eca311321a2962f3d6f09f3bff" alt=""
6.测试
6.1创建部署
我们可以查看 AKS 集群的详细信息:
data:image/s3,"s3://crabby-images/b1e5f/b1e5f9587439e5187c175e7d51c4b7a12b60abb2" alt=""
data:image/s3,"s3://crabby-images/dc1cc/dc1cc74ca9de442cb72328ed8abd7a17d4ba088e" alt=""
data:image/s3,"s3://crabby-images/87476/8747689c370de3273ebe5e0e7f8216a7dbe58a0f" alt=""
创建一个部署:
data:image/s3,"s3://crabby-images/4c7ac/4c7ac23744755630d19e7c1a5da2ee1785861c09" alt=""
data:image/s3,"s3://crabby-images/89935/89935dc30fbe0bf1fbb9d51b3b46c901a6026fb0" alt=""
然后,我们可以看到相关的信息:
data:image/s3,"s3://crabby-images/53635/53635480768c12c457eb390f79b03e50c9c9ef0f" alt=""
通过 AKS,我们也可以得到一些相关的信息:
data:image/s3,"s3://crabby-images/5789f/5789fbb8d918a7515cca63869c74df5048d1e538" alt=""
也可以通过 kubectl CLI 命令来实现:
data:image/s3,"s3://crabby-images/014d3/014d3537235b7bf77af7493e1e4fd82438b3ad8f" alt=""
6.2 公开部署
使用 GKE 接口公开 nginx 部署,并利用 LoadBalancer 创建一项服务:
data:image/s3,"s3://crabby-images/8482e/8482edc21a0c7c3b27df3f26c53315ac4ee3faf1" alt=""
data:image/s3,"s3://crabby-images/5654d/5654d95375d9d78c407a2a4e4c1358962a809464" alt=""
将会看到 AKS 使用 Azure Server 负载均衡器创建服务:
data:image/s3,"s3://crabby-images/b69d1/b69d1723dff64c3be90d01b73ff81f3ebc424969" alt=""
Using the SLB IP address:
data:image/s3,"s3://crabby-images/02926/02926d32dd59b3f20e3fc2bc4d321db4e00b0bb2" alt=""
这样就可以访问 Nginx 的欢迎界面了:
data:image/s3,"s3://crabby-images/5e933/5e9334f07e782d976ddd095c7097a3b655ad59be" alt=""
7 总结
Anthos 是 Kubernetes 的混合产品。使用它可以集中管理 Kubernetes 集群 ,包括本地和公共云上的 Kubernetes 服务。
文章版权归作者所有,未经许可不得转载。
文章信息
相关推荐
data:image/s3,"s3://crabby-images/25a23/25a238475b6aa2449beeb9a8d5d3f6af3414c03e" alt=""