百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python框架之Flask教程(二)(flask框架菜鸟教程)

ccwgpt 2024-09-15 15:05 28 浏览 0 评论

一、Flask的数据库SQLAlchemy

1.1 SQLAlchemy简介:

SQLAlchemy是一个关系型数据库框架,它提供了高层的ORM和底层的原生数据库的操作。

flask-sqlalchemy是一个简化了SQLAlchemy操作的flask扩展。


1.2 SQLAlchemy的使用:

1.2.1安装导入: 安装flask_sqlalchemy

from flask import Flask

from flask_sqlalchemy import SQLAlchemy


1.2.2创建flask的app:

app = Flask(__name__)


1.2.3配置SQLAlchemy参数:

class Config(object):

"""配置参数"""

# sqlalchemy的配置参数

SQLALCHEMY_DATABASE_URI = "mysql://root:mysql@127.0.0.1:3306/db_python04"

数据库类型://用户名:密码@数据库地址:端口号/数据库名

# 设置sqlalchemy自动更跟踪数据库

SQLALCHEMY_TRACK_MODIFICATIONS = True


1.2.4添加配置到app:

app.config.from_object(Config)


1.2.5创建数据库sqlalchemy工具对象:

db = SQLAlchemy(app)


1.2.6定义数据库表:

class Role(db.Model):

"""用户角色/身份表"""

__tablename__ = "tbl_roles" #表名


id = db.Column(db.Integer, primary_key=True) #表的主键

name = db.Column(db.String(32), unique=True)

users = db.relationship("User", backref="role")


def __repr__(self):

"""定义之后,可以让显示对象的时候更直观"""

return "Role object: name=%s" % self.name


1.2.7启动函数执行的命令:

if __name__ == '__main__':

# 清除数据库里的所有数据

db.drop_all()


# 创建所有的表

db.create_all()


# 创建对象

role1 = Role(name="admin")

# session记录对象任务

db.session.add(role1)

# 提交任务到数据库中

db.session.commit()



二、数据库迁移

2.1首先要在虚拟环境中安装Flask-Migrate:

pip install flask-migrate


2.2导入相关文件:

from flask_migrate import Migrate,MigrateCommand

from flask_script import Shell,Manager


2.3使用Manager管理我们创建的app:

app = Flask(__name__)

manager = Manager(app)


2.4配置数据库参数,同上1.2.3


2.5使用migrate将配置的数据库与app关联起来:

#第一个参数是Flask的实例,第二个参数是Sqlalchemy数据库实例

migrate = Migrate(app,db)


2.6在flask-Script中的manager中添加一个db命令:

manager.add_command('db',MigrateCommand)


2.7定义模型类,同上1.2.6


2.8运行管理器:

if __name__ == '__main__':

manager.run()


2.9创建迁移仓库,在命令行输入:

#这个命令会创建migrations文件夹,所有迁移文件都放在里面。

python code.py db init


2.10创建迁移脚本,同Django类似,有两个命令:

#创建自动迁移脚本

python code.py db migrate -m 'initial migration' #后面为脚本的备注

#更新数据库

python code.py db upgrade



三、发送邮件

3.1Flask框架使用Flask-Mail扩展包实现发送邮件功能


3.2使用QQ邮箱的smtp服务器:


3.3在代码中导入Flask-Mail扩展包:

from flask_mail import Mail, Message


3.4配置发送邮件需要的参数:

#配置邮件:服务器/端口/传输层安全协议/邮箱名/密码

app.config.update(

DEBUG = True,

MAIL_SERVER='smtp.qq.com',

MAIL_PROT=465,

MAIL_USE_TLS = True,

MAIL_USERNAME = '371673381@qq.com',

MAIL_PASSWORD = 'goyubxohbtzfbidd',

)


3.5关联app:

mail = Mail(app)


3.6在视图函数中的处理:

# sender 发送方,recipients 接收方列表

msg = Message("This is a test ",sender='371673381@qq.com', recipients= ['371673381@qq.com'])

#邮件内容

msg.body = "Flask test mail"


#发送邮件

mail.send(msg)


四、Flask中的蓝图

4.1蓝图简介:蓝图是用于实现单个应用的视图、模板、静态文件的集合


4.2蓝图的初始化:

#Blueprint必须指定两个参数,admin表示蓝图的名称,__name__表示蓝图所在模块

admin = Blueprint('admin',__name__)


4.3注册蓝图路由:

@admin.route('/')

def admin_index():

return 'admin_index'


4.4在程序实例中注册该蓝图:

app.register_blueprint(admin,url_prefix='/admin')


五、单元测试

5.1单元测试的意义:

Web程序开发过程一般包括以下几个阶段:[需求分析,设计阶段,实现阶段,测试阶段]。其中测试阶段通过人工或自动来运行测试某个系统的功能。目的是检验其是否满足需求,并得出特定的结果,以达到弄清楚预期结果和实际结果之间的差别的最终目的。


5.2测试的分类:单元测试、集成测试、系统测试等,其中单元测试是由开发人员进行的


5.3单元测试的方法:开发者编写一小段代码,检验目标代码的功能是否符合预期。通常情况下,单元测试主要面向一些功能单一的模块进行。


5.4单元测试中断言(assert)的使用:

5.4.1常用的断言方法:

assertEqual 如果两个值相等,则pass

assertNotEqual 如果两个值不相等,则pass

assertTrue 判断bool值为True,则pass

assertFalse 判断bool值为False,则pass

assertIsNone 不存在,则pass

assertIsNotNone 存在,则pass


5.5单元测试的基本写法:

