Flask(3): 在Linux系统上部署项目

        1 前言

        说实话,我并不想接触linux系统,要记住太多的命令。我更习惯windows系统,鼠标点点,只要记住少量的命令就可以了。

        但是我选择了python,就注定无法逃避linux系统。虽然python也能在windows上很好的运行,但根据我的观察,python更适合在linux系统上运行(在windows上,跟C#这类语言比,感觉python就像外人)。

        既然躲不过,那就开干。就像我不想学JavaScript一样,但涉及前端就躲不开它。谁让咱是全(guang)栈(gan)开(si)发(ling)呢😂?

        我决定从流行的ubuntu开始(虽然树莓派的官方系统之前用过,不过不是当服务器用的,而且也多用的是图形界面)。

        正好我要参加一个考试,给了一个pdf题库,只要背题就可以了。作为程序员怎么可能直接在pdf里面背题呢? 做个答题系统不香吗?我决定先用ai做个简易答题系统,在ubuntu server上部署,先用起来再说。

        2 准备部署环境

        2.1 更新服务器

        确保目标服务器上的软件是最新的,使用如下命令来更新Ubuntu服务器:

sudo apt update
sudo apt upgrade

        2.2 安装python和pip

        Flask需要Python环境。确保目标服务器上安装了Python 3和pip。

sudo apt install python3 python3-pip

        一般情况下系统已经自带,无需安装。

        2.3 安装虚拟环境组件,并建立虚拟环境

        使用如下命令安装组件:

sudo apt install python3-venv

        定位到项目部署目录,执行如下命令:

python3 -m venv myprojectenv

        注意:这里的“myprojectenv”是虚拟环境所在文件夹名称,可以根据自己的需要换成其他名称。

        2.4 激活虚拟环境

        运行如下命令来激活虚拟环境:

source myprojectenv/bin/activate

        注意: 这里的“myprojectenv”是自定义的虚拟环境目录名称

        3 安装项目依赖的模块

        将项目代码上传到服务器的部署目录下,记得先在开发环境使用“pip freeze > requirements.txt”命令生成requirements.txt文件

        在服务器上已经激活的虚拟环境里安装依赖:

pip install -r requirements.txt

        4 使用tornado作为wsgi

                在项目中使用tornado模块来创建,示例如下:

        app.py的内容

from flask import Flask

app = Flask(__name__)

@app.route("/")
def hello():
    return "Hello, World!"

run.py的内容

from tornado.wsgi import WSGIContainer
from tornado.httpserver import HTTPServer
from tornado.ioloop import IOLoop
from app import app  # 导入你的Flask应用

http_server = HTTPServer(WSGIContainer(app))
http_server.listen(8000)  # 定义监听的端口
IOLoop.current().start()  # 启动事件循环

        5 运行项目

        用上面的例子,在已经激活的虚拟环境中执行如下命令来运行项目:

python run.py

        这时可以使用   http://ip地址:8000/  来访问。不过该方法的缺点是退出终端窗口后,程序也退出运行。要在后台运行,可以使用nohup命令:

nohup python run.py &

        我的答题系统运行界面如下,真的很简易:

        6 使用nginx作为反向代理

        还可以再在外面加一层反向代理,应该可以让系统更稳定可靠吧。我用的是nginx。

        6.1 安装nginx

sudo apt install nginx

        6.2 配置nginx

‌        创建Nginx配置文件‌,为该项目创建一个单独的Nginx服务器配置文件。

sudo nano /etc/nginx/sites-available/myapp

        这里的“myapp”是自定义的配置文件名称。添加的内容示例:

server {
    listen 80;  #监听端口
    server_name localhost;
    server_name 0.0.0.0;  #对外网开放

    location / {
        proxy_pass http://127.0.0.1:8000;  #转发的网址,即wsgi访问的地址
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

    location /static/ {
        alias /path/to/your/app/static/;
    }
}

        proxy_set_header用来将原始请求的头部信息传递给后端,确保应用能获取正确的客户端ip和主机名‌

        location /static/ 定义了如何处理静态文件的请求。

        alias /path/to/your/app/static/; 表示静态文件的路径。需要将 /path/to/your/app/static/ 替换为你的应用静态文件的实际路径,例如 /home/user/myapp/static/。 这样静态文件的请求就直接在这里发给前端,无需经过后端,减小后端的压力。

        6.3 激活nginx配置

sudo ln -s /etc/nginx/sites-available/myapp /etc/nginx/sites-enabled
sudo nginx -t
sudo systemctl restart nginx

        以上的路径要根据实际情况替换,命令解释如下:

sudo ln -s ...  这个命令创建了一个符号链接,将你的配置文件从 sites-available 目录链接到 sites-enabled 目录,从而启用该配置。

sudo nginx -t  这个命令用于测试 Nginx 配置文件的语法是否正确。如果没有错误,它会输出 syntax is oktest is successful

sudo systemctl restart nginx  这个命令重启 Nginx 服务,使新的配置生效。

        6.4 给nginx分配访问文件的权限

        查看 Nginx 运行用户

ps aux | grep nginx

        通常 Nginx 的工作用户是 www-datanginx

        修改文件夹权限

        将 static 文件夹及其内容的所有者设置为 Nginx 用户,并确保文件夹有读取权限:

sudo chown -R www-data:www-data /path/to/your/static
sudo chmod -R 755 /path/to/your/static

        如果使用的是 nginx 用户,将上述命令中的 www-data 替换为 nginx

        检查父目录权限

        确保所有父目录(如 /path/to/your/)对 Nginx 用户开放执行权限:

sudo chmod o+x /path/to/your

        6.5 nginx的维护

一般情况下nginx服务已经运行了。可以使用“sudo systemctl restart nginx” 重启服务,还可以使用“tail -f /var/log/nginx/error.log”查看错误日志,了解运行情况。

7 后记

        虽然目前并没有使用linux系统的需求,但作为技术储备也好,发觉linux的未来发展前景也罢,总要学习一点的。

        现在部署的答题系统设计的非常简易,代码很少,基本是ai给出的,没有用户管理只支持一个人答题。计划等考完继续升级,不但支持多用户,还要能使用小程序在手机上打开,再在gitcode上开源发布。趁着这个项目,既熟悉linux系统,又能学习小程序开发和发布开源项目,可谓一举多得。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值