怎么讓存儲過程通用化_怎么做分布式存儲的面試?

@cholerae 大神已經做了詳細回答,http://zenlife.tk/interview-for-distributed-storage.md

寫于幾年前,內容有點稚嫩,WAL辨識度很高, 其他問題一般.

CAP不會再問了,專業的存儲文獻中很少(幾乎不)提及CAP或PACELC, 這個詞用于市場和銷售,用于和業務系統對接. 反而是,面試官問CAP問題,候選人可以由此斷定面試官沒有做過存儲builtin研發,應聘團隊可能不符合預期.

現在加一個問題,failstop的故障基本假設和處理原則是什么? 這個問題比較重要,企業可信環境(不發生或者避免發生拜占庭故障)的分布式存儲構建一定要滿足的基本原則,不符合預期的處理,就是設計上的缺陷或bug. 大家可以試著分析,共識算法,復制協議,集群的上下線管理,元數據的HA是如何實現failstop的.


設計一種詰問(打破砂鍋問到底)的面試套路.

1. 用cas實現spinlock.

2. 實現單機kv存儲系統, 多節點共享kv存儲服務, 怎么解決external consistency的問題?

kv存儲N=0
用戶A和B操作kv存儲系統按照下面時序:
1.用戶A執行操作: INC N;
2.用戶A通知用戶B執行操作;
3.用戶B執行操作: if (N % 2 == 0) {N*=2;} else {N +=3;}怎么保證結果符合預期呢? 在網絡傳輸影響操作到達次序的情況下, 怎么保證B后于A完成操作.如果這個過程插入了C, 又如何做呢?

3. 鎖實現和版本控制用那個呢?

4. kv系統數據要持久化, 怎么保證在供電故障的情況下, 依然不丟數據.

5. flush/fsync/WAL/磁盤和ssd的順序寫

6. 單機kv存儲系統, 從掉電到系統重啟這段時間, 不可用, 如何保證可用性呢?

7. 數據復制, 日志復制, 有哪些實現方法呢?

8. 做主從復制, 采用pull和push操作, 那個好呢?

9. 如何保證多副本的一致性? RSM

10. 分布式共識算法: zab, paxos, raft.

11. commit語意是什么呢?

12. 單機或者單個leader的qps/tps較低, 如何擴大十倍?

13. 怎么做partitioning和replicating呢?

14. 存儲或者訪問熱點問題, 應該怎么搞?

15. CAP原理

16. 元數據怎么管理?

17. membership怎么管理?

18. 暫時性故障和永久性故障有哪些呢?

19. failover和data replication怎么搞呢?

20. 磁盤的年故障率預估是多少?

21. kv系統存儲小王, 小李, 小張三個人的賬戶余額信息, 數據分別在不同的節點上, 怎么解決小王向小李, 小李向小張同時轉款的問題呢?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/374128.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/374128.shtml
英文地址,請注明出處:http://en.pswp.cn/news/374128.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java EE中的配置管理

我嘗試配置管理在云計算中具有很多相關性 爭論 較早。 實際上,我大膽地宣稱配置管理是任何認真嘗試從軟件中節省幾美元的基石。 那么什么是配置管理及其主要目標? 在不使事情變得過于復雜的情況下,我認為接下來的兩個目標與事實相差不遠。 以…

十年總結,一個JAVA人的十年人生路

十年總結-開篇:歇一歇,才能走的更遠經常見壇子里有人問,學習java該如何入手,或者是該學java還是學XX語言。我一直覺得,編程跟語言關系不大,重點是要有解決問題的思路。學習一門語言,其實只是尋求…

(四)Qt實現自定義模型基于QAbstractTableModel (一般)

Qt實現自定義模型基于QAbstractTableModel 兩個例子 例子1代碼 Main.cpp #include <QtGui>#include "currencymodel.h"int main(int argc, char *argv[]) {QApplication app(argc, argv);//數據源QMap<QString, double> currencyMap;currencyMap.insert(…

pt-query-digest使用介紹【轉】

本文來自&#xff1a;http://isadba.com/?p651 一、pt-query-digest參數介紹. pt-query-digest --useranemometer --passwordanemometerpass --review h192.168.11.28,Dslow_query_log,tglobal_query_review \--history h192.168.11.28,Dslow_query_log,tglobal_query_re…

python代碼模板_python 代碼模板

python中的Module是比較重要的概念。常見的情況是&#xff0c;事先寫好一個.py文 件&#xff0c;在另一個文件中需要import時&#xff0c;將事先寫好的.py文件拷貝 到當前目錄&#xff0c;或者是在sys.path中增加事先寫好的.py文件所在的目錄&#xff0c;然后import。這樣的做法…

Java并發教程–重入鎖

Java的synced關鍵字是一個很棒的工具–它使我們能夠以一種簡單可靠的方式來同步對關鍵部分的訪問&#xff0c;而且也不難理解。 但是有時我們需要對同步進行更多控制。 我們要么需要分別控制訪問類型&#xff08;讀取和寫入&#xff09;&#xff0c;要么使用起來很麻煩&#xf…

找出互聯網類似以下圖的實例

轉載于:https://www.cnblogs.com/sghcjy/p/4978851.html

python比較運算符重載_python運算符重載

