安装Kubernetes、Docker

Kubernetes、Docker安装教程

项目地址

Github

Flask

  • flask

    run.py

    from flask import Flask
    import os app = Flask(__name__) @app.route("/index/")
    def index():
    user = os.environ.get("USER")
    password = os.environ.get("PASS")
    return f"{user}_{password}" @app.route("/version/")
    def version():
    env = os.environ.get("ENV")
    version = os.environ.get("WEBVERSION")
    return f"{env}_{version}" if __name__ == '__main__':
    app.run(host="0.0.0.0", port=5000, debug=True)

    requirements.txt

    Flask
    gunicorn
    gevent
    greenlet

Docker

  • 编写dockerfile

    Dockerfile

    FROM python:3.6.8
    RUN mkdir simpleweb
    COPY . /simpleweb
    WORKDIR /simpleweb
    # 升级pip
    RUN pip3 install --upgrade pip -i https://mirrors.aliyun.com/pypi/simple # pip读取requirements.txt内容安装所需的库
    RUN pip3 install -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple
    CMD ["gunicorn", "-b", ":5000", "-k", "gevent", "run:app"]
  • 构建docker 镜像

    docker build -t zhengquantao/simpleweb:latest .
    # 可选命令
    # docker run 执行容器
    # docker exec 进入容器
    # docker tag 重命名
    # docker login 登录
    # docker push 推送到远程仓库

Kubernetes

  • ConfigMap

    存放配置文件

    simpleweb-configmap.yaml #

    apiVersion: v1
    kind: ConfigMap
    metadata:
    name: simpleweb-configmap
    data:
    env: "dev"
    webVersion: "v1"
  • Secret

    存放敏感信息,通过base64编码

    simpleweb-configmap.yaml

    apiVersion: v1
    kind: Secret
    metadata:
    name: db-user-pass
    type: Opaque
    data:
    username: YWRtaW4=
    password: MWYyZDFlMmU2N2Rm
  • Deployment

    编写pod

    simpleweb.yaml

    apiVersion: apps/v1
    kind: Deployment # 采用deployment部署
    metadata:
    name: simpleweb
    namespace: default # 默认命名空间
    labels:
    app: simpleweb
    spec:
    replicas: 2 # 副本设置1个
    selector:
    matchLabels:
    app: simpleweb
    strategy: # 升级策略,这里副本是一个
    rollingUpdate:
    maxSurge: 1
    maxUnavailable: 0
    type: RollingUpdate
    template:
    metadata:
    labels:
    app: simpleweb
    spec:
    containers: #容器相关配置
    - args: # 启动命令
    - gunicorn
    - -b
    - :5000
    - -k
    - gevent
    - run:app
    env: # 这里通过变量注入的方式配置相关参数,你也可以通过数据挂载的方式将配置挂载到容器指定目录下
    - name: USER
    valueFrom:
    secretKeyRef:
    name: db-user-pass
    key: username
    - name: PASS
    valueFrom:
    secretKeyRef:
    name: db-user-pass
    key: password
    - name: ENV
    valueFrom:
    configMapKeyRef:
    name: simpleweb-configmap
    key: env
    - name: WEBVERSION
    valueFrom:
    configMapKeyRef:
    name: simpleweb-configmap
    key: webVersion
    image: zhengquantao/simpleweb:lastest # 镜像地址
    imagePullPolicy: IfNotPresent # (IfNotPresent、Never)本地模式有坑,有远程仓库不建议使用
    name: simpleweb
    ports: # 暴漏端口
    - containerPort: 5000
    name: tcp5000
    protocol: TCP
    workingDir: /simpleweb
    restartPolicy: Always
    terminationGracePeriodSeconds: 5
  • Service

    编写service

    simplewebsvc.yaml

    apiVersion: v1
    kind: Service
    metadata:
    name: simplewebsvc
    namespace: default
    labels:
    app: simplewebsvc
    spec:
    ports:
    - name: tcp5000
    port: 5000
    protocol: TCP
    targetPort: 5000 # 容器端口
    nodePort: 31111 # 对外暴露端口
    selector:
    app: simpleweb # 指向pod
    type: NodePort
  • 执行部署

    kubectl apply -f simpleweb-secret.yaml
    kubectl apply -f simpleweb-configmap.yaml
    kubectl apply -f simpleweb.yaml
    kubectl apply -f simplewebsvc.yaml # kubectl get pods|svc 查看pod
    # kubectl create -f 构建pod
    # kubectl delete -f 删除pod
    # kubectl apply -f 存在更新pod,不存在构建pod
    # kubectl describe 查看详情pod
    # kubectl logs 查看pod日志
    # kubectl port-forward pod端口转发
    # kubectl exec 进入pod
  • 验证

    curl http://127.0.0.1:31111/index/

