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即可:

相关推荐
聪明的墨菲特i几秒前
Django前后端分离基本流程
后端·python·django·web3
工业3D_大熊7 分钟前
【虚拟仿真】CEETRON SDK在船舶流体与结构仿真中的应用解读
java·python·科技·信息可视化·c#·制造·虚拟现实
SEEONTIME16 分钟前
python-24-一篇文章彻底掌握Python HTTP库Requests
开发语言·python·http·http库requests
Bearnaise16 分钟前
PointMamba: A Simple State Space Model for Point Cloud Analysis——点云论文阅读(10)
论文阅读·笔记·python·深度学习·机器学习·计算机视觉·3d
Zfox_16 分钟前
【Linux】进程信号全攻略(二)
linux·运维·c语言·c++
安於宿命21 分钟前
【Linux】简易版shell
linux·运维·服务器
追梦不止~28 分钟前
Docker常用命令+详解
运维·docker·容器
黑龙江亿林等保32 分钟前
深入探索哈尔滨二级等保下的负载均衡SLB及其核心算法
运维·算法·负载均衡
黄小耶@33 分钟前
linux常见命令
linux·运维·服务器
叫我龙翔34 分钟前
【计网】实现reactor反应堆模型 --- 框架搭建
linux·运维·网络