MongoDB

(面試題+答案領取方式見側邊欄)
- 你說的 NoSQL 數據庫是什么意思?NoSQL 與 RDBMS 直接有什么區別?為什么要使用和不使用NoSQL 數據庫?說一說 NoSQL 數據庫的幾個優點?
- NoSQL 數據庫有哪些類型?
- MySQL 與 MongoDB 之間最基本的差別是什么?
- 你怎么比較 MongoDB、CouchDB 及 CouchBase?
- MongoDB 成為最好 NoSQL 數據庫的原因是什么?
- 32 位系統上有什么細微差別?
- journal 回放在條目(entry)不完整時(比如恰巧有一個中途故障了)會遇到問題嗎?
- 分析器在 MongoDB 中的作用是什么?
- 名字空間(namespace)是什么?
- 如果用戶移除對象的屬性,該屬性是否從存儲層中刪除?
- 能否使用日志特征進行安全備份?
- 允許空值 null 嗎?
- 更新操作立刻 fsync 到磁盤?
- 如何執行事務/加鎖?
- 為什么我的數據文件如此龐大?
- 啟用備份故障恢復需要多久?
- 什么是 master 或 primary?
- 什么是 secondary 或 slave?
- 我必須調用 getLastError 來確保寫操作生效了么?
- 我應該啟動一個集群分片(sharded)還是一個非集群分片的 MongoDB 環境?
- 分片(sharding)和復制(replication)是怎樣工作的?
- 數據在什么時候才會擴展到多個分片(shard)里?
- 當我試圖更新一個正在被遷移的塊(chunk)上的文檔時會發生什么?
- 如果在一個分片(shard)停止或者很慢的時候,我發起一個查詢會怎樣?
- 我可以把 moveChunk 目錄里的舊文件刪除嗎?
- 我怎么查看 Mongo 正在使用的鏈接?
- 如果塊移動操作(moveChunk)失敗了,我需要手動清除部分轉移的文檔嗎?
- 如果我在使用復制技術(replication),可以一部分使用日志(journaling)而其他部分則不使用嗎?
- 當更新一個正在被遷移的塊(Chunk)上的文檔時會發生什么?
- MongoDB 在 A:{B,C}上建立索引,查詢 A:{B,C}和 A:{C,B}都會使用索引嗎?
- 如果一個分片(Shard)停止或很慢的時候,發起一個查詢會怎樣?
- MongoDB 支持存儲過程嗎?如果支持的話,怎么用?
- 如何理解 MongoDB 中的 GridFS 機制,MongoDB 為何使用 GridFS 來存儲文件?
Redis (一)

- redis 和 和 memcached 什么區別?為什么高並發下有時單線程的 redis 比多線程的memcached 效率要高?
- redis 主從復制如何實現的?redis 的集群模式如何實現?redis 的 的 key 是如何尋址的?
- 使用 redis 如何設計分布式鎖?說一下實現思路?使用 zk 可以嗎?如何實現?這兩種有什么區別?
- 知道 redis 的持久化嗎?底層如何實現的?有什么優點缺點?
- redis 過期策略都有哪些?LRU 算法知道嗎?寫一下 java 代碼實現?
- 緩存穿透、緩存擊穿、緩存雪崩解決方案?
- 在選擇緩存時,什么時候選擇 redis ,什么時候選擇
- 緩存與數據庫不一致怎么辦
- 主從數據庫不一致如何解決
- Redis 常見的性能問題和解決方案
- Redis 的數據淘汰策略有哪些
- Redis 當中有哪些數據結構
- 假如 Redis 里面有 1 億個 key ,其中有 10w 個 個 key 是以某個固定的已知的前綴開頭的,如果將它們全部找出來?
- 使用 Redis 做過異步隊列嗎,是如何實現的
- Redis 如何實現延時隊列
Redis (二)
- 什么是 Redis?簡述它的優缺點?
- Redis 相比 memcached 有哪些優勢?
- Redis 支持哪幾種數據類型?
- Redis 主要消耗什么物理資源?
- Redis 的全稱是什么?
- Redis 有哪幾種數據淘汰策略?
- Redis 官方為什么不提供 Windows 版本?
- 一個字符串類型的值能存儲最大容量是多少?
- 為什么 Redis 需要把所有數據放到內存中?
- Redis 集群方案應該怎么做?都有哪些方案?
- Redis 集群方案什么情況下會導致整個集群不可用?
- MySQL 里有 2000w 數據,redis 中只存 20w 的數據,如何保證 redis
- Redis 有哪些適合的場景?
- Redis 支持的 Java 客戶端都有哪些?官方推薦用哪個?
- Redis 和 Redisson 有什么關系?
- Jedis 與 Redisson 對比有什么優缺點?
- Redis 如何設置密碼及驗證密碼?
- 說說 Redis 哈希槽的概念?
- Redis 集群的主從復制模型是怎樣的?
- Redis 集群會有寫操作丟失嗎?為什么?
- Redis 集群之間是如何復制的?
- Redis 集群最大節點個數是多少?
- Redis 集群如何選擇數據庫?
- 怎么測試 Redis 的連通性?
- Redis 中的管道有什么用?
- 怎么理解 Redis 事務?
- Redis 事務相關的命令有哪幾個?
- Redis key 的過期時間和永久有效分別怎么設置?
- Redis 如何做內存優化?
- Redis 回收進程如何工作的?