ASP.NET Core on K8S学习初探(1)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实战:借助阿里云/腾讯云容器服务进行生产环境的容器部署和运维的一些实战总结
一、关于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%.kubeconfig。当然,这里也可以选择跳过,不用管这个config。如果,碰到提示“not enough data to create auth”,需要执行以下命令来设置一下kubeconfig:
$TOKEN=((kubectl -n kube-system describe secret default | Select-String "token:") -split " +")[1] 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实例来有一个感性认识。
参考资料
- Jesse,http://video.jessetalk.cn/my/course/6
- 阿里云,https://github.com/AliyunContainerService/k8s-for-docker-desktop/tree/18.09
- 阿里云,https://yq.aliyun.com/articles/508460?spm=a2c4e.11153940.blogcont221687.18.7dd57733hFolMo
- 圣杰,https://www.cnblogs.com/sheng-jie/p/10591794.html
- 忱康,https://blog.csdn.net/cuipengchong/article/details/72459299
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
AutoScaling 成本优化模式升级--混合实例策略
伸缩组成本优化模式以成本为目标,始终创建最低价的实例,同时,通过多可用区,多实例规格分布,以此来提高服务稳定性。但是,对于成本优势最大化的竞价实例,伸缩组难以防范竞价实例大范围回收可能导致的服务雪崩,本次升级允许用户制定更详细的成本控制策略,在成本和稳定性之间进行调整和权衡。 成本优化模式简介 当您的伸缩配置选择了多实例规格,并想以最低的价格来使用同等规模的 ECS 实例配置时,您可以选择使用 成本优化策略 的伸缩组,来降低您的 ECS 实例使用成本;当您的伸缩配置选择的实例为抢占式实例时,您可能会遇到由于价格、库存等原因导致抢占式实例创建失败场景,从而导致扩容不及时,影响到业务,您也可以选择使用 成本优化策略 的伸缩组,在抢占式实例创建失败的时候自动为您尝试创建同规格的按量实例,来保证业务的稳定性。 从上述的描述,我们可以清晰的看到,
- 下一篇
负载均衡SLB有哪些应用场景及配置步骤?
我们一起来快速认识一下,负载均衡——SLB。负载均衡SLB是将访问流量根据转发策略分发到后端多台云服务器(ECS实例)的流量分发控制服务。包含两种含义:一是通过流量分发,扩展应用系统的服务能力;二是消除单点故障,提高应用系统的可用性。 应用场景 我们具体来看一看它的使用场景。 第一个使用场景的是用于高访问量的业务。当你的应用访问量非常大,单台的服务器已经无法承载这个访问量的时候,就可以使用负载均衡,将流量分发到不同的服务器上去。 第二个场景是横向扩张系统。当你已经使用了负载均衡,在业务有波动时可以在后端非常方便的添加和减少ECS来调整自己应用的服务能力。 第三个应用场景是消除单点故障。当我们在使用负载均衡时,后端有多台ECS在同时工作的。一旦其中一台ECS上的应用发生了故障,那么负载均衡会通过一个健康检查的机制来及时的发现这个故障,并且能屏蔽对这台ECS的流量转发,然后将用户的请求转发到另一台正常工作的ECS实例上。 同城的容灾阿里云负载均衡可以实现同地域多可用区之间同地域容灾,当主可用区出现故障是,可以在短时间内切换到另一备用可用区,以恢复服务能力。同时,主可用区恢复访问时,它会自动...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS关闭SELinux安全模块
- CentOS8编译安装MySQL8.0.19
- CentOS7,CentOS8安装Elasticsearch6.8.6
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装