导读 在实验、演示的时候,或者是生产过程中,我经常会需要运行一些 Docker 负载。虽然这在本地计算机上十分容易,但是当你要在云端运行的时候就有点困难了。相比于本地运行,在云端运行真的太复杂了。我尝试了几个方法,比如在 AWS Beanstalk、AWS ECS 或者 Azure ACS DC/OS 上运行 Docker,但是针对于我的需求来说,这些尝试太复杂了,而且限制诸多。

Azure 宣布 Azure Container Service 预支持 Kubernetes,与此同时,Kubernetes 也宣布支持 ACS,所以是时候尝试一下 Kubernetes 了。

你可以跳过所有步骤,只阅读演示部署和说明,点击链接:https://github.com/chaliy/play-azure-kubernetes。

介绍

那么,什么是 Kubernetes 呢?用一句简单的话来概括:它是一个容器编排工具。第一步,将应用程序进行打包,然后 Kubernetes 可以对打包好的这些应用程序进行部署、运行以及扩展。为了深入了解,可能还需要通过 Tutorial 了解,但是这个十分容易,你完全可以跳过这个步骤直接尝试如何运行它。

所需的基础设施

在本文中,我会使用新的 Azure CLI。安装十分简单,大多数情况下,只需要“pip install azure-cli”就可以了。
所以现在让我们来预览一下我们的集群。首先,你可能需要资源组来隔离你的基础设施。

az group create -n my-very-own-k8s-cluster -l "West Europe"

接下来是规制集群

az acs create -n my-very-own-k8s-cluster \-g my-very-own-k8s-cluster \--dns-prefix my-very-own-k8s-cluster \--orchestrator-type kubernetes

在等待命令完成的时候,我们来看一些评论。

1、如果你的命令出现了一些问题,比如这些命令出现一些无意义的错误,添加-debug 参数有点啰嗦,但是会出现一些错误。

2、-dnsprefix 是可选的,个人建议还是要添加上去,不然的话,就会按照“集群名字+组名字”使用,如果超过 90 个字符的长度,之后在操作过程中就会出现奇怪的错误。

默认设置下,ACS 用单个 master 和 3 个 agents 来设置集群。这些步骤默认设置下都是使用 D2 的,所以这个集群耗费比较高,当你不需要的时候记得清理资源。

以及,欢迎阅读 Kubernetes 的 ACS 引擎之下的内容,链接:https://github.com/Azure/acs-engine/blob/master/docs/kubernetes.md。上述内容给了实施过程中的一些很棒的观点。注意了,ACS 文档没有使用新的 Azure 工具,所以操作起来会有点复杂。

第一个有效负载

所有的基础设施准备完成,现在开始部署 Kubernetes。要管理集群,那么就需要 kubectl。你可以通过以下代码自动运行(可能需要自行添加到 PATH):

az acs kubernetes install-cli

接下来,你需要用集群来认证 kubectl。

az acs kubernetes get-credentials -n my-very-own-k8s-cluster \-g my-very-k8s-cluster

检查所有一切是否 OK。这个命令行会提供客户端和服务器端的版本。

kubectl version

从这里开始,你已经拥有你所需要的东西来运行你的第一个有效负载。所以让我们来创建第一个定义文件,并且尝试运行。Kubernetes 内的定义文件可以使用很多文件格式,我用的是 YAML, 所以我们用以下内容来创建 hello.yml 文件:

apiVersion: extension/v1beta1kind: Deploymentmetadata:name: hello # Name of the deployment, just for reference purposesspec:replica: 1 # Number of instances for the given applicationtemplate:metadata:labels:app: hellospec:containers:- name: ner-uk-ms # Name of container, could be anything you likeimage: chaliy/ner-ms:uk # Docker image to runports:-containerPort:8080

目前,理解一些 Kubernetes 术语十分重要。

Pod——容器实例——http://kubernetes.io/docs/user-guide/pods/Deployment——确保 pods 能够运行,扮演监督的角色——http://kubernetes.io/docs/user-guide/deployments/Service——将 pod 组成一个系统——http://kubernetes.io/docs/user-guide/services/

所以,对于定义在模版中的单个 pod 来说,我们刚刚创建的定义文件是个 deployment。以下命令行会拉取Docker镜像`chaliy/ner-ms:uk`,开启它的实例并且设置监督员:

kubectl create -f ./hello.yml

现在可以使用的命令行很少:

# Retrieve logs associated with deploymentkubectl logs hello# List Podskubectl get pods# List deploymentskubectl get deployments# Details about concrete pod, for example in case of errorskubectl describe pods/podid

如果你想要重新配置应用程序,可以在定义文件中修改,比如设置`replicas:10`,然后运行:

kubectl apply -f ./hello.yml

技术上来说,这已经在运行有效负载了。我们来看看它的运行状况。Kubernetes 的 UI 界面向用户呈现集群运行状况。它的运行方式跟应用程序的运行方式是一样的。当然,如果你不希望这样的 UI 出现在集群外面,那么默认设置下你可以只在集群内运行。但是,如果访问又会如何?

方法很简单,Kubernetes 实现 Basteon 模式,并且通过简单的方法代理到你的本地电脑。所以首先你需要运行代理:

kubectl proxy --port=8000

然后,你需要立刻看到 Kubernetes Dashboard 的话。可以浏览:http://localhost:8000/api/v1/proxy/namespaces/kube-system/services/kubernetes-dashboard
还有就是,你可能需要发布对集群外的服务。对于这个,你需要创建 service(对于 Kubernetes),然后使用 expose 命令,用新的 Loadbalancer。

kubectl expose deployment hello --type="LoadBalancer"--port=80 --target-port=8080

