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

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

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


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, 无法在国内保证稳定的访问。我们提供了一些工具脚本,帮助从阿里云镜像服务下载所需镜像。


首先,


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


Docker for Mac 开启 Kubernetes


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


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


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


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


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


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


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


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


Docker for Windows 开启 Kubernetes


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


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


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


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


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


使用 Bash shell


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


使用 PowerShell


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


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


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


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


配置 Kubernetes


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


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


验证 Kubernetes 集群状态


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


部署 Kubernetes dashboard


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



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


开启 API Server 访问代理


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


通过如下 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 上安装


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


在Windows上安装


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


配置 Istio


可以根据文档安装

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


下载 Istio 1.0.4 并安装 CLI


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


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


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


通过 Helm chart 安装 Istio


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


查看 istio 发布状态


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


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


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


安装 Book Info 示例


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


确认示例应用在运行中


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


可以通过浏览器访问

http://localhost/productpage


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

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


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


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


然后执行如下命令并生效


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


学习 Istio


大家参照 Istio 开始学习吧, 

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


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


删除实例应用


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


卸载 Istio


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


总结


阿里云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/



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

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


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

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


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

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

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