宝塔(BT面板)部署Python项目图形化完整步骤

 更新时间:2025年12月01日 09:08:34   作者:wow_DG  
这篇文章主要介绍了宝塔(BT面板)部署Python项目的完整步骤,包括安装宝塔面板、创建Python运行环境、上传项目代码、安装依赖、配置反向代理、设置静态文件和跨域等步骤,需要的朋友可以参考下

适用于:Linux 服务器(Ubuntu/CentOS 等)+ 宝塔面板(Linux 版)。全程 GUI 操作为主, FastAPI 可复制配置。

一、准备工作

  • 一台云服务器(推荐:Ubuntu 20.04/22.04 或 CentOS 7/8)。
  • 放通安全组端口:22(SSH)、8888(面板首次登录口)、80/443(网站)。
  • 有域名并完成解析(可选,用于 HTTPS)。

二、安装宝塔面板(一次性命令)

这一步需 SSH 进入服务器;安装成功后其余基本用 GUI。若下述命令失效,请到宝塔官网下载最新脚本。

# Ubuntu/Debian 常见
wget -O install.sh http://download.bt.cn/install/install_6.0.sh && bash install.sh

# CentOS 常见
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && bash install.sh

安装完成后终端会显示:面板地址(如 http://你的IP:8888)、初始账号/密码或初始化向导。若 8888 访问不到,检查云安全组与系统防火墙。

查看宝塔面板信息命令

bt default

运行后会显示类似如下信息:

外网面板地址: http://xxx.xxx.xxx.xxx:8888/xxxxxx
内网面板地址: http://xxx.xxx.xxx.xxx:8888/xxxxxx
username: xxxxxxxx
password: xxxxxxxx

三、首次进入宝塔面板(GUI)

  1. 浏览器打开 http://你的IP:8888
  2. 设置面板账号与密码。建议:
    • 修改默认端口(面板设置里)
    • 开启二次验证登录提醒
  3. 进入软件商店安装常用组件:
    • Nginx
    • Python 项目管理器 / Python 管理
    • (按需)MySQLRedis
    • (站点里内置)Let’s Encrypt 证书

四、创建 Python 运行环境(GUI)

  1. 打开软件商店 → Python 管理,安装所需 Python 版本(如 3.8/3.10/3.11)。
  2. 打开Python 项目管理器,点击创建虚拟环境,选择上面安装的 Python 版本,命名如 venv-fastapi

五、上传或获取项目代码(GUI)

  • 方式一(上传压缩包):面板 文件 → 上传 → 解压到 /www/wwwroot/your_project
  • 方式二(Git 拉取):在面板终端或 Git 插件中执行 git clone 到上述目录

建议目录(FastAPI 示例):

/www/wwwroot/your_project
├─ app/
│  └─ main.py           # 入口(app = FastAPI())
├─ requirements.txt
└─ .env                 # 可选,存放环境变量

六、安装依赖(GUI)

进入 Python 项目管理器 → 虚拟环境 → 选择 venv,点击安装依赖,选择项目 requirements.txt

国内环境可改为国内 PyPI 源以加速。

七、用“Python 项目管理器”创建运行项目

  1. 新增项目,填写:
    • 项目名称fastapi-demo(示例)
    • 项目路径/www/wwwroot/your_project
    • 运行用户www
    • 虚拟环境:选择你的 venv(如 venv-fastapi
    • 启动方式:ASGI(FastAPI/Starlette)或 WSGI(Flask/Django)
    • 启动命令:见附录(不同框架不同)
    • 开机自启:勾选
  2. 点击保存并启动,应看到“运行中”。失败请查看项目日志

八、用 Nginx 反向代理到外网域名(含 SSL)

  1. 网站 → 添加站点
    • 域名yourdomain.com
    • 网站目录:任意(若仅反代,可为空目录)
  2. 进入站点设置 → 反向代理
    • 目标 URLhttp://127.0.0.1:8000
    • 勾选启用反向代理
  3. 站点 → SSL
    • 选择 Let’s Encrypt,验证域名并签发
    • 开启强制 HTTPS

此时访问 https://yourdomain.com 即转发到后端服务。

九、静态文件与跨域(可选)

静态文件(Nginx)

location /static/ {
    alias /www/wwwroot/your_project/app/static/;
    expires 30d;
    access_log off;
}

跨域(后端或 Nginx):FastAPI 可用 CORS 中间件;或在 Nginx 添加响应头按需处理。

十、环境变量与密钥(可选)

  • 在“项目 → 启动命令”前添加:
    export ENV=prod SECRET_KEY='your-secret' && gunicorn ...
    
  • 或放 .env,配合 python-dotenv 读取。

十一、日志监控与开机自启

  • Python 项目管理器 → 日志 查看启动/错误日志。
  • 运行状态观察资源使用。
  • 勾选开机自启即可随系统启动。

十二、数据库与 Redis(可选)

  • 软件商店安装 MySQL/Redis。
  • 数据库菜单新建库与用户,将连接信息配置进项目。

十三、常见问题速查

  1. 面板打不开:检查 8888 端口、云安全组与系统防火墙。
  2. 项目启动失败/502:确认虚拟环境与依赖、启动命令模块路径是否正确,查看项目日志。
  3. 超时/504:业务阻塞或 worker 较少,适当提高 --workers、检查数据库/外部依赖。
  4. 依赖安装失败:切换国内源;有的库需系统依赖(如 build-essentialpython3-devlibmysqlclient-dev)。
  5. HTTPS 失败:确保域名解析到当前服务器,80/443 放通且未被占用。

附录 A:FastAPI 可复制配置

假设:Python 3.8.19、项目在 /www/wwwroot/your_project

目录与示例代码

/www/wwwroot/your_project
├─ app/
│  └─ main.py
├─ requirements.txt
└─ .env   (可选)

app/main.py

from fastapi import FastAPI
app = FastAPI()

@app.get("/")
def hello():
    return {"msg": "Hello from FastAPI on Baota!"}

requirements.txt

fastapi
uvicorn
gunicorn
python-dotenv

Python 项目管理器表单

  • 项目名称:fastapi-demo
  • 项目路径:/www/wwwroot/your_project
  • 运行用户:www
  • 虚拟环境:选择已创建的 venv(基于 Python 3.8.19)
  • 启动方式:ASGI / 自定义命令
  • 启动命令:
    gunicorn -k uvicorn.workers.UvicornWorker app.main:app -b 127.0.0.1:8000 --workers 2 --timeout 60
    
  • 开机自启:勾选

Nginx 反代(站点 → 反向代理)

  • 目标 URL:http://127.0.0.1:8000
  • 启用反向代理:勾选
    (SSL 在站点 → SSL 里申请并开启“强制 HTTPS”)

静态(可选)

location /static/ {
    alias /www/wwwroot/your_project/app/static/;
    expires 30d;
    access_log off;
}

总结 

到此这篇关于宝塔(BT面板)部署Python项目的文章就介绍到这了,更多相关宝塔部署Python项目内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python+Pygame实现简单的射击小游戏

    Python+Pygame实现简单的射击小游戏

    要说什么游戏能够获得大家的喜爱,唯射击游戏莫属!本文将利用Python和Pygame库制作一个简单的射击小游戏,感兴趣的小伙伴可以了解一下
    2022-04-04
  • python GUI库图形界面开发之PyQt5中QMainWindow, QWidget以及QDialog的区别和选择

    python GUI库图形界面开发之PyQt5中QMainWindow, QWidget以及QDialog的区别和选择

    这篇文章主要介绍了python GUI库图形界面开发之PyQt5中QMainWindow, QWidget以及QDialog的区别和选择,需要的朋友可以参考下
    2020-02-02
  • python 自动刷新网页的两种方法

    python 自动刷新网页的两种方法

    这篇文章主要介绍了python 自动刷新网页的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • TensorFlow平台下Python实现神经网络

    TensorFlow平台下Python实现神经网络

    这篇文章主要为大家详细介绍了TensorFlow平台下Python实现神经网络,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • 详解pytorch的多GPU训练的两种方式

    详解pytorch的多GPU训练的两种方式

    本文主要介绍了详解pytorch的多GPU训练的两种方式,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Python多图片合并PDF的方法

    Python多图片合并PDF的方法

    今天小编就为大家分享一篇关于Python多图片合并PDF的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 如何用GAN训练自己的数据生成新的图片

    如何用GAN训练自己的数据生成新的图片

    这篇文章主要介绍了如何用GAN训练自己的数据生成新的图片问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • django迁移文件migrations的实现

    django迁移文件migrations的实现

    这篇文章主要介绍了django迁移文件migrations的实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • python实现FFT快速傅立叶变换算法案例

    python实现FFT快速傅立叶变换算法案例

    FFT(快速傅里叶变换)是计算DFT及其逆变换的一种算法,其基本思想是利用DFT的对称性和周期性,通过分而治之的策略将DFT分解为更小的DFT,从而降低计算复杂度,FFT的算法步骤包括选择分解、重新排序、蝶形运算和逐层计算,在Python中
    2024-10-10
  • python 全角半角互换的实现示例

    python 全角半角互换的实现示例

    角、半角的的不一致会导致信息抽取不一致,本文主要介绍了python 全角半角互换的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03

最新评论