Python开发运维:Python项目发布到K8S集群

目录

一、实验

1.Python项目发布到K8S集群


一、实验

1.Python项目发布到K8S集群

(1)获取应用程序代码

bash 复制代码
#把hello-python.tar.gz压缩包上传到k8s控制节点master1的root下,手动解压
tar zxvf hello-python.tar.gz 

(2)切换目录

bash 复制代码
#requirements.txt文件包含main.py所需的包列表,pip将使用它来安装Flask库。 
cd /root/hello-python/app

(3)创建dockerfile

bash 复制代码
[root@master1 app]# cat dockerfile 
FROM python:3.7
RUN mkdir /app 
WORKDIR /app 
ADD . /app/ 
RUN /usr/local/bin/python -m pip install --upgrade pip
RUN pip install -r requirements.txt
EXPOSE 5000
CMD ["python","/app/main.py"]

(4)构建镜像

bash 复制代码
#需要先拉取python镜像
docker pull python:3.7

docker build  -t hello-python:v1 .

(5) 把镜像做成离线包

bash 复制代码
docker save -o hello.tar.gz hello-python:v1

(6) 查看镜像大小

bash 复制代码
du -sh hello.tar.gz

(7)传送到node1节点

bash 复制代码
 scp hello.tar.gz node1:/root

(8)在node1节点解压镜像

bash 复制代码
docker load  -i hello.tar.gz

(9)创建deployment的yaml文件

bash 复制代码
[root@master1 app]# cat deployment.yaml 
apiVersion: v1
kind: Service
metadata:
  name: hello-python-service
spec:
  selector:
    app: hello-python
  ports:
  - protocol: "TCP"
    port: 6000
    targetPort: 5000
  type: NodePort

---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: hello-python
spec:
  selector:
    matchLabels:
     app: hello-python
  replicas: 1
  template:
    metadata:
      labels:
        app: hello-python
    spec:
      containers:
      - name: hello-python
        image: hello-python:v1
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 5000

(10)更新yaml文件

bash 复制代码
kubectl apply -f deployment.yaml

(11)访问python项目

bash 复制代码
kubectl get svc

浏览器访问192.168.204.180:31552即可:

相关推荐
xqhoj3 分钟前
Linux学习指南(二)——进程
linux·运维·服务器
小二·4 分钟前
Python Web 开发进阶实战:边缘智能网关 —— 在 Flask + MicroPython 中构建轻量级 IoT 边缘推理平台
前端·python·flask
yangSnowy11 分钟前
Linux实用命令分析nginx系统日志文件
linux·运维·服务器
喵手14 分钟前
Python爬虫零基础入门【第六章:增量、去重、断点续爬·第2节】断点续爬:失败队列、重放、任务状态!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·增量、去重、断点续爬·断点续爬
轻竹办公PPT16 分钟前
2026 年 AI PPT 工具市场观察:国产工具与海外竞品的本土化对决,谁更懂中文职场
人工智能·python·powerpoint
2401_8322981017 分钟前
腾讯云TSearch存算分离,破解日志分析算力瓶颈
大数据·运维·数据库
喵手31 分钟前
Python爬虫零基础入门【第七章:动态页面入门(Playwright)·第1节】Playwright 第一次:打开页面、等待元素、拿到渲染后 HTML!
爬虫·python·爬虫实战·动态页面·playwright·python爬虫工程化实战·零基础python爬虫教学
一个无名的炼丹师37 分钟前
DeepSeek+LangGraph构建企业级多模态RAG:从PDF复杂解析到Agentic智能检索全流程实战
python·pdf·大模型·多模态·rag
历程里程碑44 分钟前
哈希3 : 最长连续序列
java·数据结构·c++·python·算法·leetcode·tornado
火云洞红孩儿1 小时前
2026年,用PyMe可视化编程重塑Python学习
开发语言·python·学习