本篇已加入《.NET Core on K8S学习实践系列文章索引》,可以点击查看更多容器化技术相关系列文章。

当近期的一个App上线后,发现目前的docker实例(应用服务BFF+中台服务+工具服务)已经很多了,而我司目前没有专业的运维人员,发现运维的成本逐渐开始上来,所以容器编排也就需要提上议程。因此我决定开始学习Kubernetes,会将学习当中的过程记录下来,预计会形成一个系列,暂且命名为:ASP.NET Core on K8S,而这个系列会由3个部分组成,且会在不同的时期写完:

  • ASP.NET Core on K8S学习初探:在Docker for Windows中搭建单节点环境,初步了解有个感性认识
  • ASP.NET Core on K8S深入学习:在Linux上搭建K8S集群,对K8S的一些核心概念有个深入的认识
  • ASP.NET Core on ACK/TKE实战:借助阿里云/腾讯云容器服务进行生产环境的容器部署和运维的一些实战总结

下面是这个学习初探部分的三篇文章索引:

Section 1 - ASP.NET Core on K8S学习初探(1)K8S单节点环境搭建

Section 2 - ASP.NET Core on K8S学习初探(2)K8S基本概念快速一览

Section 3 - ASP.NET Core on K8S学习初探(3)部署API到K8S

一、关于K8S

  关于K8S,建议阅读《10分钟看懂Docker和K8S》,这几乎是一篇不用耗费多少脑细胞的文章,因为讲的实在是太通俗易懂了。

  总体来说,就是在Docker容器技术被炒得热火朝天之时,大家发现,如果想要将Docker应用于具体的业务实现,是存在困难的——编排、管理和调度等各个方面,都不容易。于是,人们迫切需要一套管理系统,对Docker及容器进行更高级更灵活的管理。

  于是,源自于Google的K8S出现了。K8S就是基于容器的集群管理平台,它的全称,是Kubernetes。

Kubernetes 这个单词来自于希腊语,含义是舵手或领航员。K8S是它的缩写,用“8”字替代了“ubernete”这8个字符。

  这里不再过多解释,因为上面的文章里已经讲的很清楚了,理清那些繁多的K8S概念留到后面再来,这里主要是先玩起来,玩了再说。K8S的环境搭建在Windows和Linux下,还可以基于云服务提供商封装好的K8S服务进行快速构建,这里为了快速玩玩,选择了在Windows下基于Docker for Windows来进行。

二、安装核心步骤

2.1 前置条件

  确保当前Windows环境有以下几个关键点:

  • Windows 10 PRO专业版及以上
  • Hyper-V 虚拟机
  • Docker for Windows,这里演示的是Docker CE 18.06版本

  为Docker for Windows的daemon配置镜像加速:

  

2.2 下载K8S镜像

  首先,从Git上下载K8S所需的docker镜像:

git clone https://github.com/AliyunContainerService/k8s-for-docker-desktop
cd k8s-for-docker-desktop

  这里,为了匹配18.06版本(Docker CE版本号或者你的Docker for Windows的版本号),切换到该项目的18.09分支。

git checkout 18.09

  Note:关于哪个版本切换到哪个分支,请参阅这里

  然后,开始加载镜像,这里通过PowerShell的方式加载:

 .\load_images.ps1

  

  当然,也可以通过Bash Shell的方式加载:

./load_images.sh

  最后,在Docker for Windows中启用K8S:

  

2.3 快速配置K8S

  (可选)切换运行上下文至docker-for-desktop

kubectl config use-context docker-for-desktop

  核心:验证Kubernetes集群状态

kubectl cluster-info
kubectl get nodes

  

  Note:执行了kubectl cluster-info之后就可以看到已经启动了一个master节点,也就是single-node模式启用了。

  面板:部署Kubernetes Dashboard

kubectl create -f kubernetes-dashboard.yaml

  访问:开启API Server访问代理,向外部提供面板访问

kubectl proxy

  

  然后就可以通过下面这个URL访问Kubernetes的Dashboard:http://localhost:8001/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy/#!/overview?namespace=default

  但是,你会发现出现的如下这个页面,你可以选择跳过 也可以选择一个kubeconfig。

  

  其中,kubeconfig的位置(这里是Windows系统)位于:%UserProfile%\.kube\config。当然,这里也可以选择跳过,不用管这个config。如果,碰到提示“not enough data to create auth”,需要执行以下命令来设置一下kubeconfig:

$TOKEN=((kubectl -n kube-system describe secret default | Select-String "token:") -split " +")[]
kubectl config set-credentials docker-for-desktop --token="${TOKEN}"

  最后,可以正常登录后看到Dashboard的全貌了:

  

  Note:如果想通过其它主机访问并且让API Server能够接受所有主机的请求,请通过以下命令启动API Server。

kubectl proxy --address='0.0.0.0'  --accept-hosts='^*$'

三、小结

  本篇简单地记录一下如何在Windows环境下基于Docker for Windows来搭建一个单节点的K8S环境,下一篇会将ASP.NET Core以Docker方式加入到K8S集群中托管,操作K8S来管理Docker实例来有一个感性认识。

参考资料

作者:周旭龙

出处:http://edisonchou.cnblogs.com

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。

