engine.py 4.41 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
# -*- encoding: utf-8 -*-
# -----------------------------------------------------------------------------
# @File Name  : app.py
# @Time       : 2020/11/18 下午12:45
# @Author     : X. Peng
# @Email      : acepengxiong@163.com
# @Software   : PyCharm
# -----------------------------------------------------------------------------


import logging
import redis
import os
import sys
import yaml
from sqlalchemy import create_engine
赵杰's avatar
赵杰 committed
17
from sqlalchemy.orm import sessionmaker, scoped_session
18 19 20 21 22 23 24

env = sys.argv[-1]
work_dir = os.getcwd()
CFG_FILEPATH = work_dir + '/app/config/config.yaml'

config = yaml.load(open(CFG_FILEPATH, 'r'), Loader=yaml.FullLoader)

pengxiong's avatar
pengxiong committed
25
temp_img_save_folder = work_dir + '/app/templates/temp_img/productionenv/ReportTempImg/'
pengxiong's avatar
pengxiong committed
26
pdf_save_folder = work_dir + '/app/pdf/productionenv/AppHoldReport/'
27 28
template_folder = config[env]['oss']['imgs_url_prefix']
pdf_folder = config[env]['oss']['pdf_url_prefix']
29 30

tamp_product_engine = create_engine(
31
    'mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset={charset}'.format(
32
        db=config[env]['MySQL']['tamp_product_db'],
33 34 35 36
        host=config[env]['MySQL']['host'],
        port=config[env]['MySQL']['port'],
        user=config[env]['MySQL']['user'],
        password=config[env]['MySQL']['password'],
37 38 39 40 41 42
        charset="utf8"
    ),
    max_overflow=0,  # 超过连接池大小外最多创建的连接
    pool_size=100,  # 连接池大小
    pool_timeout=5,
    pool_recycle=600
43
)
44
tamp_order_engine = create_engine(
45
    'mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset={charset}'.format(
46
        db=config[env]['MySQL']['tamp_order_db'],
47 48 49 50
        host=config[env]['MySQL']['host'],
        port=config[env]['MySQL']['port'],
        user=config[env]['MySQL']['user'],
        password=config[env]['MySQL']['password'],
51 52 53 54 55 56
        charset="utf8"
    ),
    max_overflow=0,  # 超过连接池大小外最多创建的连接
    pool_size=100,  # 连接池大小
    pool_timeout=5,
    pool_recycle=600
57
)
58 59

tamp_user_engine = create_engine(
60
    'mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset={charset}'.format(
61 62 63 64 65 66
        db=config[env]['MySQL']['tamp_user_db'],
        host=config[env]['MySQL']['host'],
        port=config[env]['MySQL']['port'],
        user=config[env]['MySQL']['user'],
        password=config[env]['MySQL']['password'],
        charset="utf8"
67 68 69 70 71
    ),
    max_overflow=0,  # 超过连接池大小外最多创建的连接
    pool_size=100,  # 连接池大小
    pool_timeout=5,
    pool_recycle=600
72
)
李宗熹's avatar
李宗熹 committed
73 74

tamp_fund_engine = create_engine(
75
    'mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset={charset}'.format(
李宗熹's avatar
李宗熹 committed
76 77 78 79 80 81
        db=config[env]['MySQL']['tamp_fund_db'],
        host=config[env]['MySQL']['host'],
        port=config[env]['MySQL']['port'],
        user=config[env]['MySQL']['user'],
        password=config[env]['MySQL']['password'],
        charset="utf8"
pengxiong's avatar
pengxiong committed
82 83 84 85 86
    ),
    max_overflow=0,  # 超过连接池大小外最多创建的连接
    pool_size=100,  # 连接池大小
    pool_timeout=5,
    pool_recycle=600
wang zhengwei's avatar
wang zhengwei committed
87
)
88

赵杰's avatar
赵杰 committed
89 90 91 92 93 94 95 96 97 98 99 100
tamp_diagnose_app_engine = create_engine(
    'mysql+mysqldb://{user}:{password}@{host}:{port}/{db}?charset={charset}'.format(
        db=config[env]['MySQL']['tamp_diagnose_app_db'],
        host=config[env]['MySQL']['host'],
        port=config[env]['MySQL']['port'],
        user=config[env]['MySQL']['user'],
        password=config[env]['MySQL']['password'],
        charset="utf8"
    )
)


pengxiong's avatar
pengxiong committed
101 102 103
redis = redis.StrictRedis(
    host=config[env]['redis']['host'],
    port=config[env]['redis']['port'],
pengxiong's avatar
pengxiong committed
104 105
    db=config[env]['redis']['db'],
    password=config[env]['redis']['password']
pengxiong's avatar
pengxiong committed
106
)
107 108

logging.basicConfig(level=logging.INFO,
pengxiong's avatar
pengxiong committed
109 110
                    filename=work_dir + config[env]['log']['filename'],
                    filemode=config[env]['log']['filemode'],
111 112 113 114
                    format=config[env]['log']['format'],
                    datefmt=config[env]['log']['datefmt']
                    )

李宗熹's avatar
李宗熹 committed
115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
class TAMP_SQL(object):
    """[sqlalchemy 封装]

    Args:
        object ([type]): [description]

    Returns:
        [type]: [description]
    """

    def __init__(self, db_engine):
        # 创建DBSession类型:
        self.DBSession = scoped_session(sessionmaker(bind=db_engine))
        self.session = self.DBSession()

    def __enter__(self):
        return self

    def __exit__(self, exc_type, exc_val, exc_tb):
        try:
            self.session.commit()
        except:
            self.session.rollback()
        finally:
            self.session.close()