python-flask项目的服务器线上部署

在部署这部分我首先尝试了宝塔面板,始终连接失败

换了一种思路选择了Xshell成功连接

首先我们需要下载个免费版本的Xshell

免费的:家庭/学校免费 - NetSarang Website

下载完毕打开

1新建->

输入服务器的账号密码:

在所有会话中点击自己刚刚创建的

显示welcome....即为连接成功,到这里服务器的连接就结束了

二、打包flask项目

在 Flask 项目中,打包通常不是指将代码本身打包成一个可执行文件(因为 Flask 是一个 WSGI 应用,它通常运行在 Web 服务器和 WSGI 容器如 Gunicorn、uWSGI 等之上),而是指准备项目的所有必要文件和依赖,以便在其他环境(如生产服务器)上部署。

以下是一个简化的步骤,说明如何使用命令来准备 Flask 项目进行部署:

  1. 创建虚拟环境(如果还没有的话):
    使用 venv(Python 3 内置)或 virtualenv 来创建一个新的虚拟环境。这可以确保你的项目具有它所需要的所有依赖项,并且这些依赖项不会与其他项目冲突。

    python3 -m venv venv
    source venv/bin/activate # 在 Unix 或 MacOS 上
    venv\Scripts\activate # 在 Windows 上
  2. 安装依赖
    在虚拟环境中,使用 pip 安装 Flask 和你的项目所需的所有其他依赖项。这通常通过读取 requirements.txt 文件来完成。

    pip install -r requirements.txt

    如果你的项目还没有 requirements.txt 文件,你可以通过运行 pip freeze > requirements.txt 来生成一个(注意:这可能会包含你所有虚拟环境中的包,所以最好手动创建一个只包含项目依赖的包列表)。

  3. 收集静态文件和模板(如果使用了 Flask-Assets 或类似的库):
    如果你的 Flask 项目使用了如 Flask-Assets 这样的库来处理静态文件(如 CSS 和 JavaScript),你可能需要运行一个命令来收集这些文件到一个目录中,以便在生产环境中服务。

    flask assets build

    注意:这取决于你的项目配置和使用的库。

  4. 配置环境变量
    确保所有的环境变量(如数据库凭据、密钥等)都已正确设置。这可以通过在你的服务器上设置环境变量或使用 .env 文件(配合如 python-decouple 或 python-dotenv 这样的库)来完成。

  5. 打包文件(可选):
    虽然这不是必须的,但你可以将你的 Flask 项目打包成一个压缩文件(如 .tar.gz),以便在其他服务器上部署。这可以通过 tar 命令来完成。

    tar -czvf myflaskapp.tar.gz myflaskapp/

    这里 myflaskapp/ 是你的 Flask 项目目录。

  6. 部署
    将你的 Flask 项目部署到 Web 服务器上。这通常涉及将代码复制到服务器上,配置 Web 服务器(如 Nginx)和 WSGI 容器(如 Gunicorn),然后启动你的 Flask 应用。

  7. 测试
    在部署后,确保测试你的 Flask 应用以确保一切正常工作。

请注意,这些步骤可能因你的具体需求和项目配置而有所不同。例如,你可能需要配置日志记录、错误处理、监控等。此外,对于大型或复杂的项目,你可能还需要考虑使用自动化部署工具(如 Ansible、Docker 等)来简化部署过程。

在这里提示一下,如果报错可以直接不加版本号 python---即可

检查虚拟环境是否创建成功

要检查虚拟环境是否创建成功,您可以按照以下步骤进行:

  1. 确认venv目录存在
    在创建虚拟环境的目录(如您的示例中的C:\Users\wangpaopao\Desktop\lian)中,应该有一个名为venv的新目录。这个目录包含了虚拟环境的所有文件和文件夹。

  2. 检查Scripts目录
    venv目录中,应该有一个名为Scripts的子目录。这个目录包含了激活虚拟环境所需的批处理文件(如activate.bat对于Windows)以及虚拟环境中安装的Python脚本和可执行文件。

  3. 尝试激活虚拟环境
    打开命令提示符或PowerShell,导航到包含venv目录的文件夹,并尝试运行激活脚本。在Windows上,您应该运行venv\Scripts\activate.bat。如果您成功激活了虚拟环境,命令提示符前应该会显示虚拟环境的名称(例如(venv))。

  4. 检查Python版本
    在激活虚拟环境后,运行python --versionpython -V命令。您应该看到虚拟环境中安装的Python版本,而不是系统级别的Python版本。

  5. 检查pip版本
    同样在激活虚拟环境后,运行pip --versionpip -V命令。您应该看到与虚拟环境关联的pip版本。

  6. 尝试安装一个包
    作为最后的验证,您可以尝试在虚拟环境中安装一个Python包,例如pip install requests。如果安装成功,则说明虚拟环境工作正常。

  7. 退出虚拟环境
    在命令提示符中,输入deactivate命令可以退出虚拟环境。退出后,命令提示符前的虚拟环境名称应该会消失。

