Flask简单部署至kubernetes
安装Kubernetes、Docker
项目地址
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: 5Service
编写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的更多相关文章
- Flask应用部署
1. 介绍 前面介绍了<Linux下Nginx使用>, 但是Nginx是一个提供静态文件访问的web服务 首先我们介绍一下Web服务器, 应用服务器和应用框架的关系 客户端: 浏览器或者a ...
- 使用Minikube部署本地Kubernetes集群(二十八)
前言 使用Minikube部署本地k8s集群相对比较简单,非常推荐将其用于本地k8s开发环境,唯一麻烦点的仅仅是网络问题. 在本篇教程中,我们使用了国内的镜像来完成本地k8s集群的搭建.如果搭建过程中 ...
- Kubernetes 学习笔记(二):本地部署一个 kubernetes 集群
前言 前面用到过的 minikube 只是一个单节点的 k8s 集群,这对于学习而言是不够的.我们需要有一个多节点集群,才能用到各种调度/监控功能.而且单节点只能是一个加引号的"集群&quo ...
- 吾八哥学k8s(二):golang服务部署到kubernetes
本篇主要讲解如何将golang的服务部署到kubernetes集群里,附带相关的golang的demo和yml文件内容.纯新手入门方式,生产服务需要完整的CI/CD流程来支持. golang服务代码 ...
- 把Spring Cloud Data Flow部署在Kubernetes上,再跑个任务试试
1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! Spring Cloud Data Flow在本地跑得好好的,为什么要部署在Kubernetes上呢?主要是因为Kubern ...
- 把H2数据库从jar包部署到Kubernetes,并解决Ingress不支持TCP的问题
1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! H2 Database是一个优秀的数据库,又小又方便,支持内存和文件形式,经常会在测试.POC(proof of conce ...
- 高并发Flask服务部署
高并发Flask服务部署 AI模型持久化 OOP: 利用面向对象思想,实现算法在内存上的实例化及持久化.即一次模型加载,多次请求调用. class ocr_infer_class(threading. ...
- 使用 Kubeadm+Containerd 部署一个 Kubernetes 集群
本文独立博客阅读地址:https://ryan4yin.space/posts/kubernetes-deployemnt-using-kubeadm/ 本文由个人笔记 ryan4yin/knowle ...
- ingress-nginx 的使用 =》 部署在 Kubernetes 集群中的应用暴露给外部的用户使用
文章转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247488189&idx=1&sn=8175f067 ...
- XenApp简单部署
作者:MR.Yangwj 目录 XenApp简单部署... 1 一. XenApp安装... 1 (一) 服务器配置任务... 9 1) 许可证服务器配置... 9 ...
随机推荐
- HarmonyOS音视频开发概述
在音视频开发指导中,将介绍各种涉及音频.视频播放或录制功能场景的开发方式,指导开发者如何使用系统提供的音视频API实现对应功能.比如使用TonePlayer实现简单的提示音,当设备接收到新消息时, ...
- 重新点亮linux 命令树————文件特殊权限[十一]
前言 简单介绍一下文件特殊权限. 正文 SUID 用于二进制可执行文件,执行命令时取得文件属组权限 如 /usr/bin/passwd 当我们使用passwd 修改密码的时候其实是以root用户身份进 ...
- 推荐一个计算Grad-CAM的Python库
前言 类激活图CAM(class activation mapping)用于可视化深度学习模型的感兴趣区域,增加了神经网络的可解释性.现在常用Grad-CAM可视化,Grad-CAM基于梯度计算激活图 ...
- oracle表名、字段名等对象的命名长度限制(报错:ORA-00972: 标识符过长)
oracle表名.字段名等对象的命名长度限制(报错:ORA-00972: 标识符过长) 简单来说,出现了ORA-00972: 标识符过长的错误 找来找去发现是自己的中间表名太长导致的 Oracle数据 ...
- python格式化时间报错:UnicodeEncodeError: 'locale' codec can't encode character '\u5e74' in position 2: Illegal byte sequence
执行下列代码: from datetime import datetime t = datetime.now() print(t) print(t.strftime("%Y年%m月%d日,% ...
- 力扣524(java)-通过删除字母匹配到字典里最长单词(中等)
题目: 给你一个字符串 s 和一个字符串数组 dictionary ,找出并返回 dictionary 中最长的字符串,该字符串可以通过删除 s 中的某些字符得到. 如果答案不止一个,返回长度最长且字 ...
- Fury:一个基于JIT动态编译的高性能多语言原生序列化框架
简介: Fury是一个基于JIT动态编译的多语言原生序列化框架,支持Java/Python/Golang/C++等语言,提供全自动的对象多语言/跨语言序列化能力,以及相比于别的框架最高20~200倍的 ...
- 服务网格 ASM 年终总结:最终用户如何使用服务网格?
简介:本文不打算回顾 Istio 或是阿里云服务网格 ASM 的变化或趋势,我们来聊一聊阿里云 ASM 服务网格,它的最终用户是如何使用服务网格的. 作者:叶剑宏 背景 阿里云服务网格 ASM 于 ...
- 全链路灰度之 RocketMQ 灰度
简介:本文将以上次介绍过的<如何用 20 分钟就能获得同款企业级全链路灰度能力?>中的场景为基础,来进一步介绍消息场景的全链路灰度. 作者:亦盏 之前的系列文章中,我们已经通过全链路金丝 ...
- Dapr 在阿里云原生的实践
简介: Faas 场景下,比较吸引用户的是成本和研发效率,成本主要通过按需分配和极致的弹性效率来达成.而应用开发者期望通过 FaaS 提供多语言的编程环境,提升研发效率,包括启动时间.发布时间.开发的 ...