一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

MySQL與NoSQL——SQL與NoSQL的融合

  寫這一篇內容的原因是MySQL5.6.2突然推出了memcached的功能。NoSQL to InnoDB with Memcached的出現,可以看出NoSQL對關系數據庫的確產生了巨大的影響,個人覺得這是一個非常大的進步,可以讓開發人員更加方便的使用NoSQL和關系數據庫。NoSQL一般被認為性能高于關系數據庫,那么直接在InnoDB之上提供NoSQL功能并和MySQL共存是否是一個更好的選擇呢?

  MySQL with HandlerSocket

  去年在twitter上看到HandlerSocket的出現,并宣稱性能是Memcached的兩倍時,非常令人吃驚,居然可以達到750000qps。接著HandlerSocket成為NoSQL領域談論的焦點之一, 大量的人開始想要嘗試,并做過一些自己的性能測試。 下圖是HandlerSocket的結構圖:

圖1 HandlerSocket結構圖(來源于官方)

  HandlerSocket的出現,給我們眼前一亮的感覺。原來InnoDB的性能已經足夠好,并可以直接提供NoSQL的功能。最大的好處就是可以共享MySQL的功能,DBA以前的經驗一樣可以用。但是有些小小的風險:

  • HandlerSocket沒有與MySQL一起發布版本,因此對于使用MyISAM引擎的用戶是無緣的。不過現在Percona-Server已經集成了HandlerSocket,可以非常方便的使用。
  • 目前大規模的成功案例并不多,國內也只有少部分公司在嘗試,我知道的有飛信開放平臺,據說還不錯。
  • 官方給出的測試數據在應用場景上其實并不充分,至少測試的場景跟我們實際使用的場景相差很大。但是毫無疑問, HandlerSocket的性能比直接使用MySQL肯定要高效得多。

  InnoDB with Memcached

  也許是因為HandlerSocket的火爆的沖擊,也許是受HandlerSocket的啟發,MySQL開始關注NoSQL領域的應用,并在MySQL5.6.2版本增加了通過Memcached協議直接訪問原生Innodb API的功能。

  InnoDB with Memcached是在提供MySQL服務的同一進程中提供Memcached服務 ,這與HandlerSocket的架構模式幾乎是一樣的。雖然目前InnoDB with Memcached還是預覽版本,但是我個人更看好它,因為:

  • 它使用Memcached協議,并同時支持文本和二進制協議,在client的選擇和成熟度上就要勝出許多;
  • 其支持的三種cache模式,不但可以省去開發中使用Memcached來緩存數據的麻煩,并且具有更好的可靠性和數據一致性;
  • 應用程序中,可以使用高效的memcached協議來操作數據,同時也可以使用sql進行復雜的查詢操作;

  注意:目前通過memcached的更新操作不會記錄到binlog中,未來的版本會支持。

圖二 InnoDB with Memcached

Memcached and MySQL Cluster

  顯而易見,我們會想到MySQL Cluster結合Memcached是一個更好的組合,MySQL Cluster提供了99.999%高可用性,并真正提供了去中心化的無縫高可擴展性。還有什么比這更人興奮的呢。

  MySQL已經提供了這樣的功能,源代碼在這里。這里有一個O'Reilly MySql Conference大會的PPT演示,你也可以看下這個功能開發者的一篇博客

圖三 NDB with Memcached

  MySQL Cluster雖然具有高可靠性和無縫擴展的優勢,但是對于復雜SQL查詢的效率卻不能令人滿意。不過對于僅僅依賴于key-value查詢和寫入的海量數據存儲需求,MySQL Cluster with Memcached應該是個很好的選擇。

  總結

  Memcached協議由于其簡單、協議輕量、存在大量的client,所以提供兼容Memcached協議的產品比較占據先天的優勢。

  MySQL提供NoSQL的功能,個人覺得并不是MySQL耐不住寂寞,而是的確在響應用戶的需求。我前面的文章也說過,NoSQL只是一個概念,并不是一個數據庫 產品,MySQL也可以是NoSQL,現在也正應了這句話。NoSQL從架構上就約束了開發者的架構和開發方式,從而提高擴展性和性能,而NoSQL和MySQL的融合,也同時提供了復雜查詢功能。

  雖然MySQL提供了NoSQL功能,如果你要嘗試的話,你的數據庫設計必須從NoSQL從發,然后再考慮SQL查詢功能。

  SQL與NoSQL的融合的確會給開發者帶來方便,比如最近很流行的Mongodb,它吸引開發最大的點就是支持簡單的關系查詢。SQL與NoSQL的融合可能是未來很多數據庫產品的一個趨勢。但是純NoSQL數據庫的優勢也是顯著的,就是他的簡單、高效、易擴展。

it知識庫MySQL與NoSQL——SQL與NoSQL的融合,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 综合成人 | 视频三区 | 欧美午夜性视频 | 丁香六月婷婷七月激情 | 欧美综合激情 | 精品中文字幕一区二区三区四区 | 午夜欧美 | 伊人久久综合网亚洲 | 国产成人91激情在线播放 | 久久aa| 99在线精品日韩一区免费国产 | 春色视频一区二区三区 | 国产成人精品高清在线观看99 | 91久久国产精品 | 香蕉久久一区二区三区 | 午夜在线观看视频在线播放版 | 亚洲人人爱 | 婷婷丁香五月中文字幕 | 国内自拍视频一区二区三区 | 精品极品三级久久久久 | 福利岛国深夜在线 | 国产亚洲视频在线 | 亚洲一二区视频 | 男女男精品视频网站 | 成人福利在线视频 | 天天视频免费入口 | 久久久久777777人人人视频 | 国产成人亚洲毛片 | 成人国产精品免费网站 | 久久青青草原热精品 | 桃花阁成人网在线观看 | 亚洲第一色网站 | 久久精品亚洲精品国产色婷 | 成人午夜精品网站在线观看 | 成年女人免费v片 | 国产精品四虎在线观看免费 | 色优久久| 国产午夜精品一区二区 | 一区二区三区免费在线视频 | 欧美日韩有码 | 优优色影院 |