Flask简单部署至kubernetes的更多相关文章

  1. Flask应用部署

    1. 介绍 前面介绍了<Linux下Nginx使用>, 但是Nginx是一个提供静态文件访问的web服务 首先我们介绍一下Web服务器, 应用服务器和应用框架的关系 客户端: 浏览器或者a ...

  2. 使用Minikube部署本地Kubernetes集群(二十八)

    前言 使用Minikube部署本地k8s集群相对比较简单,非常推荐将其用于本地k8s开发环境,唯一麻烦点的仅仅是网络问题. 在本篇教程中,我们使用了国内的镜像来完成本地k8s集群的搭建.如果搭建过程中 ...

  3. Kubernetes 学习笔记(二):本地部署一个 kubernetes 集群

    前言 前面用到过的 minikube 只是一个单节点的 k8s 集群,这对于学习而言是不够的.我们需要有一个多节点集群,才能用到各种调度/监控功能.而且单节点只能是一个加引号的"集群&quo ...

  4. 吾八哥学k8s(二):golang服务部署到kubernetes

    本篇主要讲解如何将golang的服务部署到kubernetes集群里,附带相关的golang的demo和yml文件内容.纯新手入门方式,生产服务需要完整的CI/CD流程来支持. golang服务代码 ...

  5. 把Spring Cloud Data Flow部署在Kubernetes上,再跑个任务试试

    1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! Spring Cloud Data Flow在本地跑得好好的,为什么要部署在Kubernetes上呢?主要是因为Kubern ...

  6. 把H2数据库从jar包部署到Kubernetes,并解决Ingress不支持TCP的问题

    1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! H2 Database是一个优秀的数据库,又小又方便,支持内存和文件形式,经常会在测试.POC(proof of conce ...

  7. 高并发Flask服务部署

    高并发Flask服务部署 AI模型持久化 OOP: 利用面向对象思想,实现算法在内存上的实例化及持久化.即一次模型加载,多次请求调用. class ocr_infer_class(threading. ...

  8. 使用 Kubeadm+Containerd 部署一个 Kubernetes 集群

    本文独立博客阅读地址:https://ryan4yin.space/posts/kubernetes-deployemnt-using-kubeadm/ 本文由个人笔记 ryan4yin/knowle ...

  9. ingress-nginx 的使用 =》 部署在 Kubernetes 集群中的应用暴露给外部的用户使用

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247488189&idx=1&sn=8175f067 ...

  10. XenApp简单部署

    作者:MR.Yangwj 目录 XenApp简单部署... 1 一.         XenApp安装... 1 (一)      服务器配置任务... 9 1)     许可证服务器配置... 9 ...

随机推荐

  1. Windows wsl2支持systemd

    背景 很多Linux发行版都是使用systemd来管理程序进程,但是在WSL中默认是用init来管理进程的. 为了符合长久的使用习惯,且省去不必要的学习成本,就在WSL的发行版(我这里安装的是Ubun ...

  2. Git 11 设置项目提交人

    前面介绍了可以给 Git 设置全局提交人,这样当前电脑所有项目提交人都会变成设置的值. 但实际开发中有时候需要给不同项目设置不同提交人. 比如工作的项目是一个提交人,自己维护的开源项目又是另一个提交人 ...

  3. IP路由的工作原理

    一.路由 路由在网络中起到什么作用? • 路由器负责将数据报文在IP网段之间进行转发 • 路由是指导路由器如何进行数据转发的路径信息 IP之间连通的前提是什么? • 沿途的每台路由器上都有到达目的网段 ...

  4. node nvm使用

    背景 node 经过了一次大的改变,直接从8到了10,差别很大,但是有的项目又需要用到8,这个时候不能完全升级. 所以我们需要一个管理虚拟环境的工具. 安装 https://github.com/co ...

  5. Webpack Proxy工作原理?为什么能解决跨域?

    一.是什么 webpack proxy,即webpack提供的代理服务 基本行为就是接收客户端发送的请求后转发给其他服务器 其目的是为了便于开发者在开发模式下解决跨域问题(浏览器安全策略限制) 想要实 ...

  6. 学习C#编程经典书籍

    1.<C# 语言程序设计>(第4版):由微软公司的C#语言团队编写,是学习C#语言的必备经典著作. 2.<C#高级编程>(第9版):由Andrew Troelsen编写,涵盖了 ...

  7. kubelet 原理分析

    Reference https://atbug.com/kubelet-source-code-analysis/ kubelet 简介 kubernetes 分为控制面和数据面,kubelet 就是 ...

  8. 力扣430(java)-扁平化多级双向链表(中等)

    题目: 你会得到一个双链表,其中包含的节点有一个下一个指针.一个前一个指针和一个额外的 子指针 .这个子指针可能指向一个单独的双向链表,也包含这些特殊的节点.这些子列表可以有一个或多个自己的子列表,以 ...

  9. Koordinator v0.7: 为任务调度领域注入新活力

    简介: 在这个版本中着重建设了机器学习.大数据场景需要的任务调度能力,例如 Coscheduling.ElasticQuota 和精细化的 GPU 共享调度能力.并在调度问题诊断分析方面得到了增强,重 ...

  10. 技术干货 | 阿里云数据库PostgreSQL 13大版本揭秘

    简介: 阿里云RDS PostgreSQL是一款兼容开源PostgreSQL的全托管云数据库产品,自2015年首次发布以来,根据用户需求不断升级迭代,已支持9.4.10.11.12等多个版本,覆盖了高 ...