1、打印操作會首先嘗試__str__和str內置函數&#xff0c;他通常返回一個用戶友好顯示。__repr__用于所有其他環境&#xff0c;用于交互式模式下提示回應以及repr函數&#xff0c;如果沒有使用__str__&#xff0c;則會使用print和str。它通常返回一個編碼字符串&#xff0c;可以…

使用Spring MVC開發Restful Web服務

REST簡介 摘自Wikipedia&#xff1a; REST風格的體系結構由客戶端和服務器組成。 客戶端向服務器發起請求&#xff1b; 服務器處理請求并返回適當的響應。 請求和響應圍繞資源表示的傳遞而構建。 資源本質上可以是可以解決的任何連貫且有意義的概念。 正如您所閱讀的&#xff0…

深入Java核心 Java內存分配原理精講

深入Java核心 Java內存分配原理精講 Java內存分配與管理是Java的核心技術之一&#xff0c;之前我們曾介紹過Java的內存管理與內存泄露以及Java垃圾回收方面的知識&#xff0c;今天我們再次深入Java核心&#xff0c;詳細介紹一下Java在內存分配方面的知識。一般Java在內存分配時…

iOS正則表達式(親測,持續更新)

先來說說判斷方法,書寫不簡介但是好理解: -(BOOL)isRealNmaeString:(NSString *)str{NSString *pattern "填寫正則表達式";NSPredicate *pred [NSPredicate predicateWithFormat:"SELF MATCHES %", pattern];BOOL isMatch [pred evaluateWithObject:str…

python新建一個文件夾需要重新安裝模塊嗎_解決pycharm每次新建項目都要重新安裝一些第三方庫的問題...

目前有三個解決辦法&#xff0c;也是親測有用的&#xff1a;第一個方法&#xff1a;因為之前有通過pycharm的project interpreter里的號添加過一些庫&#xff0c;但添加的庫只是指定的項目用的&#xff0c;如果想要用&#xff0c;就必須用之前的項目的python解釋器&#xff0c;…

端到端測試的濫用–測試技術2

我的上一個博客是有關測試代碼方法的一系列博客中的第一篇&#xff0c;概述了使用一種非常常見的模式從數據庫檢索地址的簡單方案&#xff1a; …并描述了一種非常通用的測試技術&#xff1a; 不編寫測試 &#xff0c; 而是手動進行所有操作。 今天的博客涵蓋了另一種實踐&…

[AlwaysOn Availability Groups]排查:AG超過RPO

[AlwaysOn Availability Groups]排查&#xff1a;AG超過RPO 排查&#xff1a;AG超過RPO 在異步提交的secondary上執行了切換&#xff0c;你可能會發現數據的丟失大于RPO&#xff0c;或者在計算可以忍受的數據都是超過了RPO。 1.通常原因 1.網絡延遲太高&#xff0c;網絡吞吐量太…

那些年困擾我們的Linux 的蠕蟲、病毒和木馬

雖然針對Linux的惡意軟件并不像針對Windows乃至OS X那樣普遍&#xff0c;但是近些年來&#xff0c;Linux面臨的安全威脅卻變得越來越多、越來越嚴重。個中原因包括&#xff0c;手機爆炸性的普及意味著基于Linux的安卓成為惡意黑 客最具吸引力的目標之一&#xff0c;以及使用Lin…

python單元測試框架unittest介紹和使用_Python+Selenium框架設計篇之-簡單介紹unittest單元測試框架...

前面文章已經簡單介紹了一些關于自動化測試框架的介紹&#xff0c;知道了什么是自動化測試框架&#xff0c;主要有哪些特點&#xff0c;基本組成部分等。在繼續介紹框架設計之前&#xff0c;我們先來學習一個工具&#xff0c;叫unittest。unittest是一個單元測試框架&#xff0…

使用PowerMock模擬靜態方法

在最近的博客中&#xff0c;我試圖強調使用依賴注入的好處&#xff0c;并表達一種想法&#xff0c;即這種技術的主要好處之一是&#xff0c;通過在類之間提供高度的隔離&#xff0c;它可以使您更輕松地測試代碼&#xff0c;并且得出的結論是&#xff0c;許多好的測試等于好的代…

多態之向上轉型

//向上轉型&#xff0c;子類引用指向父類對象 public class UpcastingDemo{ public static void main(String[] args){ Employee enew Employee(); System.out.println(e.grade); e.job(); e.run(); System.out.println("\n"); Manager mnew Manager(…

(轉)FPGA異步時序和多時鐘模塊

http://bbs.ednchina.com/BLOG_ARTICLE_3019907.HTM 第六章 時鐘域 有一個有趣的現象&#xff0c;眾多數字設計特別是與FPGA設計相關的教科書都特別強調整個設計最好采用唯一的時鐘域。換句話說&#xff0c;只有一個獨立的網絡可以驅動一個設計中所有觸發器的時鐘端口。雖然…

穆里尼奧:與范加爾風格不同,轉變需要時間

據英媒報道&#xff0c;曼聯主帥穆里尼奧近日向媒體表示自己很難繼續遵循前任主帥范加爾的理念去建立球隊&#xff0c;因為他們兩人有著完全不同的想法。 穆里尼奧近日在接受BT Sport的采訪時表示&#xff1a;“這份工作對于我來說最難的地方便是我與范加爾是非常不同的教練&am…