一、Nosql與Hadoop、Voldemort、Dynamo之間關(guān)系是怎樣的
Nosql是非關(guān)系數(shù)據(jù)庫。Voldemort和Dynamo都是鍵值數(shù)據(jù)庫,屬于NoSQL的一種。Hadoop是一個生態(tài)圈,一套開源項目,其中的子項目HBase和這些來比較才有意義。HBase是列式數(shù)據(jù)庫。也是NOSQL的一種。Dynamo和Voldemort的架構(gòu)類似,主要屬于Leader-less的分布式數(shù)據(jù)庫。
Hadoop是計算系統(tǒng),核心存儲是HDFS,屬于一種分布式文件系統(tǒng)。
Dynamo是亞馬遜發(fā)明的一種鍵值存儲系統(tǒng),但是只有論文沒有代碼。
Voldemort是Linkedin發(fā)布的一種Dynamo的具體實現(xiàn)方法,是開源的,在http://www.project-voldemort.com可以看到。
Voldemort有一種數(shù)據(jù)庫結(jié)構(gòu)支持將Hadoop的計算結(jié)果快速的建成只讀數(shù)據(jù)庫文件,叫做BuildAndPush供在線查詢。
延伸閱讀:
二、Django 是什么
Django 是一個高級的 Python 網(wǎng)絡(luò)框架,可以快速開發(fā)安全和可維護的網(wǎng)站。由經(jīng)驗豐富的開發(fā)者構(gòu)建,Django 負責處理網(wǎng)站開發(fā)中麻煩的部分,因此你可以專注于編寫應(yīng)用程序,而無需重新開發(fā)。 它是免費和開源的,有活躍繁榮的社區(qū),豐富的文檔,以及很多免費和付費的解決方案。
Django 可以使你的應(yīng)用具有以下優(yōu)點:
完備性
Django 遵循“功能完備”的理念,提供開發(fā)人員可能想要“開箱即用”的幾乎所有功能。因為你需要的一切都是一個”產(chǎn)品“的一部分,它們都可以無縫結(jié)合在一起,遵循一致性設(shè)計原則,并且具有廣泛和最新的文檔。
通用性
Django 可以(并已經(jīng))用于構(gòu)建幾乎任何類型的網(wǎng)站—從內(nèi)容管理系統(tǒng)和維基,到社交網(wǎng)絡(luò)和新聞網(wǎng)站。它可以與任何客戶端框架一起工作,并且可以提供幾乎任何格式(包括 HTML,Rss 源,JSON,XML 等)的內(nèi)容。你正在閱讀的網(wǎng)站就是基于 Django。
在內(nèi)部,盡管它為幾乎所有可能需要的功能(例如幾個流行的數(shù)據(jù)庫,模版引擎等)提供了選擇,但是如果需要,它也可以擴展到使用其他組件。
安全性
Django 幫助開發(fā)人員通過提供一個被設(shè)計為“做正確的事情”來自動保護網(wǎng)站的框架來避免許多常見的安全錯誤。例如,Django 提供了一種安全的方式來管理用戶賬戶和密碼,避免了常見的錯誤,比如將 session 放在 cookie 中這種易受攻擊的做法(取而代之的是 cookies 只包含一個密鑰,實際數(shù)據(jù)存儲在數(shù)據(jù)庫中)或直接存儲密碼而不是密碼哈希。
密碼哈希是通過密碼散列函數(shù)發(fā)送密碼而創(chuàng)建的固定長度值。Django 能通過運行哈希函數(shù)來檢查輸入的密碼 – 就是 – 將輸出的哈希值與存儲的哈希值進行比較是否正確。然而由于功能的“單向”性質(zhì),即時存儲的哈希值受到威脅,攻擊者也難以解決原始密碼。(但其實有彩虹表 – 譯者觀點)
默認情況下,Django 可以防范許多漏洞,包括 SQL 注入,跨站點腳本,跨站點請求偽造和點擊劫持。