我的编程空间,编程开发者的网络收藏夹
学习永远不晚

异常排查_Python.[alembic

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

异常排查_Python.[alembic

问题复现:

INFO  [alembic.runtime.migration] Context impl SQLiteImpl.
INFO  [alembic.runtime.migration] Will assume non-transactional DDL.
INFO  [alembic.env] No changes in schema detected.


配置文件:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
#
# Authors: limanman
# 51CTOBG: http://xmdevops.blog.51cto.com/
# Purpose:
#
"""
from __future__ import absolute_import


# 说明: 配置基类
class __Config(object):
    # -- flask-pids
    PID_FILE = 'logs/xmzoomeye-mtr.pid'

    # -- flask-sqlalchemy
    SQLALCHEMY_ECHO = True
    SQLALCHEMY_RECORD_QUERIES = True
    SQLALCHEMY_NATIVE_UNICODE = True
    SQLALCHEMY_TRACK_MODIFICATIONS = True
    SQLALCHEMY_COMMIT_ON_TEARDOWN = True
    SQLALCHEMY_DATABASE_URI = 'sqlite:///app/conf/mtrdata.db'

    @staticmethod
    def init_app(app):
        pass


# 说明: 开发环境
class __DevelopmentConfig(__Config):
    pass


# 说明: 预测环境
class __TestingConfig(__Config):
    pass


# 说明: 正式环境
class __ProductionConfig(__Config):
    pass


config = {
    'default': __DevelopmentConfig,
    'develop': __DevelopmentConfig,
    'testing': __TestingConfig,
    'product': __ProductionConfig,
}


问题排查:

1. 此应用为一个网络检测展示程序,为了简化就没有使用任务队列,直接后端跑一个mtr检测,利用协程的方式不影响前端数据获取和展示

2. 框架写好后发现迁移命令python xmzoomeye-mtr db init时发现flask-migrate竟然没有检测到我定义的表....., 这是什么鬼?

3. 后来无意间看到网上的一段代码突然发现...自己没有在任何一个文件中导入过自定义的表....动手尝试~ 竟然成功.... 原来flask-migrate是检测上下文中db.Model的子类来创建表的...


解决方案:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
#
# Authors: limanman
# OsChina: http://xmdevops.blog.51cto.com/
# Purpose:
#
"""
# 说明: 导入公共模块
from app import db as _db
from app import create_app
# 说明: 为数据库检测
from app.models import Area, Addr, Info
from flask_script import Manager, Command
from flask_migrate import Migrate, MigrateCommand
# 说明: 导入其它模块

app = create_app()
manager = Manager(app)
migrate = Migrate(app, _db)
manager.add_command('db', MigrateCommand)


if __name__ == '__main__':
    manager.run()

说明: 既然检测上下文中的db.Model的子类,所以只要在任意正确位置导入即可被检测到,so~ 为了方便我直接在入口文件中添加了~尝试再次初始化/迁移/升级~


再次创建:

D:\XmDevOps_Py\test\xmzoomeye-mtr>python xmzoomeye-mtr db init
Creating directory D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations ... done
Creating directory D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\versions ... don
e
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\alembic.ini ... done
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\env.py ... done
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\env.pyc ... done
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\README ... done
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\script.py.mako ... done
Please edit configuration/connection/logging settings in 'D:\\XmDevOps_Py\\test\
\xmzoomeye-mtr\\migrations\\alembic.ini' before proceeding.

D:\XmDevOps_Py\test\xmzoomeye-mtr>python xmzoomeye-mtr db migrate
INFO  [alembic.runtime.migration] Context impl SQLiteImpl.
INFO  [alembic.runtime.migration] Will assume non-transactional DDL.
INFO  [alembic.autogenerate.compare] Detected added table 'areas'
INFO  [alembic.autogenerate.compare] Detected added index 'ix_areas_areaname' on
 '['areaname']'
INFO  [alembic.autogenerate.compare] Detected added table 'addrs'
INFO  [alembic.autogenerate.compare] Detected added index 'ix_addrs_addr' on '['
addr']'
INFO  [alembic.autogenerate.compare] Detected added table 'infos'
Generating D:\XmDevOps_Py\test\xmzoomeye-mtr\migrations\versions\e5295ab2586d_.p
y ... done

D:\XmDevOps_Py\test\xmzoomeye-mtr>python xmzoomeye-mtr db upgrade
INFO  [alembic.runtime.migration] Context impl SQLiteImpl.
INFO  [alembic.runtime.migration] Will assume non-transactional DDL.
INFO  [alembic.runtime.migration] Running upgrade  -> e5295ab2586d, empty messag
e



免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

异常排查_Python.[alembic

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

异常排查_Python.[alembic

问题复现:INFO  [alembic.runtime.migration] Context impl SQLiteImpl.INFO  [alembic.runtime.migration] Will assume non-transac
2023-01-31

Java如何排查oom异常

在Java中,OOM(Out of Memory)异常通常是由于程序尝试分配的内存超出了虚拟机的限制而导致的。以下是一些排查OOM异常的常见方法:1. 检查内存使用情况:使用Java内存分析工具,如jconsole、jvisualvm等,可
2023-10-10

linux堆栈异常怎么排查

要排查Linux堆栈异常,可以采取以下步骤:查看系统日志:使用命令`dmesg`或`journalctl`来查看系统日志,查找任何与堆栈异常相关的错误或警告消息。查看核心转储文件:如果系统崩溃或出现堆栈异常导致的崩溃,可以查看核心转储文件
2023-10-27

linux网卡异常怎么排查

当Linux网卡出现异常时,以下是一些排查步骤:检查物理连接:确保网线连接正确,插头没有松动或损坏。检查网络配置:使用ifconfig命令或ip命令检查网卡是否正确配置了IP地址、子网掩码和网关。检查网卡状态:使用ifconfig或ip命令
2023-10-25

Spring Boot怎么排查 java.lang.ArrayStoreException异常

这篇文章主要讲解了“Spring Boot怎么排查 java.lang.ArrayStoreException异常”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Spring Boot怎么排查
2023-06-22

amqp协议链接异常怎么排查

这篇文章主要介绍“amqp协议链接异常怎么排查”,在日常操作中,相信很多人在amqp协议链接异常怎么排查问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”amqp协议链接异常怎么排查”的疑惑有所帮助!接下来,请跟
2023-06-29

Java oom异常的原因怎么排查

Java中的OOM(Out Of Memory)异常通常由以下几个原因引起:内存泄漏:当对象被创建后,如果没有被及时释放,就会导致内存泄漏。可以通过使用内存分析工具(如Eclipse Memory Analyzer)来检测内存泄漏,并找到泄
2023-10-23

linux异常关机问题如何排查

要排查Linux异常关机问题,可以按照以下步骤进行:1. 检查系统日志:查看/var/log目录下的日志文件,特别是syslog和kern.log文件,看是否有任何异常或错误信息。可以使用命令如下:```sudo tail -n 100 /
2023-08-31

Discuz登录异常?快速排查故障!

抱歉,我无法提供有关如何对 Discuz 登录异常进行快速排查的具体代码示例。但我可以帮助提供一些指导,您可以在文章中参考。Discuz 是一个开源的论坛程序,有时会出现登录异常的情况。当用户遇到这种问题时,我们可以采取一些步骤来排查故障
Discuz登录异常?快速排查故障!
2024-03-11

PHP启动异常的排查与修复

PHP是一种常用的服务器端脚本语言,广泛应用于Web开发领域。在开发和部署过程中,有时会遇到PHP启动异常的情况,造成网站无法正常访问。本文将介绍PHP启动异常的可能原因,并提供具体的代码示例来帮助排查和修复这些问题。1. PHP启动异常
PHP启动异常的排查与修复
2024-03-12

SIGPIPE(Signal 13, Code 0) 异常排查及处理

这篇文章主要为大家介绍了SIGPIPE(Signal 13, Code 0) 异常排查原因解析及处理详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-29

如何解决j2Cache线上异常排查问题

这篇文章主要为大家展示了“如何解决j2Cache线上异常排查问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决j2Cache线上异常排查问题”这篇文章吧。问题背景开发反馈,线上有个服务在
2023-06-29

linux中如何排查CPU与Load异常问题

这篇文章主要介绍了linux中如何排查CPU与Load异常问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、top命令既然说了cpu和load,那总需要监控吧,没有监控就
2023-06-15

Oracle用户登录异常,故障排查攻略

故障排查攻略:Oracle用户登录异常在进行数据库管理与运维过程中,Oracle作为一款广泛使用的数据库管理系统,经常会遇到用户登录异常的情况,可能会给数据库管理带来一定的困扰。因此,本文将分享Oracle用户登录异常的排查攻略,并提供具
Oracle用户登录异常,故障排查攻略
2024-03-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录