如果以上步骤都能成功执行,那么您的虚拟环境就已经成功创建了。

虚拟环境中sql遇到的问题

由于 mysql.service 和 mariadb.service 都没有找到,这通常意味着MySQL或MariaDB服务在你的系统上并未安装,或者它们的包名与标准的不同。

不过,既然你找到了 mysql-common 包,这可能意味着系统曾经安装过与MySQL相关的包,但现在主服务并未安装或已卸载。

为了解决这个问题,你可以尝试以下步骤:

  1. 安装MySQL
    如果你想要安装MySQL,可以使用以下命令:

    sudo apt update
    sudo apt install mysql-server

    安装过程中,系统会提示你设置root用户的密码。

  2. 安装MariaDB
    如果你想要安装MariaDB(它是MySQL的一个分支),可以使用以下命令:

    sudo apt update
    sudo apt install mariadb-server

    同样,安装过程中会提示你设置root用户的密码。

  3. 检查服务状态
    安装完成后,你可以使用以下命令来检查MySQL或MariaDB服务的状态:

    对于MySQL:

    sudo systemctl status mysql

    对于MariaDB:

    sudo systemctl status mariadb
  4. 如果仍然找不到服务
    如果安装后仍然找不到服务,可能是你的系统使用了不同的服务名称或者服务并未正确安装。你可以尝试搜索与MySQL或MariaDB相关的服务:

    systemctl list-units --type=service | grep -E 'mysql|mariadb'

    这个命令会列出所有与mysqlmariadb相关的服务。

  5. 检查apt缓存
    你可以检查apt的缓存,看看是否有与MySQL或MariaDB相关的包可供安装:

    apt cache search mysql
    apt cache search mariadb

    这些命令会列出所有与mysqlmariadb相关的可用包。

  6. 阅读安装文档或错误消息
    如果以上步骤都无法解决问题,你可能需要阅读Ubuntu的官方文档或查看安装过程中的错误消息,以获取更多关于为什么服务无法找到的信息。

最后,请确保你的系统是最新的,并且你正在使用的apt包管理器也是最新的。你可以使用以下命令来更新系统和包列表:

sudo apt update
sudo apt upgrade

出现这个页面基本就成功了

我是将自己在小皮面板中创建的数据库进行导入到服务器上

下面是检查方法:

要检查SQL文件是否已成功导入到MySQL数据库中,您可以使用以下几种方法:

  1. 查看MySQL的导入输出
    当您使用mysql命令行工具导入SQL文件时,它会显示导入过程中的信息,包括任何错误或警告。检查这些输出可以帮助您确定导入是否成功。

  2. 登录MySQL并检查数据库和表
    您可以登录到MySQL命令行客户端,然后选择导入的数据库,并检查表是否存在以及它们是否包含数据。

    mysql -u root -p
    # 输入密码后
    USE form;
    SHOW TABLES; # 查看数据库中的表
    DESCRIBE table_name; # 查看表的结构,其中table_name是您的表名
    SELECT * FROM table_name LIMIT 10; # 查看表中的数据

    如果表存在并且包含数据,那么导入很可能是成功的。

  3. 检查数据行数
    如果您知道原始SQL文件中应该有多少行数据,您可以在MySQL中查询以验证。

    SELECT COUNT(*) FROM table_name;

    这将返回表中的数据行数,您可以将其与原始数据进行比较。

  4. 检查日志文件
    如果MySQL服务器配置了日志文件(如错误日志、查询日志等),您可以在这些日志文件中查找与导入相关的任何信息。这可以帮助您诊断任何潜在的问题。

  5. 使用MySQL管理工具
    您可以使用图形界面的MySQL管理工具(如phpMyAdmin、MySQL Workbench等)来连接到MySQL服务器,并检查数据库和表的内容。这些工具通常提供直观的界面来浏览和管理数据库对象。

  6. 验证数据完整性
    如果导入的数据具有特定的完整性约束(如主键、外键、唯一索引等),您可以运行查询来验证这些约束是否得到满足。这可以帮助您确保数据的完整性和准确性。

