Python使用SQLAlchemy訪問MemFireDB

之前看到一個(gè)帖子說的挺好甥捺,項(xiàng)目開發(fā)盡量不要自己造輪子兆衅,能用開源項(xiàng)目或者SAAS服務(wù)盡量用烛谊,很多事情都是跟時(shí)間賽跑风响。

最近在體驗(yàn) MemFire Cloud,如果大家有個(gè)人項(xiàng)目或者公司內(nèi)部測試項(xiàng)目丹禀,推薦大家嘗試一下状勤,挺方便的,不用自己搭建數(shù)據(jù)庫双泪,在家或者公司隨時(shí)可以訪問持搜,這是我的邀請碼:hm2tJQ hm3U69

SQLAlchemy是Python中最常用的訪問數(shù)據(jù)庫的ORM庫,MemFireDB兼容Postgres接口焙矛,所以可以直接把MemFireDB當(dāng)Postgres使用葫盼。

https://memfiredb.com上創(chuàng)建數(shù)據(jù)庫時(shí),可以選擇創(chuàng)建密碼或者證書兩種認(rèn)證模式村斟,在公網(wǎng)上部署的數(shù)據(jù)庫贫导,如果存儲(chǔ)的是比較重要的數(shù)據(jù),建議使用證書認(rèn)證模式蟆盹,該模式安全系數(shù)要高很多孩灯,撞庫、彩虹表逾滥、暴力破解等傳統(tǒng)的密碼破解方式對證書認(rèn)證是無能為力的峰档。如果只是簡單測試,可以使用密碼認(rèn)證方式寨昙,這種方式配置簡單些讥巡。

言歸正傳,下面是SQLAlchemy使用證書連接MemFireDB的例子舔哪,創(chuàng)建完數(shù)據(jù)庫后欢顷,把下載的證書解壓到代碼同級的目錄就可以了,記得將host尸红、port吱涉、dbname、dbuser設(shè)置為對應(yīng)的值:

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

import sys

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
import sqlalchemy.engine.url as url


Base = declarative_base()


class Counter(Base):
    __tablename__ = 'counters'

    id = Column(Integer, primary_key=True)
    counter = Column(Integer)


engine = None


def init_db_engine(host, port, dbname, user, ssl_ca, ssl_cert, ssl_key):
    global engine
    uri = url.URL(
        drivername="postgresql",
        host=host,
        port=port,
        username=user,
        database=dbname,
    )

    ssl_args = {
        "sslmode": "verify-ca",
        "sslrootcert": ssl_ca,
        "sslcert": ssl_cert,
        "sslkey": ssl_key
    }
    print ssl_args
    engine = create_engine(uri, connect_args=ssl_args, encoding='utf-8', echo=False,
                           pool_size=100, pool_recycle=3600, pool_pre_ping=True)


def get_session():
    global engine
    SessionCls = sessionmaker(bind=engine)
    return SessionCls()


def main():
    host = sys.argv[1]
    port = int(sys.argv[2])
    dbname = sys.argv[3]
    dbuser = sys.argv[4]

    init_db_engine(host, port, dbname, dbuser, './root.crt', './memfiredb.crt', './memfiredb.key')
    Base.metadata.create_all(engine)

    session = get_session()
    session.execute('delete from counters')
    cnt = Counter(counter=1)
    session.add(cnt)
    session.commit()
    session.close()


if __name__ == '__main__':
    main()
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末外里,一起剝皮案震驚了整個(gè)濱河市怎爵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌盅蝗,老刑警劉巖鳖链,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡芙委,警方通過查閱死者的電腦和手機(jī)逞敷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來灌侣,“玉大人推捐,你說我怎么就攤上這事〔嗵洌” “怎么了牛柒?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長痊乾。 經(jīng)常有香客問我皮壁,道長,這世上最難降的妖魔是什么哪审? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任蛾魄,我火速辦了婚禮,結(jié)果婚禮上湿滓,老公的妹妹穿的比我還像新娘滴须。我一直安慰自己,他們只是感情好茉稠,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布描馅。 她就那樣靜靜地躺著,像睡著了一般而线。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上恋日,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天膀篮,我揣著相機(jī)與錄音,去河邊找鬼岂膳。 笑死誓竿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谈截。 我是一名探鬼主播筷屡,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼簸喂!你這毒婦竟也來了毙死?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤喻鳄,失蹤者是張志新(化名)和其女友劉穎扼倘,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體除呵,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡再菊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年爪喘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纠拔。...
    茶點(diǎn)故事閱讀 39,932評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秉剑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出稠诲,到底是詐尸還是另有隱情秃症,我是刑警寧澤,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布吕粹,位于F島的核電站种柑,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏匹耕。R本人自食惡果不足惜聚请,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望稳其。 院中可真熱鬧驶赏,春花似錦、人聲如沸既鞠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嘱蛋。三九已至蚯姆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間洒敏,已是汗流浹背龄恋。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留凶伙,地道東北人郭毕。 一個(gè)月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像函荣,于是被迫代替她去往敵國和親显押。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容