15分钟在笔记本上搭建 Kubernetes + Istio开发环境

640?wx_fmt=png

本文作者 | 阿里云资深技术专家易立


11月13~15日,KubeCon 上海大会召开,云原生是这个秋天最火热的技术。很多同学来问如何上手 Kubernetes和Istio 服务网格开发。本文将帮助你利用Docker CE桌面版,15分钟在笔记本上从零搭建 Kubernetes + Istio开发环境,开启云原生之旅。


说明:本文测试通过环境 Docker CE 18.09 (Kubernetes 1.10.3) 以及 Istio 1.0.4


先决条件,你需要一个 Docker for Mac或者Docker for Windows的安装包,如果没有请下载下载 Docker CE最新版本。由于Kubernetes大量的容器镜像在 gcr.io, 无法在国内保证稳定的访问。我们提供了一些工具脚本,帮助从阿里云镜像服务下载所需镜像。


首先,


640?wx_fmt=png


Docker for Mac 开启 Kubernetes


为 Docker daemon 配置 Docker Hub 的中国官方镜像加速 https://registry.docker-cn.com


640?wx_fmt=png


可选操作: 为 Kubernetes 配置 CPU 和 内存资源,建议分配 4GB 或更多内存。


640?wx_fmt=png


预先从阿里云Docker镜像服务下载 Kubernetes 所需要的镜像, 可以通过修改 images.properties 文件加载你自己需要的镜像


640?wx_fmt=png


开启 Kubernetes,并等待 Kubernetes 开始运行


640?wx_fmt=png


Docker for Windows 开启 Kubernetes


为 Docker daemon 配置 Docker Hub 的中国官方镜像加速 https://registry.docker-cn.com


640?wx_fmt=png


可选操作: 为 Kubernetes 配置 CPU 和 内存资源,建议分配 4GB 或更多内存。


640?wx_fmt=png


预先从阿里云Docker镜像服务下载 Kubernetes 所需要的镜像, 可以通过修改 images.properties 文件加载你自己需要的镜像


使用 Bash shell


640?wx_fmt=png


使用 PowerShell


640?wx_fmt=png


说明: 如果因为安全策略无法执行 PowerShell 脚本,请在 “以管理员身份运行” 的 PowerShell 中执行 Set-ExecutionPolicy RemoteSigned 命令。


开启 Kubernetes,并等待 Kubernetes 开始运行


640?wx_fmt=png


配置 Kubernetes


可选操作: 切换Kubernetes运行上下文至 docker-for-desktop


640?wx_fmt=png


验证 Kubernetes 集群状态


640?wx_fmt=png


部署 Kubernetes dashboard


640?wx_fmt=jpeg



640?wx_fmt=png


开启 API Server 访问代理


640?wx_fmt=png


通过如下 URL 访问 Kubernetes dashboard


http://localhost:8001/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy/#!/overview?namespace=default


说明:如果测试 Istio,不需要安装 Ingress,如果需要 Ingress 可以参考 

https://github.com/AliyunContainerService/k8s-for-docker-desktop 中 Ingress相关章节


安装 Helm


可以根据文档安装 helm

  https://github.com/helm/helm/blob/master/docs/install.md


在 Mac OS 上安装


640?wx_fmt=jpeg


在Windows上安装


640?wx_fmt=jpeg


配置 Istio


可以根据文档安装

Istio https://istio.io/docs/setup/kubernetes/


下载 Istio 1.0.4 并安装 CLI


640?wx_fmt=png


在Windows上,您可以手工下载Istio安装包,或者把getLatestIstio.ps1拷贝到你希望下载 Istio 的目录,并执行 - 说明:根据社区提供的安装脚本修改而来


640?wx_fmt=png


通过 Helm chart 安装 Istio


640?wx_fmt=png


查看 istio 发布状态


640?wx_fmt=png


为 default 名空间开启自动 sidecar 注入


640?wx_fmt=png


安装 Book Info 示例


640?wx_fmt=png


确认示例应用在运行中


640?wx_fmt=png


可以通过浏览器访问

http://localhost/productpage


说明:如果当前80端口已经被占用或保留,我们可以编辑

install/kubernetes/helm/istio/values.yaml 文件中


Gateway 端口进行调整,比如将 80 端口替换为 8888 端口


640?wx_fmt=png


然后执行如下命令并生效


640?wx_fmt=png


学习 Istio


大家参照 Istio 开始学习吧, 

https://istio.io/zh/docs/examples/bookinfo/


640?wx_fmt=png


删除实例应用


640?wx_fmt=png


卸载 Istio


640?wx_fmt=png


总结


阿里云Kubernetes服务 (ACK) 已经对 Istio提供了支持,并将Istio和阿里云进行了深度整合,比如可以通过阿里云日志服务支持基于Jaeger的全链路监控,基于云监控提升Istio可观测性和报警能力等。后续也将进一步简化Kubernetes和Istio的开发者体验,让大家方便地把 Kubernetes + Istio 应用无缝迁移上云。


拓展阅读


  • Kubernetes 中文文档

    https://kubernetes.io/zh/

  • Istio 中文文档

    https://istio.io/zh/

  • Istio官方文档 -  阿里云Kubernetes服务 (ACK)支持

    https://istio.io/docs/setup/kubernetes/quick-start-alicloud-ack/

  • 阿里云 Kubernetes服务上的Istio实践

  • https://help.aliyun.com/document_detail/90563.html

  • 阿里云容器服务团队博客 Istio 实践系列文章 - 持续更新中

    https://yq.aliyun.com/teams/11/type_blog-cid_349-page_1

  • ServiceMesher社区

    http://www.servicemesher.com/



640?wx_fmt=jpeg

2019年开发者必读!20位阿里技术大牛们帮你列了一份经典书单!


640?wx_fmt=jpeg

老代码多=过度耦合=if else?阿里巴巴工程师这样捋直老代码


640?wx_fmt=jpeg

即将开源! 2亿用户背后的Flutter应用框架Fish Redux

640?wx_fmt=png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值