使用上述方法之一或多种方法,您应该能够验证SQL文件是否已成功导入到MySQL数据库中。

这里可能有个误区:我的服务器中数据库的用户名为:root

能正确显示结构即为部署成功

测试运行

在 Windows 上,如果您已经创建了一个名为 venv 的虚拟环境,并且想要激活它,您需要打开命令提示符(CMD)或 PowerShell,并导航到包含 venv 文件夹的目录。之后,您可以运行 venv\Scripts\activate 脚本来激活虚拟环境。

以下是激活虚拟环境的步骤:

  1. 打开命令提示符(CMD)或 PowerShell。

  2. 使用 cd 命令切换到包含 venv 文件夹的目录。例如,如果 venv 文件夹位于 C:\Users\YourUsername\YourProject 目录下,您可以运行:

    cd C:\Users\YourUsername\YourProject

    请替换 YourUsername 和 YourProject 为您的实际用户名和项目名称。

  3. 激活虚拟环境。在命令提示符或 PowerShell 中,运行:

    venv\Scripts\activate

    这将在命令提示符前添加 (venv) 来指示您当前处于激活的虚拟环境中。

  4. 安装 Flask(如果尚未安装)。在激活的虚拟环境中,运行:

    pip install Flask

    这将使用虚拟环境中的 pip 来安装 Flask。

  5. 运行您的 Flask 应用程序。假设您的应用程序入口点是 app.py,并且您使用 Gunicorn 来运行它,可以运行类似以下命令:

    gunicorn --worker-class sync app:app -b 0.0.0.0:8000

    这里 app:app 表示从 app.py 文件中导入名为 app 的 Flask 实例。

  6. 如果您的 Flask 应用程序正确配置并且没有其他错误,它现在应该可以在指定的端口上运行了。

请注意,如果您使用的是 PowerShell,并且激活虚拟环境时遇到任何问题,可以尝试使用 .\venv\Scripts\activate 来确保 PowerShell 正确解释路径。

如果您在激活虚拟环境或安装 Flask 时遇到任何具体的错误消息,请提供详细信息以便进一步帮助解决问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/683393.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WalleWeb简化你的DevOps部署流程

walle-web:简化部署流程,提升开发效率,Walle Web让DevOps触手可及 - 精选真开源,释放新价值。 概览 Walle Web是一个功能强大且免费开源的DevOps平台,旨在简化和自动化代码部署流程。它支持多种编程语言,包…

学习axios拦截器

axios拦截器的作用:用于在请求发送前和响应返回后对请求和响应进行统一处理,例如添加公共请求头、处理请求参数、统一处理错误信息等。拦截器提供了一种灵活、高效的方式来管理HTTP请求和响应,帮助在前端开发中更好地处理数据交互。 这是一个…

Commons-Collections篇-CC3链

前言 我们分析前两条链CC1和CC6时,都是利用invoke反射调用的Runtime().getRuntime().exec()来执行命令。而很多时候服务器的代码当中的黑名单会选择禁用Runtime CC3链主要通过动态加载类加载机制来实现自动执行恶意类代码 1.环境安装 可以接着使用我们之前分析C…

植物大战僵尸杂交版2.0.88最新版安装包

游戏简介 游戏中独特的杂交植物更是为游戏增添了不少亮点。这些杂交植物不仅外观独特,而且拥有更强大的能力,能够帮助玩家更好地应对游戏中的挑战。玩家可以通过一定的条件和方式,解锁并培养这些杂交植物,从而不断提升自己的战斗…

重大变化,2024软考!

根据官方发布的2024年度计算机技术与软件专业技术资格(水平)考试安排,2024年软考上、下半年开考科目有着巨大变化,我为大家整理了相关信息,大家可以看看! 🎯2024年上半年:5月25日&am…

【动手学深度学习】卷积神经网络(AlexNet)的研究详情

目录 🌊1. 研究目的 🌊2. 研究准备 🌊3. 研究内容 🌍3.1 卷积神经网络(AlexNet) 🌍3.2 练习 🌊4. 研究体会 🌊1. 研究目的 多层感知机模型选择:比较不同…

【devops】 Bytebase 一站式开源 数据库DevOps平台

初识 Bytebase 1、安装 安装地址 https://www.bytebase.com/docs/get-started/self-host/#docker 安装指令 docker run --init \--name bytebase \--publish 8080:8080 --pull always \--volume ~/.bytebase/data:/var/opt/bytebase \bytebase/bytebase:2.18.02、登录-dashboa…