5.5.1定义一个类,继承自unittest.TestCase:

import unittest


class TestClass(unitest.TestCase):

#该方法会首先执行,方法名为固定写法

def setUp(self):

pass

#测试代码,函数命名格式一定以test_开头

def test_app_exists(self):

pass

#该方法会在测试代码执行完后执行,方法名为固定写法

def tearDown(self):

pass


六、Flask的部署

6.1Flask部署示意图:


6.2由上图可以看出,Flask部署主要方式是Nginx+gunicorn+flask

其中Gunicorn(绿色独角兽)是一个Python WSGI的HTTP服务器,

优点是Gunicorn直接用命令启动,不需要编写配置文件,相对uWSGI要容易很多。


6.3Gunicorn的安装:pip install gunicorn


6.4运行Gunicorn

#指定进程和端口号: -w: 表示进程(worker)-b:表示绑定ip地址和端口号(bind)。

$gunicorn -w 4 -b 127.0.0.1:5001 运行文件名称:Flask程序实例名


6.5安装Nginx:$sudo apt-get install nginx


6.6nginx的相关指令:先进入/usr/local/nginx/目录

#启动

sudo sbin/nginx

#查看

ps aux | grep nginx

#停止

sudo sbin/nginx -s stop


6.7修改nginx配置:打开/usr/local/nginx/conf/nginx.conf文件


server {

# 监听80端口

listen 80;

# 本机

server_name localhost;

# 默认请求的url

location / {

#请求转发到gunicorn服务器

proxy_pass http://127.0.0.1:5001;

#设置请求头,并将头信息传递给服务器端

proxy_set_header Host $host;

}

}

相关推荐

十分钟让你学会LNMP架构负载均衡(impala负载均衡)

业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...

AGV仓储机器人调度系统架构(agv物流机器人)

系统架构层次划分采用分层模块化设计,分为以下五层:1.1用户接口层功能:提供人机交互界面(Web/桌面端),支持任务下发、实时监控、数据可视化和报警管理。模块:任务管理面板:接收订单(如拣货、...

远程热部署在美团的落地实践(远程热点是什么意思)

Sonic是美团内部研发设计的一款用于热部署的IDEA插件,本文其实现原理及落地的一些技术细节。在阅读本文之前,建议大家先熟悉一下Spring源码、SpringMVC源码、SpringBoot...

springboot搭建xxl-job(分布式任务调度系统)

一、部署xxl-job服务端下载xxl-job源码:https://gitee.com/xuxueli0323/xxl-job二、导入项目、创建xxl_job数据库、修改配置文件为自己的数据库三、启动...

大模型:使用vLLM和Ray分布式部署推理应用

一、vLLM:面向大模型的高效推理框架1.核心特点专为推理优化:专注于大模型(如GPT-3、LLaMA)的高吞吐量、低延迟推理。关键技术:PagedAttention:类似操作系统内存分页管理,将K...

国产开源之光【分布式工作流调度系统】:DolphinScheduler

DolphinScheduler是一个开源的分布式工作流调度系统,旨在帮助用户以可靠、高效和可扩展的方式管理和调度大规模的数据处理工作流。它支持以图形化方式定义和管理工作流,提供了丰富的调度功能和监控...

简单可靠高效的分布式任务队列系统

#记录我的2024#大家好,又见面了,我是GitHub精选君!背景介绍在系统访问量逐渐增大,高并发、分布式系统成为了企业技术架构升级的必由之路。在这样的背景下,异步任务队列扮演着至关重要的角色,...

虚拟服务器之间如何分布式运行?(虚拟服务器部署)

  在云计算和虚拟化技术快速发展的今天,传统“单机单任务”的服务器架构早已难以满足现代业务对高并发、高可用、弹性伸缩和容错容灾的严苛要求。分布式系统应运而生,并成为支撑各类互联网平台、企业信息系统和A...

一文掌握 XXL-Job 的 6 大核心组件

XXL-Job是一个分布式任务调度平台,其核心组件主要包括以下部分,各组件相互协作实现高效的任务调度与管理:1.调度注册中心(RegistryCenter)作用:负责管理调度器(Schedule...

京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?

京东大佬问我,SpringBoot中如何做延迟队列?单机如何做?分布式如何做呢?并给出案例与代码分析。嗯,用户问的是在SpringBoot中如何实现延迟队列,单机和分布式环境下分别怎么做。这个问题其实...

企业级项目组件选型(一)分布式任务调度平台

官网地址:https://www.xuxueli.com/xxl-job/能力介绍架构图安全性为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;调度中心和执...

python多进程的分布式任务调度应用场景及示例

多进程的分布式任务调度可以应用于以下场景:分布式爬虫:importmultiprocessingimportrequestsdefcrawl(url):response=re...

SpringBoot整合ElasticJob实现分布式任务调度

介绍ElasticJob是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目ElasticJob-Lite和ElasticJob-Cloud组成。它通过弹性调度、资源管控、...

分布式可视化 DAG 任务调度系统 Taier 的整体流程分析

Taier作为袋鼠云的开源项目之一,是一个分布式可视化的DAG任务调度系统。旨在降低ETL开发成本,提高大数据平台稳定性,让大数据开发人员可以在Taier直接进行业务逻辑的开发,而不用关...

SpringBoot任务调度:@Scheduled与TaskExecutor全面解析

一、任务调度基础概念1.1什么是任务调度任务调度是指按照预定的时间计划或特定条件自动执行任务的过程。在现代应用开发中,任务调度扮演着至关重要的角色,它使得开发者能够自动化处理周期性任务、定时任务和异...

取消回复欢迎 发表评论: