使用Kubectl部署web服务到K8s集群

本文涉及的产品
函数计算FC,每月15万CU 3个月
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
简介: 本场景带您体验如何使用k8s的原生命令kubectl部署一个web应用(魔方应用)的镜像到k8s集群中,并通过Ingress将部署的服务暴露出来由外部访问。

使用Kubectl部署web服务到K8s集群

1.  创建资源

开始实验之前,您需要先创建云服务器ECS和ACK集群资源。

  1. 在实验室页面,单击创建资源
  2. (可选)在实验室页面左侧导航栏中,单击云产品资源列表,可查看本次实验资源相关信息(例如IP地址、用户信息等)。

说明:资源创建过程需要15~20分钟。

2.  部署业务应用

  1. 执行如下命令,创建名为app-ns的命名空间。

说明:通常创建应用需要确定部署在k8s的哪个namespace中,一般不建议部署在default namespace下,索引我们创建名为app-ns的命名空间。

kubectl create ns app-ns
  1. 执行如下命令,创建deploy.yaml文件

说明:现在我们需要将业务应用部署到k8s集群中,这里我们已经准备好了一个应用并打包成镜像,镜像地址如下:

仓库地址:registry.cn-hangzhou.aliyuncs.com/acr-toolkit/ack-cube。

版本: 1.0。

这是一个示例性质的魔方游戏应用。这个应用会监听80端口,接受根路径的访问,返回一个简单的魔方游戏界面。要让这个web应用的镜像在k8s中运行,我们首先要定义一个 deployment资源然后,通过创建deploy.yaml来描述deployment资源。

vim deploy.yaml
  1. i键进入编辑模式,将如下代码复制到文件中,然后按ECS退出编辑模式,输入:wq后按下Enter键保存并退出。

参数说明:

  • image:就是这个web应用的镜像地址。
  • replicas:代表这个应用只部署一份。
apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp-deployment
  namespace: app-ns
  labels:
    app: myapp
spec:
  replicas: 1
  selector:
    matchLabels:
      name: myapp
  template:
    metadata:
      labels:
        name: myapp
      namespace: app-ns
    spec:
      containers:
        - name: ack-kube
          image: registry.cn-hangzhou.aliyuncs.com/acr-toolkit/ack-cube:1.0
          ports:
            - containerPort: 80
          resources:
            requests:
              cpu: 0.25
              memory: 512Mi
            limits:
              cpu: 1
              memory: 1024Mi
  1. 执行如下命令,运行deploy.yaml文件,部署应用。
kubectl apply -f ~/deploy.yaml
  1. 执行如下命令,查看部署的POD。
kubectl get pod -n app-ns

返回结果如下,当您看到status字段为Running时,代表应用部署完成,处于运行中的状态。如果您看到的是ContainerCreating,代表服务容器正在创建中,需要您耐心等待应用创建完成。

至此,我们已经完成了应用本身的部署,下面我们看下如何在k8s里配置服务。

3.  部署服务

由于deployment是一个弹性组件,其管理的应用实例不是固定的,而是可以任意伸缩。这带来了很多的好处,例如可以支持弹性伸缩、滚动更新等等。但是相反的,这也会导致应用实例IP不固定,从访问者的角度我们不可能每次去查找当前的应用实例。所以,为了能提供稳定的访问入口,我们还需要部署服务来接收请求,并屏蔽内部的弹性机制。

本步骤将指导您如何部署服务。

  1. 执行如下命令,创建service.yaml文件。
vim service.yaml
  1. i键进入编辑模式,将如下代码复制到文件中,然后按ECS退出编辑模式,输入:wq后按下Enter键保存并退出。

参数说明:

  • selector:这是一个选择器,通过name=myapp这个条件来选择需要代理的Pod。
  • ports:这里定义了服务自身暴露的端口和需要访问的应用的端口。
apiVersion: v1
kind: Service
metadata:
  name: myapp-service
  namespace: app-ns
spec:
  ports:
    - port: 80
      targetPort: 80
      protocol: TCP
  type: ClusterIP
  selector:
    name: myapp
  1. 执行如下命令,运行service.yaml文件,部署服务service。
kubectl apply -f ~/service.yaml
  1. 执行如下命令,查看部署的服务service。
kubectl get service -n app-ns

返回结果如下,您可查看到服务service的相关信息。

这里我们就完成了服务的部署。下面我们通过ingress将内部的服务暴露出去。

4.  配置ingress开放外部访问

k8s是一个集群,deployment、service都是集群内部的资源,他们通过一个内部虚拟网络互相访问。但是对于外部的用户,这些所有的资源都是不可见的,所以我们还需要配置一个外部访问的入口到service的映射规则,从而将内部服务暴露出去。

本步骤将指导您如何使用ingress的来实现服务对外暴露的需求。

  1. 执行如下命令,创建ingress.yaml文件。
vim ingress.yaml
  1. i键进入编辑模式,将如下代码复制到文件中,定义ingress规则,然后按ECS退出编辑模式,输入:wq后按下Enter键保存并退出。
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: example-ingress
  namespace: app-ns
spec:
  ingressClassName: nginx #default ingress class. optional
  rules:
  - http:
      paths:
      - backend:
          service:
            name: myapp-service
            port:
              number: 80
        path: /
        pathType: Prefix
  1. 执行如下命令,运行ingress.yaml文件,部署ingress。
kubectl apply -f ~/ingress.yaml
  1. 执行如下命令,查看部署的ingress。
kubectl get ingress -n app-ns

返回结果如下,您可查看到访问地址的IP,以及端口是80。如果您的返回结果中ADDRESS为空,表示ingress正在部署,请您稍等片刻,再次执行上述命令。

  1. 在您的本机浏览器中,打开新页签,在地址栏中访问http://ADDRESS:80