山东大学软件学院项目实训-创新实训-基于大模型的旅游平台(二十七)- 微服务(7)

11.1 : 同步调用的问题 11.2 异步通讯的优缺点 11.3 MQ MQ就是事件驱动架构中的Broker 安装MQ docker run \-e RABBITMQ_DEFAULT_USERxxxx \-e RABBITMQ_DEFAULT_PASSxxxxx \--name mq \--hostname mq1 \-p 15672:15672 \-p 5672:5672 \-d \rabbitmq:3-management 浏览器访问1…

gkuubibiih

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话: 知不足而奋进,望远山而前行&am…

SwiftUI中Menu和ControlGroup的使用

本篇文章主要介绍一下Menu组件和ControlGroup组件的使用。Menu组件是在iOS 14(tvOS 17)推出的一个组件,点击后提供一个可选择的操作列表。ControlGroup组件是一个容器视图,以视觉上适当的方式为给定的上下文显示语义相关的控件&am…

钢基础知识介绍

钢铁是一种铁碳合金,含有一定量的碳和其他合金元素,如硅、锰等。而钢材则是经过加工处理后的钢铁材料,具有更高的强度、硬度、塑性和韧性。钢铁的硬度、强度和耐磨性相对较低,而钢材经过加工处理后,其硬度、强度和耐磨…

训练营第二十七天 | 491.递增子序列46.全排列47.全排列 II332.重新安排行程51. N皇后

491.递增子序列 力扣题目链接(opens new window) 给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2。 示例: 输入: [4, 6, 7, 7]输出: [[4, 6], [4, 7], [4, 6, 7], [4, 6, 7, 7], [6, 7], [6, 7, 7], [7,7], [4,7,7]] 说明: …

企业(园区)智慧能源双碳平台解决方案

园区作为工业企业集聚区,在提供了大量基础设施和公共服务的同时也成为了碳排放的主要源头。工业园区的耗能约占全社会总耗能的69%,碳排放占全国总排放约31%。工业园区节能、减耗、提质、减碳工作的落实,是我国实现碳达峰碳中和目标的必然要求…

关系代数与规范化

本文是根据自己的理解,结合实践整理所得,有兴趣的可以参考学习。

P3. 创建个人中心页面

P3. 创建个人中心页面 0 概述Tips1 个人中心页面1.1 创建 Bot 表及 pojo, mapper1.2 实现 Bot 增删改查的 API1.3 实现个人中心页面前端 0 概述 主要介绍了一下添加一个表(类),及其CRUD的前端和后端的实现方式,介绍的是通用的方法。 后端的CRUD很好写&am…

TCP/IP协议介绍——三次握手四次挥手

TCP/IP(Transmission Control Protocol/Internet Protocol,传输控制协议/网际协议)是指能够在多个不同网络间实现信息传输的协议簇。TCP/IP协议不仅仅指的是TCP 和IP两个协议,而是指一个由FTP、SMTP、TCP、UDP、IP等协议构成的协议…

Capture One Pro 23:专业 Raw 图像处理的卓越之选

在当今的数字摄影时代,拥有一款强大的图像处理软件至关重要。而 Capture One Pro 23 for Mac/Win 无疑是其中的佼佼者,为摄影师和图像爱好者带来了前所未有的体验。 Capture One Pro 23 以其出色的 Raw 图像处理能力而闻名。它能够精准地解析和处理各种…

Priority_queue

一、priority_queue的介绍和使用 1.1 priority_queue的介绍 1.优先队列是一种容器适配器,根据严格的弱排序标准,它的第一个元素总是它所包含的元素中最大的。 2.优先队列类似于堆, 在堆中可以随时插入元素, 并且只能检索最大堆…

React中使用 ts 后,craco库配置别名时需要注意什么?

文章目录 前言编译报错如下解决方式总结 前言 我们都知道craco库可以用来覆盖react配置,如设置别名等。但是在项目使用 Typescript 后,我们需要额外配置,否则会造成编译报错。 详细craco配置可以查看之前文章: 项目初始化与配置…

SpringBoot:SpringBoot中使用Redisson实现分布式锁

一、前言 Redisson是一个在Redis的基础上实现的Java驻内存数据网格(In-Memory Data Grid)。它不仅提供了一系列的分布式的Java常用对象,还提供了许多分布式服务。 刚好项目中需要使用到分布式锁,记录一下Redisson是如何使用分布式…