使用flask+gunicorn+nginx进行项目部署

2024-03-16 01:30

本文主要是介绍使用flask+gunicorn+nginx进行项目部署,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用gunicorn+nginx对flask项目进行部署

最近在进行项目部署,想将自己的项目部署到服务器上,以实现外网可随时访问。

在此分享部署过程中的经验

如有同样问题的小伙伴,可参考此片文章

一,需要拥有一台服务器

我这里使用的是阿里云的服务器(新用户白嫖),学生认证10块钱一个月,当然好像也是可以白嫖一段时间的。第一次使用阿里云很摸不着头脑我都没法找到在哪查看自己的ECS,这玩意要点时间琢磨琢磨。

1.https://www.aliyun.com/进入阿里云官网,购买(白嫖)服务器。

为你的服务器安装好系统,这里我选择安装的是ubantu20.04(为了方便免安装python3.8)

设置好你的密码(用户名默认root)

2.使用linux终端或window终端登陆你的服务器,这里我使用是的ubantu20.04登陆我的服务器的(正好和服务器的系统一样)。

使用命令登陆你的服务器:

ssh root@127.0.0.1(这里是你的服务器公网ip)

二,进入服务器后,就像正常使用linux一样,安装好配置文件即可

一,项目的传输:

1.我这是使用xftp进行文件的上传的(放个网盘文件)

链接:https://pan.baidu.com/s/1yZWLJN0hI2W03d5Svm_cJg 
提取码:uy6i 
方便手机端保存(放个二维码)

2.安装完成后我们打开软件登陆(选择password)

 在文件-》打开里面可以看到连接过的服务器

连接完成后就可以从本地上传文件到服务器了,右键文件-》上传即可

3.在服务器安装运行的必备库,可以将其写到一个文本中,在本地创建re.txt,并写入库和对应版本,如下格式:

上传到服务器根目录后使用命令(使用pip3,我这里有python2,所有直接使用pip会默认使用python2安装)

pip3 install -r re.txt

即可完成相关库的安装

二,Gunicorn的安装及配置:

1.换源

sudo apt update

2.安装python(根据自己需要去安装,由于服务器安装的是ubantu20.02,自带了python2,3.8,3.9)

看过很多的方法,但是都比较麻烦,这里可以git去安装,参考此篇博客:

在此之前若未安装git,需要按照提示去安装git

https://blog.csdn.net/jaket5219999/article/details/80894517?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522161641247516780357296935%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=161641247516780357296935&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~baidu_landing_v2~default-1-80894517.pc_search_result_before_js&utm_term=linuxpython%E5%AE%89%E8%A3%85%E5%91%BD%E4%BB%A4

3.gunicorn安装:

sudo apt-get install gunicorn

配置gunicorn

先安装vim

sudo apt install vim

在根目录下创建gun.conf并写入配置文件

sudo vim /root/gun.conf

进入文件后按i写入如下内容(这里的ip是你服务器的公网ip)

详细配置信息如上图,在flask中ip和端口号也要对应(这里ip与gunicorn中配置要一样)

注意!!!端口号要在服务器安全组中添加,建议大于1024(据说linux对此有限制????)

启动gunicorn,查看是否配置成功:

gunicorn -c gun.conf 你的flask文件名,不要.py后缀:flask内实例名

例如:(flask内示例名是app,文件名为flask_main.py)

gunicorn -c gun.conf flask_main:app

在浏览器键入你的公网ip:端口号看是否可以访问(ip和端口号要和上面gunicorn中一致)。

可以访问后,在终端按住ctrl+c终止gunicorn运行,进行后续步骤。

 

三,nginx的安装

1.命令安装nginx

sudo apt install nginx

2.配置nginx(上述命令安装默认配置文件在下面这个地址)

sudo vim /etc/nginx/sites-available/default

进入配置文件后,按i编辑文件

-》删除所有内容(一定要删一定要删,我第一次没配置成功就是因为这个。。。也不知道是不是这个原因,但是删除再编辑就好了)

-》加入如下内容(登陆qq后,ctrl+alt+a截图识别文字)

编辑完成后,按esc退出编辑,键入:wq!保存并退出即可。

查询配置文件是否有误:

nginx -t

如下提示代表无误:

到这里就配置完成了,重启一下nginx(未启动过就直接启动nginx)即可

service nginx restart

此时,已经部署完成了,过程无误,即可通过公网ip访问了。

四,Gunicorn后台运行

当你完成前三大步后,高高兴兴的关闭了服务器终端,你会发现,无法通过公网ip访问了。

这是因为,gunicorn停止运行了

这是我们要他在关闭终端后依然可以运行,就要使其在后台运行:

注意:这条命令里面的参数要和你自己的一致

gunicorn -c gun.conf flask_main:app -D

-D就是表示在后台运行。

,这个时候才是真正的大功告成,此时可以退出服务器终端,依然可以通过公网ip访问。

五,项目更新

当项目文件更新或者更改了的时候,我们就要重启gunicorn以及nginx(这个不清楚是不是也要重启,我想着反正也不麻烦,就重启下吧)

此时的gunicorn是后台运行的,我们要先关闭这个进程,防止他占用端口:

使用命令查看进程树

pstree -ap|grep gunicorn 

显示如下数据:

  |-gunicorn,22344 /usr/bin/gunicorn -c gun.conf flask_main:app -D|   |-gunicorn,22346 /usr/bin/gunicorn -c gun.conf flask_main:app -D|   |-gunicorn,22347 /usr/bin/gunicorn -c gun.conf flask_main:app -D|   |-gunicorn,22348 /usr/bin/gunicorn -c gun.conf flask_main:app -D|   `-gunicorn,22349 /usr/bin/gunicorn -c gun.conf flask_main:app -D|           |-grep,22393 --color=auto gunicorn

再使用命令

kill -9 22344

杀死父进程(22344是父进程的进程号)

最后再使gunicorn在后台运行即可。

 

 

以上就是linux下使用gunicorn+nginx部署flask项目的经验内容了,当然gunicorn和nginx有更多的配置项,这里只是写的比较简单的配置。

 

 

 

这篇关于使用flask+gunicorn+nginx进行项目部署的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813891

相关文章

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学