测试平台系列(60) 在Linux机器上部署Pity

简介: 在Linux机器上部署Pity

大家好~我是米洛


这是一个完整的接口测试平台系列教程,希望能和大家一起学习,从0到1打造一个开源平台。


回顾


上一节我们编写了用例列表相关改造,但由于编辑/新增case的页面还得好好设计一番,而后端接口也没啥大的变化。

所以今天我们来聊聊怎么部署。

部署服务的几种方式


其实我们如果是在公司使用的话,一般公司运维都会提供部署服务的平台,但可能都是以业务代码使用的语言为主。

比如我上家公司,业务代码是用的Java,所以在Java服务的部署上,基本上接入公司发布系统即可。不扯远了,有的公司测试会自己维护一台服务器,随便儿你玩,不走发布系统。(当然如果你们公司支持Python服务的发布,建议还是用公司的发布系统,贵在稳定+可视化)

如果我们是自己维护自己的服务器,该怎么部署咱们的系统呢?

以下是Pity的部署教程,如果想看其他Python部署方式的,可以先跳过哈。

数据库

数据库这块比较简单,Pity提供了自动建表功能,底层使用的是MySQL,所以大家需要准备一台MySQL服务器,或者就在你的服务器安装好MySQL也是一样。

具体的安装过程我这儿就不细说了。

安装好以后我们会拿到用户名,密码,host和port信息,我们还需要创建数据库:


create database pity;

修改pity关于数据库的配置


在pity/Config.py修改SQLALCHEMY的连接串:

44.jpg

配置成你们本地的数据库连接

这样你的数据就能好好保存在你们的数据库了。

安装依赖


pip3 install -r requirements.txt

也可以使用豆瓣源:


pip3 install -r requirements.txt -i https://pypi.douban.com/simple

如果过程中安装失败了,建议升级一下pip

测试服务是否启动

如果启动服务的时候报没有logs文件夹,可以在pity根目录新建文件夹: logs,因为github会自动忽略掉空文件夹,所以可能需要大家自己创建。

在pity目录下启动服务:


python3 main.py

45.jpg

如果出现这样的图片,则是启动成功了

打开http://服务器ip:7777:

46.jpg

image


正题

我们今天主要是讲怎么用gunicorn部署Python服务,只不过博主我先用了自己的项目

回到正题,我们先来看一看最简单的一个部署方式

经典部署方式


在解决好所有环境依赖以后,我们通过python3 xxx.py启动服务,这样其他人就能够通过服务器ip+端口访问页面了。

http://服务器ip:端口号/

思考一下这样做的弊端:

  1. 服务器会一直打印着请求信息,并没有在后台运行

47.jpg

就像现在这样,shell会一直持续保持这样的状态


  1. 程序如果自动宕机,不能自动恢复

比如哪天程序不小心崩溃了,有的异常没有被自动捕获,导致整个Python程序崩溃,从而导致系统无法访问

  1. Python GIL性能太差

改进一下


针对经典部署,其实也有一些处理方式,比如第一条,我们可以用nohup帮我们解决第一个困难。


nohup python xxx.py &

然后可以看到当前目录生成了nohup.out的文件,而你的控制台窗口也没有再停留在服务输出窗口。

但还有其他困难,我们怎么解决呢?别慌!我们还有gunicorn+supervisor

supervisor

supervisor是一个托管容器,你的应用会被托管到里面,而他会提供一个守护线程,专门监控你的应用。当你的应用不小心崩了,他会自动把应用拉起,非常好用

遇到非代码错误,比如有人误操作kill掉你的程序,它会自动帮忙拉起,毫无波澜。

gunicorn

gunicorn基于gevent,差不多算是个提升app性能的库,它可以帮助我们的web应用提升性能,并且他也有自动重启的功能,还可以开启根据服务器配置开启不同数量的worker

怎么使用呢


安装Gunicorn


pip3 install gunicorn

以我们的app为例,我们的app名字叫pity,文件是main.py,所以取到app的方法就是: main:pity

48.jpg

image

普通gunicorn模式


安装好以后gunicorn命令就能够使用了,输入命令:


# FastApi应用
gunicorn -k uvicorn.workers.UvicornWorker main:pity -b 0.0.0.0:7777 -w 4 &

解释一下参数:

-k:

这个是指定worker为Uvicorn的Worker,为fastapi专属,其他比如flask应用不需要带上这个参数。

-w

workers数量,也就是起的线程数量,一般根据自己CPU内核来。比如我的服务器是4核的,那我就设定为4。

main:pity就是上面说的app的具体位置。

试验一下

49.jpg

可以看到服务都启动成功了

50.jpg

ps -ef | grep gunicorn可以看到这些个线程

配置文件的方式启动


我们编写gunicorn.py文件(配置文件):


import os
import gevent.monkey
gevent.monkey.patch_all()
import multiprocessing
# debug = True
loglevel = 'debug'
bind = "0.0.0.0:7777"
pidfile = "logs/gunicorn.pid"
accesslog = "logs/access.log"
errorlog = "logs/debug.log"
daemon = True
timeout = 60
# 启动的进程数
# workers = multiprocessing.cpu_count()
workers = 8
worker_class = 'gevent'
x_forwarded_for_header = 'X-FORWARDED-FOR'

配置好bind地址,日志信息,workders数量,multiprocessing.cpu_count()会返回CPU数量。

记得安装gevent,用pip。

51.jpg

image

可以看到服务起来了,这边我开了8个workder

其实这个时候gunicorn已经具备了自动拉起功能,但gunicorn也可能被kill掉,所以我们更稳妥点儿的话,需要supervisor

supervisor

这块的资料比较多,大家可以尽情百度,因为博主主要讲的是部署方式,还得靠大家自己去实践呐。

更多部署方式


dockerk8s什么的也是不错的选择,如果大家有兴趣也可以多研究一下,作为测试的我们,掌握好基本的用法即可。

如果有兴趣也欢迎大家一起探讨~~



相关文章
|
14天前
|
机器学习/深度学习 监控 Linux
eLxr 简介——为边缘到云部署提供企业级Linux
eLxr项目发布了Debian衍生版的第一个版本,继承了Debian的智能边缘功能,并计划对这些功能进行扩展,以便简化边缘到云的部署方法。eLxr是一个开源企业级Linux发行版,旨在应对近边缘网络和工作负载的独特挑战。
|
6天前
|
安全 Linux 图形学
Linux平台Unity下RTMP|RTSP低延迟播放器技术实现
本文介绍了在国产操作系统及Linux平台上,利用Unity实现RTMP/RTSP直播播放的方法。通过设置原生播放模块的回调函数,可将解码后的YUV数据传递给Unity进行渲染,实现低延迟播放。此外,还提供了播放器启动、参数配置及停止的相关代码示例,并概述了如何在Unity中更新纹理以显示视频帧。随着国产操作系统的发展,此类跨平台直播解决方案的需求日益增长,为开发者提供了灵活高效的开发方式。
|
4天前
|
NoSQL Java Linux
Jedis测试redis。(redis在linux虚拟机中)
该博客文章提供了使用Jedis客户端连接Linux虚拟机中的Redis服务器的步骤,包括Maven依赖配置、测试用例编写以及测试结果的截图。
|
6天前
|
编解码 算法 Linux
Linux平台下RTSP|RTMP播放器如何跟python交互投递RGB数据供视觉算法分析
在对接Linux平台的RTSP播放模块时,需将播放数据同时提供给Python进行视觉算法分析。技术实现上,可在播放时通过回调函数获取视频帧数据,并以RGB32格式输出。利用`SetVideoFrameCallBackV2`接口设定缩放后的视频帧回调,以满足算法所需的分辨率。回调函数中,每收到一帧数据即保存为bitmap文件。Python端只需读取指定文件夹中的bitmap文件,即可进行视频数据的分析处理。此方案简单有效,但应注意控制输出的bitmap文件数量以避免内存占用过高。
|
6天前
|
编解码 Linux 数据安全/隐私保护
Linux平台x86_64|aarch64架构如何实现轻量级RTSP服务
为满足在Linux平台(x86_64与aarch64架构)上实现轻量级RTSP服务的需求,我们开发了一套解决方案。该方案通过调用`start_rtsp_server()`函数启动RTSP服务,并设置端口号及认证信息。支持AAC音频和H.264视频编码,可推送纯音频、纯视频或音视频流。此外,还支持X11屏幕采集、部分V4L2摄像头采集、帧率/GOP/码率调整、摄像头设备选择与预览等功能。对于音频采集,支持alsa-lib和libpulse接口。整体设计旨在提供150-400ms的低延迟体验,适用于多种应用场景。
|
10天前
|
消息中间件 监控 Java
【一键解锁!】Kafka Manager 部署与测试终极指南 —— 从菜鸟到高手的必经之路!
【8月更文挑战第9天】随着大数据技术的发展,Apache Kafka 成为核心组件,用于处理实时数据流。Kafka Manager 提供了简洁的 Web 界面来管理和监控 Kafka 集群。本文介绍部署步骤及示例代码,助您快速上手。首先确认已安装 Java 和 Kafka。
41 4
|
12天前
|
资源调度 JavaScript 搜索推荐
Linux系统之部署CodeX Docs文档工具
【8月更文挑战第7天】Linux系统之部署CodeX Docs文档工具
27 4
|
5天前
|
编解码 Linux 开发工具
Linux平台x86_64(麒麟|统信UOS)|aarch64(飞腾)如何实现摄像头|屏幕和麦克风|扬声器采集推送RTMP服务或轻量级RTSP服务
国产化操作系统的发展,减少了外部依赖,更符合国家安全标准,并可提升自主研发能力,促进产业链发展,满足定制开发能力,减少了外部技术封锁的风险,提高了国际竞争力,推动了产业升级。目前大牛直播SDK针对Linux平台x86_64架构和aarch64架构的RTMP推送模块和轻量级RTSP服务模块
|
6天前
|
JavaScript Linux 内存技术
NVM——Linux下快速部署NVM并安装nodeJs
NVM——Linux下快速部署NVM并安装nodeJs
17 0
|
9天前
|
关系型数据库 Linux 网络安全
"Linux系统实战:从零开始部署Apache+PHP Web项目,轻松搭建您的在线应用"
【8月更文挑战第9天】Linux作为服务器操作系统,凭借其稳定性和安全性成为部署Web项目的优选平台。本文以Apache Web服务器和PHP项目为例,介绍部署流程。首先,通过包管理器安装Apache与PHP;接着创建项目目录,并上传项目文件至该目录;根据需要配置Apache虚拟主机;最后重启Apache服务并测试项目。确保防火墙允许HTTP流量,正确配置数据库连接,并定期更新系统以维持安全。随着项目复杂度提升,进一步学习高级配置将变得必要。
21 0

热门文章

最新文章