ASP.NET Core on K8S学习初探(1)K8S单节点环境搭建的更多相关文章

  1. ASP.NET Core on K8S学习初探(3)部署API到K8S

    在上一篇<基本概念快速一览>中,我们把基本的一些概念快速地简单地不求甚解地过了一下,本篇开始我们会将ASP.NET Core WebAPI部署到K8S,从而结束初探的旅程. Section ...

  2. ASP.NET Core on K8S学习初探(2)K8S基本概念快速一览

    在上一篇<单节点环境搭建>中,通过Docker for Windows在Windows开发机中搭建了一个单节点的K8S环境,接下来就是动人心弦的部署ASP.NET Core API到K8S ...

  3. ASP.NET Core 借助 Helm 部署应用至K8S

    前言 玩K8S也有一段时间了,借助云服务提供商的K8S控制台,已经可以很方便的快速部署应用至K8S.通过简单的点击,可以一次性帮忙创建K8S 对象:Deployment.Service.Ingress ...

  4. ASP.NET Core Web开发学习笔记-1介绍篇

    ASP.NET Core Web开发学习笔记-1介绍篇 给大家说声报歉,从2012年个人情感破裂的那一天,本人的51CTO,CnBlogs,Csdn,QQ,Weboo就再也没有更新过.踏实的生活(曾辞 ...

  5. 一起学ASP.NET Core 2.0学习笔记(二): ef core2.0 及mysql provider 、Fluent API相关配置及迁移

    不得不说微软的技术迭代还是很快的,上了微软的船就得跟着她走下去,前文一起学ASP.NET Core 2.0学习笔记(一): CentOS下 .net core2 sdk nginx.superviso ...

  6. ASP.NET Core快速入门--学习笔记系列文章索引目录

    课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 抓住国庆假期的尾巴完成了此系列课程的学习笔记输出! ASP.NET Core快 ...

  7. ASP.NET Core MVC 网站学习笔记

    ASP.NET Core MVC 网站学习笔记 魏刘宏 2020 年 2 月 17 日 最近因为” 新冠” 疫情在家办公,学习了 ASP.NET Core MVC 网站的一些知识,记录如下. 一.新建 ...

  8. Asp.Net Core 程序部署到Linux(centos)生产环境(二):docker部署

    运行环境 照例,先亮环境:软件的话我这里假设你已经批准好了.net core 运行环境,未配置可以看我的这篇[linux(centos)搭建.net core 运行环境] 腾讯云 centos:7.2 ...

  9. Asp.Net Core 程序部署到Linux(centos)生产环境(一):普通部署

    运行环境 照例,先亮底 centos:7.2 cpu:1核 2G内存 1M带宽 辅助工具:xshell xftp 搭建.net core运行环境 .net core 的运行环境我单独写了一篇,请看我的 ...

随机推荐

  1. AtCoder Grand Contest 012 A

    A - AtCoder Group Contest Time limit : 2sec / Memory limit : 256MB Score : 300 points Problem Statem ...

  2. April Fools Contest 2017 C

    Description DO YOU EXPECT ME TO FIND THIS OUT? WHAT BASE AND/XOR LANGUAGE INCLUDES string? DON'T BYT ...

  3. 人品问题 树形dp

    题目 网上出现了一种高科技产品——人品测试器.只要你把你的真实姓名输入进去,系统将自动输出你的人品指数.把儿不相信自己的人品为0.经过了许多研究后,把儿得出了一个更为科学的人品计算方法.这种方法的理论 ...

  4. 条形码问题 dp+求某个序列在某种排列中的序号的方法

    题目 条形码是一种由亮条(Light Bar)和暗条(Dark Bar)交替出现且以暗条为起头的符号,每条都占有若干个单位宽.图33-1给出了一个含有4个条的条形码,它延续了1+2+3+1=7单位的宽 ...

  5. linux系统文件目录解析

    /bin 二进制可执行命令  /dev 设备文件(硬盘/光驱等)  /etc 系统管理和配置文件  /etc/rc.d 启动的配置文件和脚本  /home 用户主目录,下面会有以登录用户名作为文件夹名 ...

  6. Hash环/一致性Hash原理

    当前,Memcached.Redis这类分布式kv缓存已经非常普遍.从本篇开始,本系列将分析分布式缓存相关的原理.使用策略和最佳实践. 我们知道Memcached的分布式其实是一种“伪分布式”,也就是 ...

  7. String的用法——构造方法

    package cn.itcast_01; /* 字符串:就是多个字符组成的一串数据,也可以看成一个字符数组 *通过API,我们得知: A: 字符串字面值,如abc,也可以看做一个对象 B:字符串是常 ...

  8. AJPFX关于hashmap和hashtable 的区别

    Hashtable和HashMap类有三个重要的不同之处.第一个不同主要是历史原因.Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现. ...

  9. 个人作业(alpha)

    这个作业属于哪个课程  https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass1/ 这个作业要求在哪里  https://edu.cn ...

  10. 微信小程序组件解读和分析:一、view(视图容器 )

    view组件说明:    视图容器    跟HTML代码中的DIV一样,可以包裹其他的组件,也可以被包裹在其他的组件内部.用起来比较自由随意,没有固定的结构. view组件的用法: 示例项目的wxml ...