说明:您需要将ADDRESS改为上一步骤的命令返回结果中的ADDRESS。

返回如下页面,您即可开始使用部署的魔方应用。

现在,您已经完成了除了卸载相关资源外的所有步骤,下面我们将开始卸载相关资源。

5.  卸载资源

进行配置并提供服务只完成了一半的工作,完整的操作周期除了正向的安装,还包含了逆向的卸载。

本步骤将指导您如何把配置的各种资源给卸载掉。

说明:资源卸载我们就不使用yaml脚本了,直接使用kubectl命令就可以完成。

  1. 执行如下命令,卸载ingress。
kubectl delete ingress example-ingress -n app-ns
  1. 执行如下命令,卸载service。
kubectl delete service myapp-service -n app-ns
  1. 执行如下命令,卸载deployment。
kubectl delete deployment myapp-deployment -n app-ns
  1. 至此我们就完成了卸载工作,现在我们需要确认卸载结果。依次执行如下命令,确认卸载结果。
kubectl get deployment -n app-ns
kubectl get service -n app-ns
kubectl get ingress -n app-ns

返回结果如下,表示卸载工作已完成。如果您的返回结果和如下截图不一样,并且您的返回结果中STATUS字段为Terminating,表示pod正在卸载中,请您稍等片刻,再次执行上述命令,确认卸载结果。

实验链接:https://developer.aliyun.com/adc/scenario/96ca10d683f04001a217708b234a4dc2

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1月前
|
开发框架 监控 安全
Windows Defender 导致 Web IIS 服务异常停止排查
某日凌晨IIS服务异常停止,经查为Windows Defender安全补丁KB2267602触发引擎更新,导致系统资源波动,进而引发应用池回收。确认非人为操作,系统无重启。通过分析日志与监控,定位原因为Defender更新后扫描加重负载。解决方案:将IIS及.NET相关路径添加至Defender排除列表,避免业务影响。
323 116
|
1月前
|
人工智能 算法 调度
阿里云ACK托管集群Pro版共享GPU调度操作指南
本文介绍在阿里云ACK托管集群Pro版中,如何通过共享GPU调度实现显存与算力的精细化分配,涵盖前提条件、使用限制、节点池配置及任务部署全流程,提升GPU资源利用率,适用于AI训练与推理场景。
233 2
|
1月前
|
弹性计算 监控 调度
ACK One 注册集群云端节点池升级:IDC 集群一键接入云端 GPU 算力,接入效率提升 80%
ACK One注册集群节点池实现“一键接入”,免去手动编写脚本与GPU驱动安装,支持自动扩缩容与多场景调度,大幅提升K8s集群管理效率。
225 89
|
6月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
本文介绍如何利用阿里云的分布式云容器平台ACK One的多集群应用分发功能,结合云效CD能力,快速将单集群CD系统升级为多集群CD系统。通过增加分发策略(PropagationPolicy)和差异化策略(OverridePolicy),并修改单集群kubeconfig为舰队kubeconfig,可实现无损改造。该方案具备多地域多集群智能资源调度、重调度及故障迁移等能力,帮助用户提升业务效率与可靠性。
|
5月前
|
开发框架 安全 前端开发
Go Web开发框架实践:模板渲染与静态资源服务
Gin 是一个功能强大的 Go Web 框架,不仅适用于构建 API 服务,还支持 HTML 模板渲染和静态资源托管。它可以帮助开发者快速搭建中小型网站,并提供灵活的模板语法、自定义函数、静态文件映射等功能,同时兼容 Go 的 html/template 引擎,具备高效且安全的页面渲染能力。
|
5月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:使用 Gin 快速构建 Web 服务
Gin 是一个高效、轻量级的 Go 语言 Web 框架,支持中间件机制,非常适合开发 RESTful API。本文从安装到进阶技巧全面解析 Gin 的使用:快速入门示例(Hello Gin)、定义 RESTful 用户服务(增删改查接口实现),以及推荐实践如参数校验、中间件和路由分组等。通过对比标准库 `net/http`,Gin 提供更简洁灵活的开发体验。此外,还推荐了 GORM、Viper、Zap 等配合使用的工具库,助力高效开发。
|
Kubernetes 容器 Perl
Kubernetes-kubectl命令出现错误【The connection to the server localhost:8080 was refused - did you specif...
  今天在Kubernetes的从节点上运行命令【kubectl】出现了如下错误 [root@k8snode1 kubernetes]# kubectl get pod The connection to the server localhost:80...
38817 0
|
Kubernetes Shell API
kubernetes-kubectl命令说明
本文基于kubernetes 1.5.2版本编写 kubectl kubectl controls the K8S cluster manager. Find more information at https://github.
1327 0
|
6月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
ACK One 的多集群应用分发,可以最小成本地结合您已有的单集群 CD 系统,无需对原先应用资源 YAML 进行修改,即可快速构建成多集群的 CD 系统,并同时获得强大的多集群资源调度和分发的能力。
273 9
|
8月前
|
存储 Kubernetes 监控
K8s集群实战:使用kubeadm和kuboard部署Kubernetes集群
总之,使用kubeadm和kuboard部署K8s集群就像回归童年一样,简单又有趣。不要忘记,技术是为人服务的,用K8s集群操控云端资源,我们不过是想在复杂的世界找寻简单。尽管部署过程可能遇到困难,但朝着简化复杂的目标,我们就能找到意义和乐趣。希望你也能利用这些工具,找到你的乐趣,满足你的需求。
829 33

推荐镜像

更多