Flask 系列之 Migration

749711-20190114152131660-1990119250.png

说明

  • 操作系统:Windows 10
  • Python 版本:3.7x
  • 虚拟环境管理器:virtualenv
  • 代码编辑器:VS Code

实验目标

通过使用 flask-migrate 实现数据库的迁移操作

实验

安装环境包

pip install flask
pip install flask-sqlalchemy
pip install flask-migrate

使用示例

示例代码如下所示:

import os
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate

basedir = os.path.abspath(os.path.dirname(__file__))

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + \
    os.path.join(basedir, 'default.sqlite')
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True

db = SQLAlchemy(app)
migrate = Migrate(app, db)

@app.shell_context_processor
def make_shell_context():
    return dict(app=app, db=db, User=User)

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(128))

然后,打开当前项目的虚拟环境窗口,尝试执行下图操作:

set flask_app=manage.py

# 初始化 migration
flask db init

#执行 migration
flask db migrate -m "initialize"

# 更新 migration(注:如果不执行此步,那么我们的变动则无法同步到数据库)
flask db upgrade

如下图所示:

749711-20190408143140090-392904186.png

我们每一次的 Migration 都会有对应的编号,这个编号会同样记录到我们的数据库中的 alembic_version 表中。

以后,当我们的数据模型发生修改的话,我们只需要重复上述的 flask db migrateflask db upgrade 操作即可。

总结

关于 Flask-Migrate 的更多操作,我们可以通过执行 flask db 查看。如下图所示,这里不做过多的解释了。

749711-20190408144114951-875648764.png

相关参考

转载于:https://www.cnblogs.com/hippieZhou/p/10667754.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在计算机领域,live migration(实时迁移)是指在不中断正在运行的虚拟机的情况下将其从一台物理主机迁移到另一台物理主机的过程。这种迁移可以在虚拟机继续运行的同时进行,对用户来说是透明的。 live migration通常用于以下情况: 1. 负载均衡:通过将虚拟机从一个物理主机迁移到另一个物理主机,可以实现负载均衡,从而更好地利用资源。 2. 硬件维护:当需要对物理主机进行维护或升级时,可以将虚拟机迁移到其他物理主机上,以避免服务中断。 3. 故障恢复:当一台物理主机发生故障时,可以将其上的虚拟机迁移到其他正常运行的物理主机上,以实现快速恢复。 在live migration过程中,需要考虑一些参数来控制迁移的行为。其中,live_migration_downtime(实时迁移停机时间)表示迁移过程中虚拟机的停机时间,live_migration_downtime_steps(实时迁移停机时间步长)表示迁移过程中每个步骤的停机时间,live_migration_downtime_delay(实时迁移停机时间延迟)表示在迁移过程中每个步骤之间的延迟时间。 以下是一个live migration的示例代码: ```python live_migration_downtime = 5000 live_migration_downtime_steps = 7 live_migration_downtime_delay = 75 # 进行live migration def live_migration(): # 实现live migration的代码逻辑 pass # 设置live migration参数 def set_live_migration_parameters(downtime, steps, delay): live_migration_downtime = downtime live_migration_downtime_steps = steps live_migration_downtime_delay = delay # 调用live migration函数 live_migration() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值