一 使用docker运行fastapi程序(python封装http接口)

一 docker commit

1 下载python3的镜像

docker pull python:3.8-slim # slim版本,比普通版本小很多

2 以交互模式运行容器

docker run -it --name fastapi python:3.8-slim bash

3 在容器中安装fastapi和后台服务

pip3 install fastapi
pip install uvicorn

4 写一个简单的fastapi接口。main.py

from typing import Union
from fastapi import FastAPI
app = FastAPI()
@app.get("/")
async def read_root():
return {"Hello": "World"}

5 执行exit退出容器

6 将容器另存为新的镜像

docker commit fastapi python3-fastapi-test

7 启动容器

docker run -d -p 9090:8080 python3-fastapi-test uvicorn main:app --host 0.0.0.0 --port 8080 --reload
将容器的8080端口映射到宿主机的9090端口

8 访问接口,正常返回

curl 127.0.0.1:9090
返回:{"Hello":"World"}

二 docker build

1 编写Dockerfile

FROM python:3.8-slim
WORKDIR /app
RUN pip install -r requirement.txt
COPY . /app
EXPOSE 8080
CMD ["uvicorn", "--host", "0.0.0.0", "main:app", "--reload"]
# RUN chmod +x script.sh
# RUN ./script.sh
# ENTRYPOINT ["/bin/bash", "script.sh"]

2 构建docker镜像

docker build -t python3-fastapi-test:latest .

3 启动容器

docker run -dt -p 9090:8080 python3-fastapi-test 

4 访问接口,正常返回

curl 127.0.0.1:9090
返回:{"Hello":"World"}

二 k8s的deployment部署应用

1 在宿主机编写deployment的yaml文件fastapi-test.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
name: fast-api
labels:
app: fast-api
spec:
selector:
matchLabels:
app: fast-api
replicas: 1
template:
metadata:
labels:
app: fast-api
spec:
nodeName: node01
containers:
- name: fast-api
image: python3-fastapi-test
imagePullPolicy: Never
ports:
- containerPort: 9090
name: fast-api
command: ["/bin/bash", "-c", "uvicorn main:app --host 0.0.0.0 --port 9090 --reload"] 这里解释一下imagePullPolicy表示k8s拉取镜像的策略:
IfNotPresent 默认值,表示宿主机上没有该镜像时才拉取。
Always 表示每次创建pod时都会重新拉取镜像。
Never 表示只使用本地镜像,从不主动拉取镜像。 nodeName: node01 表示从node01这个节点拉取镜像启动pod,因为我的镜像在node01这个节点,所以加了这个参数

2 通过deployment启动pod

执行命令:kubectl apply -f fastapi-test.yaml
查看pod,可以看到pod已经起来
[root@node01 test]# kubectl get pod
NAME READY STATUS RESTARTS AGE
fast-api-7c8d949dd9-8lztf 1/1 Running 0 40m 查看pod的ip地址
[root@node01 test]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
fast-api-7c8d949dd9-8lztf 1/1 Running 0 68m 100.117.144.148 node01 <none> <none> 调用接口,成功返回“{"Hello":"World"}”
[root@node01 test]# curl 100.117.144.148:9090
{"Hello":"World"}[root@node01 test]#

3 创建service添加负载均衡

如果我们的服务有多个pod,可以创建一个service作为访问服务的入口,自动实现负载均衡

执行命令:kubectl expose -f fastapi-test.yaml --port=9090 --target-port=8080
查看service
[root@node01 test]# kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
fast-api ClusterIP 10.102.138.74 <none> 9090/TCP 2s
这里可以看到已经创建了service,通过curl可成功访问接口
[root@node01 test]# curl 10.102.138.74:9090
{"Hello":"World"}[root@node01 test]
添加fastapi-test.yaml
apiVersion: v1
kind: Service
metadata:
name: fast-api
spec:
selector:
app: fast-api # 通过app名匹配对应容器
ports: 
- protocol: TCP
port: 9090
targetPort: 8080

️ kubernetes中的nodePort,targetPort,port区别意义

#nodePort
外部机器可访问的端口。
比如一个Web应用需要被其他用户访问,那么需要配置type=NodePort,而且配置nodePort=30001,那么其他机器就可以通过浏览器访问scheme://node:30001访问到该服务,例如http://node:30001。
例如MySQL数据库可能不需要被外界访问,只需被内部服务访问,那么不必设置NodePort
# targetport
容器的端口(最根本的端口入口),与制作容器时暴露的端口一致(DockerFile中EXPOSE),例如docker.io官方的nginx暴露的是80端口。
# port
kubernetes中的服务之间访问的端口,尽管mysql容器暴露了3306端口(参考https://github.com/docker-library/mysql/的DockerFile),但是集群内其他容器需要通过33306端口访问该服务,外部机器不能访问mysql服务,因为他没有配置NodePort类型

示例

apiVersion: v1
kind: Service
metadata:
name: nginx-service
spec:
type: NodePort
ports:
- port: 30080
targetPort: 80
nodePort: 30001
selector:
name: nginx-pod
-----------
apiVersion: v1
kind: Service
metadata:
name: mysql-service
spec:
ports:
- port: 33306
targetPort: 3306
selector:
name: mysql-pod

通过k8s部署服务的更多相关文章

  1. .NetCore 使用k8s部署服务的过程中需要注意的地方以及遇到的问题

    这里开始我准备了3台测试服务器,这里我使用了JumpServer管理起来了,这里我们来看下: Master :192.168.0.236 Node1:192.168.0.237 Node2:192.1 ...

  2. Python服务Dokcer化并k8s部署实例

    这篇文章记录了我试验将一个基于python的服务docker化并k8s部署的过程. 服务介绍Docker化设计业务代码改造创建docker镜像K8S部署设计yaml文件运行服务介绍这是一个用 pyth ...

  3. 微服务探索之路03篇-docker私有仓库Harbor搭建+Kubernetes(k8s)部署私有仓库的镜像

    ❝ 目录: 微服务探索之路01篇.net6.0项目本地win10系统docker到服务器liunx系统docker的贯通 微服务探索之路02篇liunx ubuntu服务器部署k8s(kubernet ...

  4. 微服务从代码到k8s部署应有尽有系列(一)

    从本篇文章开始,我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 实战项目地址:https://github.com/Mikaelemmmm/go-zer ...

  5. 微服务从代码到k8s部署应有尽有系列(二、网关)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  6. 微服务从代码到k8s部署应有尽有系列(三、鉴权)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  7. 微服务从代码到k8s部署应有尽有系列(四、用户中心)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  8. 微服务从代码到k8s部署应有尽有系列(五、民宿服务)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  9. 微服务从代码到k8s部署应有尽有系列(六、订单服务)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  10. 微服务从代码到k8s部署应有尽有系列(十四、部署环境搭建)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

随机推荐

  1. 时钟频率(HZ)与数据传输速率(bit/s)的关系-转载

    (24条消息) 时钟频率(HZ)与数据传输速率(bit/s)的关系_子曰小玖的博客-CSDN博客_速率和频率的关系 时钟频率(HZ)与数据传输速率(bit/s)两者是相同的概念.举例:IIC传输位速率 ...

  2. Unity 复杂Json 解析

    最近项目需要, 搞了一串嵌套非常多的Json 用LitJson读取体验不太好,上网查了一下发现NetwtonsoftJson ,十分好用 一句代码就可以了 JObject data = JsonCon ...

  3. spring-configuration-metadata元数据与additional-spring-configuration-metadata元数据区别

    参考 https://docs.spring.io/spring-boot/docs/current/reference/html/appendix-configuration-metadata.ht ...

  4. Linux基础第七章:磁盘阵列(RAID)

    一.磁盘阵列 二.磁盘阵列类型 1.RAID 0 2.RAID 1 3.RAID 5 4.RAID10 三.磁盘阵列配置 1.硬件方式 2.软件方式 一.磁盘阵列独立硬盘冗余阵列(RAID, Redu ...

  5. Unity 简易聊天室(基于TCP)(1)

    为了准备毕业设计,学习了服务器与客户端之间传输的一些简单的知识,并跟着网络上的教程制作了一个简易的Unity聊天室 服务器:用C# .Net Framework写的 结构分为:main(主函数).Se ...

  6. xmapp

    下载软件 并开启Apache 创建文本 `<?php echo " 姓名:丁文博 学号:20211306 才艺:打篮球 专业:信息安全 学校:北京电子科技学院 ";` 在网页 ...

  7. ZSTUOJ刷题④:Problem B.--输出双层金字塔

    Problem B: 输出双层金字塔 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 7860  Solved: 5834 Description 输出双层 ...

  8. 元素定位xpath路径中添加参数的方法

    在某次自动化测试中,需要定位下拉列表(非select列表)中不同的元素,我想到了利用参入参数的方式来实现,经过多次尝试,得到如下方法,与大家分享 例如在通过text定位某个元素时,self.find_ ...

  9. c++ vtdcm对于压缩模式文档图片的读取

    //获取dcm数据结构,一下图像数据仅针对单通道8字节数据 DcmFileFormat fileformat; OFCondition oc = fileformat.loadFile(dcmPath ...

  10. Vue2路由跳转传参,获取路由参数,Vue监听路由

    1 this.$router.push({ 2 // name:路由组件名 3 name: routeName, 4 query: { 5 mapId:this.mapId 6 } 7 }) 8 9 ...