这个命令行会开始设置新的 load balance,需要一点时间。要检查它是否运行,要查询关于 service 的信息:

kubectl get services/hello

之后你就会看到外部 IP 地址,意味着服务已处于 OK 状态,你可以用来发送请求。类似于:

curlhttp://EXTERNAL-IP/

所有的脚本都可以在这个网址找到:https://github.com/chaliy/play-azure-kubernetes。在这里你可以找到使用 Nginx 代理作为路由器的一些真实例子。

结论

对于我来说,用户体验很棒,但是我也不确定我会不会继续使用,因为有几个问题还在困扰着我:

1、Kubernetes ACS 版本还在预发布阶段,有些功能还没有实现(比如,你还不能对你的集群进行缩容扩容)。

2、使用成本较高,至少需要 4D2 个节点,每月最高可能要花费 1000 美元。使用相对小一点的实例也是可以的,但是,我的负载类型还不知道如何利用它。

3、目前还没有可以创建系统的设备。类似于 docker-compose 能够提供相关服务。

本文地址:https://www.linuxprobe.com/?p=142206

在 Azure 上部署 Kubernetes 集群相关推荐

  1. 使用acs-engine在Azure中国区部署kubernetes集群详解

    1. acs-engine简介 ACS是微软在2015年12月推出的一项基于容器的云端PaaS服务.说简单点,acs-engine就是一个ARM模板生成器,用户只需要配置几个简单的参数来描述容器集群的 ...

  2. 使用Kubespray部署Kubernetes集群

    Kubespray是Google开源的一个部署生产级别的Kubernetes服务器集群的开源项目,它整合了Ansible作为部署的工具.项目地址:https://github.com/kubernet ...

  3. Minikube-运行在笔记本上的Kubernetes集群

    前言 Minikube是一个可以在本地电脑上运行Kubernetes的工具.Minikube会在笔记本电脑中的虚拟机上运行一个单节点的Kubernetes集群,让用户能对Kubernetes进行体验或 ...

  4. 如何在CentOS上创建Kubernetes集群

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由编程男孩 发表于云+社区专栏 介绍 Kubernetes(常简称为K8s)是用于自动部署.扩展和管理容器化(containerized ...

  5. 使用Rancher的RKE快速部署Kubernetes集群

    简要说明: 本文共涉及3台Ubuntu机器,1台RKE部署机器(192.168.3.161),2台Kubernetes集群机器(3.162和3.163). 先在Windows机器上,将rke_linu ...

  6. 部署Kubernetes集群(二进制 v1.18.8版)

    第一章 kubernetes 功能介绍 · kubernetes 从入门到实践 · 看云 二进制 部署Kubernetes集群 组件版本 组件 版本 二进制包下载地址 备注 centos 7.8.20 ...

  7. ② kubeadm快速部署Kubernetes集群

    文章目录 1. 安装要求 2. 目标 3. 准备环境 4. 所有节点安装Docker/kubeadm/kubelet 4.1 安装Docker(以一台为例,其他相同) 4.2 添加kubernetes ...

  8. RKE部署Kubernetes集群

    安装docker 在各个节点建立自定义账户,使其可以用命令操作docker useradd <user_name> passwd <user_name> usermod -aG ...

  9. Kubernetes---通过Ansible自动化快速部署Kubernetes集群

    Kubernetes-通过Ansible自动化快速部署Kubernetes集群 目录 Kubernetes-通过Ansible自动化快速部署Kubernetes集群 一.安装ansible 二.环境准 ...

最新文章

  1. pandas使用replace函数将dataframe指定数据列中的特定字符串进行自定义替换(replace substring in dataframe column values)
  2. 二十六、二叉树--查找指定节点
  3. 博客园写代码发家的大牛
  4. mysql od函数_Mysql数学函数不求人
  5. 原阿里中供梁法锋:O2O产品的地推管理 | SHARE 2015产品经理O2O论坛实录
  6. SAP One Order redesign里的WebUI advanced search重构
  7. 红黑树概念及其相关操作的实现
  8. [转]android 获取 imei号码
  9. Leetcode--135. 发糖果
  10. Python 操作 MongoDB
  11. WebDriver Selenium eclipse环境搭建
  12. 肯德尔(Kendall)相关系数概述及Python计算例
  13. Matlab绘制经纬度地图并添加坐标点
  14. 方寸微 T620 存储安全芯片 安全存储 USB3.0 U盘/移动硬盘
  15. 图片高斯模糊效果的实现
  16. 学习使用ffmpeg命令给视频添加一张设计好的背景图片
  17. Win10系统图片打开方式恢复默认照片查看器
  18. R实战 | 森林图绘制
  19. python小作业初版之信用卡交易
  20. Day20.常用类:Date类、LocalTime、Math类、bigDecimal、Arrays、枚举

热门文章

  1. 鸿蒙音波萨顶顶,假唱被揭穿5位明星,筷子兄弟丢人到国外,萨顶顶竟然拿反话筒!...
  2. 上线一月破千万,孙俪都是其粉丝,揭秘花粉儿APP的成长秘诀
  3. 联通宽带开启 IPV6 的方法
  4. 【渝粤教育】国家开放大学2018年春季 8644-21T汽车电子商务 参考试题
  5. 扯淡-20220918
  6. 印度开始追上中国?为何文盲几乎一半,却总能出顶级程序员和高管
  7. 景观生态学原理| 2 景观生态学的理论与核心
  8. ORA-12528: TNS: 监听程序: 所有适用例程都无法建立新连接
  9. 基础算法(三):双指针/位运算/离散化/区间合并
  10. Fanvas将旧网站的swf动画转为canvas,以解决移动端swf动画无法显示问题