以下是我在部署基于 Streamlit 开发的 Python 项目时候遇到的一些问题。

一、打开外网映射,但端口未显示

1.1 排查

1. Nginx 配置

  • 检查宝塔 Nginx 是否正常启动,无报错重启;
  • 确认 Nginx 代理配置中,绑定的端口与 Streamlit 启动端口完全一致
  • 检查代理路径、反向代理规则是否配置正确。

2. 检查防火墙/安全组端口是否放行

  • 宝塔面板:安全 → 防火墙,放行 Streamlit 使用的端口(如 8501);
  • 腾讯云:额外添加入站规则,放行对应端口;
  • 本地服务器防火墙:关闭或放行指定端口。

3. 安装的库版本不兼容!

        宝塔部署Python项目时,优先用固定版本号安装依赖,不要用 --upgrade直接升级到最新版。例如项目根目录创建requirements.txt,锁定所有依赖版本,避免环境混乱:

(例)requirements.txt:

numpy==1.26.4

pandas==2.2.2

streamlit==1.35.0

小注意点:

服务器部署OpenCV项目,优先安装opencv-python-headless,不要用完整版(opencv-python)

二、显示use_container_width 用不了问题

streamlit 的导入: import streamlit as st       

         use_container_width 是Streamlit 1.30.0+ 版本才新添的参数(图片自适应参数),如果Streamlit 的版本低于这个,就会导致图片加载失败而导致报错。

1. 解决法1

        升级Streamlit 版本。

streamlit不同组件的参数
组件 支持的宽度相关参数 不支持的参数
st.image() width=0 / use_container_width=True
st.button() width/ use_container_width
st.container() border

2. 解决法2

        直接修改代码—>找到所有使用 “st.image()” 并且带有  “use_container_width=True” 的代码块,移除掉:use_container_width=True 

三、网页的图表文字未正常显示

        图表不显示文字、中文变方框。

3.1 排查问题:

1. Linux服务器没有配备正确的中文字体

2. 图表元素没有强制绑定中文字体,导致全局配置不生效

3.2 解决:直接嵌入字体文件!

1)从你的本地Windows电脑,复制 C:/Windows/Fonts/simhei.ttf(黑体),其他字体也行;

        可以把它复制粘贴到桌面先,方便一会儿上传到宝塔项目文件根目录。

2)通过宝塔面板,上传到你要部署的项目根目录,和 .py文件 同文件夹

3)代码里面使用

import matplotlib
import matplotlib.pyplot as plt
from pathlib import Path

# 字体文件路径 = 项目根目录的 simhei.ttf
FONT_PATH = "/www/wwwroot/代码/simhei.ttf"    # 这个是我的项目目录

# 使用项目内字体
matplotlib.rcParams['font.sans-serif'] = [FONT_PATH]
matplotlib.rcParams['axes.unicode_minus'] = False
matplotlib.rcParams['font.family'] = 'sans-serif'
matplotlib.rcParams['font.size'] = 10

注意:上面代码是在全局定义的,我们要注意和局部使用对上,在后面代码要使用上图表的位置处,我们可以直接把字体路径写在图表里。

from matplotlib.font_manager import FontProperties

# 字体绝对路径
font = FontProperties(fname='/www/wwwroot/你的项目目录/simhei.ttf', size=12)

# 绘图时指定字体
plt.title("图表标题", fontproperties=font)
plt.xlabel("X轴", fontproperties=font)
plt.ylabel("Y轴", fontproperties=font)

Ctrl+Shift+R:浏览器强制刷新(Windows/Linux)

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