搭建一个利用docker启动服务的Flask的小demo

定义数据库

# -*- coding: utf-8 -*-

from sqlalchemy import *
from sqlalchemy.orm import (
scoped_session, sessionmaker, relationship, backref
)
from sqlalchemy.ext.declarative import declarative_base # mysql+mysqlconnector://<user>:<password>@<host>[:<port>]/<dbname>
engine = create_engine("mysql+mysqlconnector://root:@localhost:3306/demo", convert_unicode=True)
session = scoped_session(sessionmaker(
autocommit=False, autoflush=False, bind=engine
)) Base = declarative_base()
Base.query = session.query_property() class Department(Base): __tablename__ = "department" id = Column(Integer, primary_key=True)
name = Column(String(50)) class Employee(Base): __tablename__ = "employee" id = Column(Integer, primary_key=True)
name = Column(String(50))
hired_on = Column(DateTime, default=func.now())
department_id = Column(Integer, ForeignKey("department.id"))
department = relationship(
Department,
backref=backref(
"employee",
uselist=True,
cascade="delete,all"
)
)

利用SQLAlchemy定义了两个表,其中Department通过relationship可以关联多个Employee,然后通过python console创建表和数据:

>>> from models import *
>>>
>>>
>>> Base.metadata.create_all(bind=engine)
>>>
>>>
>>> engineering = Department(name="Engineering")
>>> session.add(engineering)
>>> hr = Department(name="Human")
>>> session.add(hr)
>>>
>>>
>>> peter = Employee(name="Peter", department=engine)
engine engine_from_config( engineering
>>> peter = Employee(name="Peter", department=engineering)
>>>
>>> session.add(peter)
>>>
>>>
>>>
>>> roy = Employee(name="Roy", department=engineering)
>>>
>>> session.add(roy)
>>>
>>>
>>> tracy = Employee(name="Tracy", department=hr)
>>>
>>> session.add(tracy)

定义graphql的的Query

# -*- coding: utf-8 -*-

from graphene import relay, ObjectType, Schema
from graphene_sqlalchemy import (
SQLAlchemyConnectionField, SQLAlchemyObjectType
) from models import (
Department as DepartmentModel,
Employee as EmployeeModel
) class Department(SQLAlchemyObjectType): class Meta:
model = DepartmentModel
interfaces = (relay.Node, ) class DepartmentConnections(relay.Connection): class Meta:
node = Department class Employee(SQLAlchemyObjectType): class Meta:
model = EmployeeModel
interfaces = (relay.Node, ) class EmployeeConnections(relay.Connection): class Meta:
node = Employee class Query(ObjectType): node = relay.Node.Field()
all_employees = SQLAlchemyConnectionField(EmployeeConnections)
all_departments = SQLAlchemyConnectionField(DepartmentConnections, sort=None) schema = Schema(query=Query)

首先通过继承SQLAlchemyObjectType类来定义新的查询的类,然后通过relay.Connection来连接所定义的查询类,并且在Query中进行申明,其中我在Connection后面加了一个s是因为在github上看issue的时候发现在构造类的过程中会出现重名的情况导致申明Query的时候会报错,所以加一个s用来避免这个错误。

其中有关graphene的部分我自己也还不是特别熟悉,所以只能是大概说一下自己的思路,如果有错误的地方会在后续中及时的进行修改,避免误人子弟。

最终达到的效果是指定来一个schema,其中包含了我所定义的查询。

本地启动

# -*- coding: utf-8 -*-

from flask import Flask
from flask_graphql import GraphQLView from models import session
from schema import schema app = Flask(__name__)
app.debug = True app.add_url_rule(
"/graphql",
view_func=GraphQLView.as_view(
"graphql",
schema=schema,
graphiql=True
)
) @app.teardown_appcontext
def shutdown_session(exception=None):
session.remove() if __name__ == "__main__":
app.run()

通过Flask的add_url_rule将graph的视图定义成通过路由可访问,然后启动就可以进行访问了,点击http://127.0.0.1:5000/graphql就可以本地访问了。

通过docker启动

  • 建立镜像
# run.docker
FROM python:3.6 COPY . /app WORKDIR /app RUN pip install -r requirements.txt CMD ["python", "app.py"]

这个是我的Dockerfile,通过Dockerfile,我指定了这个镜像是来自于python:3.6这个镜像,然后把我当前目录下的所有内容通过COPY . /app复制到了docker镜像中的/app目录下,接着我指定了WORKDIR/app,这样我就可以在/app目录下进行操作了,首先是安装所有需要的依赖包,因为我是从python3.6拉的镜像,所以可以不用再去安装pip,直接就可以安装了,如果是其他镜像可能还要同构apt去安装pip再进行依赖包的安装,最后就是用CMD来运行文件了。

docker build -t flask_sqlalchemy:core -f run.docker .
# 其中的.是为了指明上下文路径,其实Dockerfile中的命令并不是对本地文件进行操作,而是通过指定上下文路径将这些文件传到docker搭建镜像的环境中再进行操作。

镜像建立之后就可以run了

docker run -d -p 5000:5000 --name flask-core flask_sqlalchemy:lastest

然后就启动了。





Flask+SQLAlchemy+graphene+docker示例的更多相关文章

  1. flask SQLAlchemy中一对多的关系实现

    SQLAlchemy是Python中比较优秀的orm框架,在SQLAlchemy中定义了多种数据库表的对应关系, 其中一对多是一种比较常见的关系.利用flask sqlalchemy实现一对多的关系如 ...

  2. flask, SQLAlchemy, sqlite3 实现 RESTful API 的 todo list, 同时支持form操作

    flask, SQLAlchemy, sqlite3 实现 RESTful API, 同时支持form操作. 前端与后台的交互都采用json数据格式,原生javascript实现的ajax.其技术要点 ...

  3. flask建表遇到的错误: flask,sqlalchemy.exc.OperationalError: (MySQLdb._exceptions.OperationalError) (1071, 'Specified key was too long; max key length is 767 bytes')

    error:flask,sqlalchemy.exc.OperationalError: (MySQLdb._exceptions.OperationalError) (1071, 'Specifie ...

  4. Flask – SQLAlchemy成员增加

    目录 简介 结构 展示 技术 运行 代码 创建数据库表单 views视图 home主页 添加成员addnew.html 展示页show_all 简介 结构 $ tree -I "__pyca ...

  5. flask SQLALchemy外键及约束

    from flask import Flask,session from flask_sqlalchemy import SQLAlchemy import config app = Flask(__ ...

  6. Flask SQLAlchemy & model

    Flask-SQLAlchemy Flask-SQLAlchemy库让flask更方便的使用SQLALchemy,是一个强大的关系形数据库框架,既可以使用orm方式操作数据库,也可以使用原始的SQL命 ...

  7. Docker示例

    运行一个Hello world   zane@zane-V:~$ docker run ubuntu /bin/echo 'Hello world' Unable to find image 'ubu ...

  8. Flask+SQLAlchemy+alembic+Flask-RESTful使用

    前言 其实准备把这篇删掉,先写Flask-restful相关的,后来想想大体框架还是先写出来,这两天踩了很多坑,有的谷歌也没有答案.一直摸索也总算是开始了. 正文 SQLAlchemy/alembic ...

  9. python3 + flask + sqlalchemy +orm(3):多对多关系

    一篇文章有多个tag,一个tag也可以属于多篇文章,文章和tag存在多对多关系 config.py DEBUG = True #dialect+driver://root:1q2w3e4r5t@127 ...

随机推荐

  1. Generator生成器函数执行过程的理解

    一个最基本的Generator函数格式如下,函数体内部要使用yield修饰符则必须在函数名前加上*号 ; function *testYield(x){ console.log('before yie ...

  2. 批量转换文件字符编码(GBK转UTF-8)

    今天收到一份代码,拖到IDE中发现乱码,看来下编码是GBK的(

  3. Spring Security教程之Jsp标签(八)

    目录 1.1     authorize 1.2     authentication 1.3     accesscontrollist Spring Security也有对Jsp标签的支持的标签库 ...

  4. winform 通用自动更新程序

    通用自动更新程序 主要功能: 1. 可用于 C/S 程序的更新,集成到宿主主程序非常简单和配置非常简单,或不集成到主程序独立运行. 2. 支持 HTTP.FTP.WebService等多种更新下载方式 ...

  5. NOI-动规题目集锦

    162:Post Office 解题思路 #include<bits/stdc++.h> using namespace std; ],f[][],mi[][],i,j; int main ...

  6. Laravel文档工具

    laravel-doc ⛵laravel-doc 是一个用来生成文档,通过markdown来撰写文档,并提供web访问文档的项目 安装要求 PHP >= 7.0.0 Laravel >= ...

  7. spring cloud 服务容错保护 - Hystrix

    1.为什么要断路器 在微服务架构中通常会涉及到多个服务间调用,处于调用链路底层的基础服务故障可能会导致级联故障,进而造成整个系统不可用的情况,这种现象被称为服务雪崩效应.服务雪崩效应是一种因“服务提供 ...

  8. python3 根据时间获取本月一号和月末日期

    一.概述 有一个统计报表需求,需要知道上个月的第一天和最后一天,来进行上个月的数据统计. 二.代码实现 #!/usr/bin/env python3 # coding: utf-8 import ca ...

  9. Java学习:Lambda表达式

    Lambda表达式 函数式编程思想概述---强调做什么,而不是以什么形式做 面向对象的思想: 做一件事情,找一个能解决这个的事情的对象,调用对象的方法,完成事情 函数式编程思想 只要能获取到结果,谁去 ...

  10. windows上 nginx 配置代理服务,配置多域名,以及最简单实现跨域配置

    Nginx,不用多说啦,大家都熟悉的不能再熟悉了,它是一款轻量级的高性能Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,最近在本地研究将nginx和resin配合使用,使服务 ...