我從未聽過P講任何一個人壞話,就算遇到很離譜的狀況,她總是用平實的語調敘述整件事情的前因後果。無論誰有煩惱,我們會一起「俯瞰」整件事,拋出想法或感動,盡量不帶批判。
「妳從這次事件中,學習到什麼?」
「妳這次遇到的狀況,跟上次事件有點像,當類似的事情反覆出現,有沒有覺得老天要給妳什麼樣的提醒?」
避免圍繞在無意義的蜚語流言,把焦點拉回跟自身相關的人事物上,多分享自己的夢想計畫、生活體驗、生命省思,或對社會世界有益的議題上。把每次相聚當作寶貴的交流機會,為實現夢想注入養分。話題可以輕鬆,插科打諢無傷大雅,但請不要太偏離內心的一把尺。
高品質的聊天,最能激發創意與促進知識交流。「主題式」的聚會最容易達到效果,例如品酒、外拍攝影、登山健行,其他開放填空。
取自《質感說話課》
*********************************
各位朋友,早安:
昨天直播跟高姊談交朋友的話題,我就想到這篇即將分享的摘文。
https://www.facebook.com/Psychologist.Hung/videos/668995333684609/
如果互動常在批判或嘲諷他人,這樣的聚會參加多了,真的很傷神。心不清靜,是非也多。
剛好今天要跟潘姊直播,潘姊的新書便是專攻「說話」這件事。我身邊也有這種益友,我常能因為他們的分享,引導我有更深的思考。
祝願您,能跟朋友產生建設性的對話,彼此滋養成長!
*********************************
讓相處時光更有價值
【文/ 潘月琪】
「我們藉由批評與嘲諷他人所建立的關係,並不是真正的連結。」
──TED人氣講者/布芮尼.布朗博士(Brené Brown)
有部喜劇電影《高年級姐妹會》(Book Club),描述四位熟齡閨密組成讀書會,平時會交流各自讀過的好書,當然也會相約吃美食,互相揶揄,聊聊婚姻、舊愛與身材變形的煩惱。某日,個性較開放的其中一位女主角薇薇安,興奮拿出全球暢銷情慾小說《格雷的五十道陰影》,強力推薦姐妹們一定要看,意外掀起一連串「愛」與「性」的精彩討論,也活化了這四位「黃金女郎」遭遇瓶頸的熟齡生活。
且慢!先別急著轉身溫習《格雷》三部曲,讓我們回想一下――噢!不是要你幻想拿著皮鞭的性感總裁,而是最近一次跟朋友聚會,你們都聊了些什麼?返家路上,你覺得滿足還是空虛?還期待下次跟同樣的朋友相見嗎?
當我們成為大人,有越來越多的責任,數不清的待辦事項,時間如此寶貴,好不容易跟朋友聚餐,作為辛苦勞動的犒賞,什麼都想聊,就像走進限時九十分鐘的吃到飽餐廳,面對琳瑯滿目的食材,什麼都想吃,但時間永遠不夠,這時候,需要有「選擇」的智慧。
談到吃,我的朋友K可來勁了:「先進攻那些成本最高、品質最好的料理,龍蝦、生蠔、菲力牛排……也要搭配一些青菜水果,營養要均衡嘛!」語氣一轉:「可是我兒子每次都先倒一大杯可樂,又夾一堆薯條,光吃這些就飽了,氣死我了!」看他一副「恨鐵不成鋼」氣呼呼的模樣,我放聲大笑。
胃容量有限,若先吃薯條,容納龍蝦的空間就少了。攝取太多垃圾食物,不會得到對心血管有益的蛋白質,只會得到脂肪肝。
相處時間有限,如果先花十分鐘抱怨店員送錯餐點,再追問同事的愛恨糾葛、部門主管的職場角力、明星八卦,然後花更長的篇幅,數落分手多年的前任情人,最後重複問朋友一樣的問題:「當年他這樣,究竟是什麼意思?」聊完這些,差不多該散場了。這些話題像冰可樂一樣,當下暢飲很爽快,但對於想要追求美好人生的你,真的「營養又美味」嗎?
「我們藉由批評與嘲諷他人所建立的關係,並不是真正的連結。」休士頓大學社工研究院的研究教授、也是知名TED講者――布芮尼.布朗博士這麼說。
聚會中常見的「營養失衡」,包括太冗長的情緒發言,抱怨天下不公,「同仇敵愾」謾罵、批評、訕笑討厭的人,還有炫耀新買的戰利品。除非是復古黑膠唱盤,那值得給它一個舞台,外加二十分鐘的亮相時間。
想要讓相聚時光更有價值,何不換個方式,以「高品質的閒聊」取代上述內容,也就是增加建設性、成長性、知識性、趣味性,以及有療癒作用的對話,聊著聊著,心情和思緒會逐漸澄澈清明,腦子會蹦出靈感,大家都開心笑個不停,或太感動而落淚,那就對了!
比方為剛升職的好友慶祝,當大夥兒紛紛用叉子進攻土耳其知名甜點――糖漿甜甜球(Lokma),你順口一提:「這甜點超好吃的!有句土耳其諺語說得好,吃甜點就能說好話。(Eat sweet, talk sweet.)為了世界和平,我們不多吃一點怎麼行呢?」
悲慘事件剛發生不久,想尋求朋友們的情感支持,絕對無可厚非,哭得一把眼淚一把鼻涕也絕對沒問題,宣洩完情緒後,不妨多拋出幾句話來延伸話題:
「會發生這樣的事,有沒有我沒注意到的盲點?」
「我好生氣,○○不做事又愛在老闆面前邀功,換成你們會怎麼處理?」
用開放性的問題,聽聽朋友們的建議,釐清為什麼會有這樣的事情發生,一起激盪未來可以怎麼改善。千萬不要一個人唱獨角戲,除非你是脫口秀主持人艾倫.狄珍妮(Ellen DeGeneres)。
P與L是我非常喜歡相處的兩位好友,P是室內設計公司副總,性格沉穩內斂,出國旅行會帶筆墨紙硯在飯店房間抄心經。L是國中音樂老師,一雙巧手能夠輕易做出極美的手工蠟燭,還會製香。
有次聚會,L教我們分辨天然「大豆蠟」與一般坊間常用的「石蠟」的差別,原來石蠟是由石油精煉過程中的副產物,即使有精煉石蠟及食品級石蠟等差別,仍然會對環境生態造成影響。P長期資助印度偏鄉孩童,去年她寄給我們每人一張空白卡片,並體貼附上回郵信封,邀請我們寫幾句話祝福這些遠方的孩子們。我們的聚會從不冷場,每次都像度假般身心舒暢。
我從未聽過P講任何一個人壞話,就算遇到很離譜的狀況,她總是用平實的語調敘述整件事情的前因後果。無論誰有煩惱,我們會一起「俯瞰」整件事,拋出想法或感動,盡量不帶批判。
「妳從這次事件中,學習到什麼?」
「妳這次遇到的狀況,跟上次事件有點像,當類似的事情反覆出現,有沒有覺得老天要給妳什麼樣的提醒?」
避免圍繞在無意義的蜚語流言,把焦點拉回跟自身相關的人事物上,多分享自己的夢想計畫、生活體驗、生命省思,或對社會世界有益的議題上。把每次相聚當作寶貴的交流機會,為實現夢想注入養分。話題可以輕鬆,插科打諢無傷大雅,但請不要太偏離內心的一把尺。
高品質的聊天,最能激發創意與促進知識交流。「主題式」的聚會最容易達到效果,例如品酒、外拍攝影、登山健行,其他開放填空。
我的作家好友G在人物傳記、報導文學領域是個中高手,學識淵博,如果以台灣山岳來比喻,在我心中,她就是玉山主峰的等級。
G跟我都很喜愛娜妲莉.高柏(Natalie Goldberg)的《心靈寫作》,這本教導創意寫作的小書,成為我們頗長一段時間的共同話題。我們曾經持續半年的「心靈寫作」聚會,每週見面坐定後,先聊聊天,然後各自振筆疾書半小時,寫得盡興時再延長時間,等時間一到,交換剛剛的即興書寫,邊討論邊延伸其他話題。
「做任何事都要有中心思想,寫作也是。」撰寫這本書時,我想起聚會時G分享的寫作建議,至今依然受用。
「那要不要大家先靜坐冥想五分鐘,用湯匙敲敲杯子,輪流發言五分鐘,再開始吃眼前的蛋糕?」另一位好友開玩笑說。這樣做也不錯,但也不用那麼拘謹,只要鼓起勇氣,婉拒充斥負面言談、空洞無趣的邀約,聚會品質就會產生改變。
當然,每個人對「高品質閒聊」的定義和需求略有差異,調整過程中,可能會流失一些曾經「無話不談」的朋友,因而感到失落。就像剛開始減少攝取糖類、加工食品,會覺得很不適應。等時間拉長,聚會成為滋養你的來源,你將會感謝自己做了這些取捨。
達賴喇嘛與南非屠圖大主教曾在印度達蘭薩拉(Dharamshala)相聚五天,那時,達賴喇嘛邁入人生第九個十年,大主教也已經八十多歲,兩位宗教領袖年事已高,又各有艱難的政治處境,幾乎可斷言那是他們此生最後一次相處。那麼他們都聊些什麼呢?兩位老人家心繫人類更廣大的自由、生死、和平,盡情談喜悅的本質、那些讓喜悅遠離的事物、支持喜悅的八大支柱,以及人們該如何練習喜悅。
如此高瞻遠矚的境界,並非遙不可及,想讓聚會時光更有價值,不妨改變一下閒聊的內容吧!
.
以上文字取自
質感說話課:言語的溫柔力量,是送給自己和他人最美的禮物
博客來 https://bit.ly/2VATkuU
誠 品 https://bit.ly/2RPj9Gw
金石堂 https://bit.ly/34QssLQ
博識網 https://bit.ly/3cuM5M2
遠流粉絲團
https://www.facebook.com/ylibfans/
.
(重新開放報名人數上限150人)6/14免費台南新希望健康講座_您的存在本身就是美好
https://www.facebook.com/events/1483251235180580/
已額滿_7/16-17免費台北市教師研習_非暴力溝通_如何讀懂愛的語言
https://www.facebook.com/events/519814295382140/
已額滿_11/7 三重免費公益講座_樂讀親子共學系列講座_以善意應對青少年情緒人際問題
https://www.facebook.com/events/189917322447609/
相信自己是夠好的媽媽:是犧牲,還是責任?是妥協,還是平衡?放下對母愛的執著,恢復你的生命彈性,重新找回愛自己的方式
博客來:https://bit.ly/2vhVD9s
讀書花園:https://bit.ly/2GEA9dH
誠品:https://bit.ly/2W4E3Sq
金石堂:https://bit.ly/2vhQ6jh
活化水 網 路 流言 在 Taipei Ethereum Meetup Facebook 的最佳貼文
📜 [專欄新文章] ELI5! 區塊鏈到底在幹嘛?
✍️ Juin Chiu
📥 歡迎投稿: https://medium.com/taipei-ethereum-meetup #徵技術分享文 #使用心得 #教學文 #medium
用生活化的例子輕鬆學會區塊鏈技術的重要概念
前言
我們熟知的世界正在慢慢地被區塊鏈技術瓦解與重建。不論背景,有愈來愈多人想對區塊鏈技術一探究竟,或許更進一步成為從業者、貢獻者或佈道者。
不幸的是,初學者若想學習區塊鏈技術,第一個問題可能會是高學習門檻,這是因為目前在各種主流平台上所流傳的區塊鏈知識或資源,都不免會大量使用艱澀的術語,長久以來便塑造出區塊鏈高大上的距離感,好似區塊鏈是只專屬於一小群駭客或者專業人士才能理解的技術。然而這是不準確的,事實上,區塊鏈技術中許多概念都能用一般常識理解,頂多只需要國小數學。
本文中,筆者將化繁為簡,試著把區塊鏈技術中的每個元素都使用生活化的例子比擬,讓區塊鏈愛好者與初學者不需用到密碼學/經濟學/資訊科學,也能領會區塊鏈技術的精髓之處。
本文將提及的概念如下:
什麼是帳本?
什麼是交易?
為什麼需要區塊?
有哪些共識機制?
區塊鏈安全嗎?
智能合約如何運作?
以下正文開始:
區塊鏈:一個公平的記錄系統
簡單來說,區塊鏈技術旨在打造一個去中心化的(Decentralized)狀態紀錄系統,更準確一點:區塊鏈技術旨在打造是一個追求真正「公平」的系統。
區塊鏈實現公平的關鍵在於:它完全仰賴自然法則運作,只透過一系列精細的規則就能保證系統的正確,這打破了人類社會一直以來的仰賴的中心化系統,使促成不平等的最大因素不復存在。
區塊鏈技術可以打造出具世界規模的去中心化運算平台,由數千甚至數萬個參與者共同維護狀態並提供計算資源。如果這個運算平台是應用在貨幣與資產的場景中,那麼這個平台可被稱為分散式帳本。
在接下來的段落,筆者將用一個例子展示一個極度精簡、只用紙跟筆的就可以運作的分散式帳本。在這個例子中,一群學生可以使用區塊鏈技術發行屬於他們自己的虛擬幣:「考卷幣」(Exam Paper Coin, EPC)。
考卷幣:使用區塊鏈技術發行的虛擬幣
考卷幣(EPC)是一種使用區塊鏈技術發行的虛擬幣,並存在於分散式帳本中。它的用途是為考卷加分,這將會吸引想考高分或者擔心被當的人學生持有。為什麼 EPC 只能被稱作虛擬幣,而不被稱作密碼貨幣?這是因為 EPC 的發行不會使用任何有關密碼學的技術,因此 EPC 嚴格來說不是密碼貨幣。
在分散式帳本被創建之初,沒有任何人擁有 EPC ,那麼 EPC 是怎麼「鑄造」與分配的?至少可以肯定的是,EPC 不能憑空產生,否則所有參與者就能不斷製造 EPC,使分散式帳本崩潰。事實上,EPC 的價值奠基於參與者的「付出」。
分散式帳本中最重要的角色非記帳者莫屬。每當記帳者成功完成工作,它便可以獲得固定數量的 EPC 作為報酬。於是,分散式帳本中的 EPC 便如此逐步地被鑄造出來。將 EPC 賦予具有貢獻的記帳者除了能夠公平分配 EPC,同時也是一種激勵機制(Incentivizing Mechanism),提供參與者維護帳本的動機。
那麼每個人所具有的 EPC 是怎麼記錄在帳本中的?
帳本: EPC 都要記錄下來
帳本即為依時間順序與特定格式記錄價值的系統。在分散式帳本中,每一批紀錄都會由某一個特定的「記帳者」維護,而記帳者會以特定的規則從所有的參與者中選出,因此分散式帳本是具有多個「記帳者」的系統。
為了確保能公平選出 EPC 的所有記帳者,分散式帳本不會使用任何記帳者的個人資訊,例如姓名、電話,做為帳本上的識別。記帳者可以自由地使用假名(Pseudonym)作為帳本上唯一的識別(Identifier),或者稱為地址(Address)。所以王小庭同學可以使用 Alice 這個假名,而且如果王小庭同學喜歡的話,他也可以同時使用 Bob 這個假名。
EPC 使用如下的格式記錄每個地址幣的數量:
Alice 100 EPCBob 0 EPCCharlie 0 EPCDavid 0 EPCEva 0 EPC
多數區塊鏈稱其識別為地址(Address),其為非對稱密碼學中公鑰(Public Key)的雜湊值(Hash)。地址具有統一的格式,例如以太坊的地址為長度 160 位元的 16 進位數字。
交易:把我的 EPC 轉移給別人
EPC 是可以轉移的,現在 Alice 可以將它持有的 100 EPC 中的 60 EPC 轉移給 Bob,以幫助 Bob 在下一次考試中免於被當。這樣的轉幣紀錄稱為交易(Transaction, Tx),可以如下表示:
Tx1
60 EPC, from [Alice] to [Bob]
而這筆交易會由 Alice 以上述格式記在紙條上,以 Tx1 表示。
簽章:讓參與者的所有動作都不可抵賴
EPC 的每個參與者的每個行為,例如交易,都必須附帶簽章(Signature),證明「這個動作確實是由我本人發起的」,簽署者不可抵賴,任何沒有附帶簽名的動作都是不被承認的。一個附帶簽名的交易紙條會像這樣:
Tx1
60 EPC, from [Alice] to [Bob], ALICE
簽章分為簽署(Sign)及驗證(Verify)兩個動作。驗證即是確認簽章是否確實是由行為發起者所簽署。在這個例子中,僅用一個簡單的驗證:若簽章與識別相符,則驗證成功。例如 Tx1 中,簽名 ALICE 確實與交易發起者 Alice 相符,因此驗證成功。
簽章就是區塊鏈的數位簽章(Digital Signature),其使用私鑰(Private Key)簽署,公鑰(Public Key)驗證,非常難以偽造。
訊息的散佈:怎麼讓所有參與者都收到訊息?
由於 Tx1 是由 Alice 發起的,因此 Alice 將於它自己的帳本記下這筆交易,接著 Alice 必須把這筆交易的內容也轉達所有的參與者,讓所有參與者皆具有所有的交易內容。
EPC 的參與者們不以口語,而是以傳紙條的方式互相交換訊息。紙條要如何有效率地傳播訊息給所有在教室中的參與者呢?可以使用「一傳十、十傳百」的策略。也就是:一次傳 10 張紙條給自己周圍的參與者,參與者收到後再抄寫 10 次後傳給周圍尚未收到該紀錄的其他參與者,逐步將訊息擴散致所有參與者。
這樣的傳播策略正如同流言被散佈的方式,因此也被稱為流言散佈協定(Gossip Protocol)。紙條傳播的網路就是對等網路(Peer-to-peer Network),紙條就是對等網路的封包(Packet)。關於對等網路的介紹,可以參考筆者日前的撰文:
隱私、區塊鏈與洋蔥路由
區塊:記錄一段時間內的交易順序
經過一段時間之後,每個 EPC 參與者手上都會有許多來自別的參與者的紙條,每張紙條都記載著不同的交易。在理想狀況下,如果所有參與者收到紙條的順序都相同,且每個參與者都收到了所有紙條,則所有參與者的帳本上的狀態,也就是餘額,都會相同。然而,若採用上述的訊息散佈策略,會發生兩種情況:每個參與者收到紙條的順序會不同,或者某些紙條可能會被遺漏。這些情況都會讓每個參與者的帳本產生差異,使帳本不可靠。而一個不可靠的帳本,不能作為貨幣發行的工具。
有沒有辦法能使所有 EPC 參與者用相同的交易順序記帳呢?這便是區塊鏈技術的奧秘之處。
為此,我們需要使用一個精心設計的結構:區塊(Block)。每個參與者皆會將一段時間內收到的交易紙條的編號,依照自己的順序寫在另一張紙條上,這張紙條就是區塊紙條,簡稱區塊,產出區塊的參與者則稱為區塊生產者。收到區塊紙條的其他參與者便會知道區塊生產者在這段時間內的交易順序。
為了要讓所有帳本都具有一致的狀態,EPC 的所有參與者必須要選出其中一個區塊作為所有參與者的共識(Consensus)。所有參與者都必須要遵照共識區塊的交易順序來更新自己的帳本,而這個區塊生產者就是記帳者。由於記帳者可以獲得報酬,因此在利益的驅使下,所有參與者都會努力生產區塊以爭取記帳權。
值得注意的是,每個區塊當中都會記錄前一個已達成共識的區塊的編號。例如接下來的範例,Bk15 的前一個已達成共識的區塊為 Bk3:
Bk15
Last Block: Bk3
Height: 15
Transactions:- Tx1- Tx5- Tx4- Tx10- Tx7- Tx13
Nonce: 1
Signature: CHARLIE
由於每個新的共識區塊都會指向前一個共識區塊,如此便會形成一條長鏈般的結構,已形成共識的區塊接成一條鏈,這就是區塊鏈(Blockchain)名稱的由來。
而當 EPC 參與者在收取共識的區塊後,將按照共識依序為每個交易內容進行帳本餘額的轉換。如此,所有的帳本都將具有一致的狀態。
依據特定輸入及轉換函數(Transition Function)執行狀態更新的系統,稱為狀態機複製(State Machine Replication)
摘要:濃縮紙條上的訊息
在介紹達成共識的方法前,筆者要先來介紹一個樸實無華但重要的概念:摘要(Digest),其顧名思義就是一段內容經過消化的產物。假設有一種摘要產生器,這個機器可以放入一張紙條,然後透過 3 個步驟計算出紙條的摘要。
摘要產生器將記載訊息的紙條切成一條一條固定寬度的細長條狀紙帶,如下圖:
2. 將這些紙帶依照順序接成一個長條紙帶。紙帶上有字跡的黑色部分與沒字跡的白色部分會出現不規則相間,測量每個黑色區塊之間相鄰的距離,如下圖:
3. 每段距離的數字相乘後的數字就是這個紙條的摘要(Digest)。
每個 EPC 參與者都會有一台摘要產生器,而它需要上緊發條才能開始工作,且每計算完一張紙條便須重新上一次發條。
摘要的計算雖然簡單,卻具有一些很有用的特性:
首先,摘要會隨著紙條內容的變動而更動。只要更動了任何一點紙條內容,例如區塊的交易順序,或者流水號(Nonce),都會使摘要改變。因此一個附上摘要的紙條,可以讓收到紙條的人在收到後再自行計算一次摘要並比對兩者,以驗證紙條的內容是否被修改過。因此,摘要是可驗證的(Verifiable)。
若想在不更動摘要的情況下同時變動紙條內容,只能不斷嘗試用不同內容產生摘要,直到發生碰撞(Collision) — 意即兩個不同內容的紙條出現相同摘要。
其次,摘要也是單向的:一個紙條很容易產出摘要,但摘要很難還原出原本的紙條內容。這也代表摘要是隨機且難以預測的,因此摘要可以作為一種亂數(Random Number)來源。
正式的區塊鏈使用更難預測且更不易碰撞的的密碼雜湊函數(Cryptograpgic Hash Function)產生訊息摘要。
理解關於區塊鏈技術的基本要件後,接下來就來看看區塊鏈技術的精妙之處:共識機制。
共識機制:如何達成共識?
在區塊鏈技術中,大致上有兩種方式可以產生共識:抽彩(Lottery)或表決(Vote),它們各自有不同特性,每一種分散式帳本都會使用其中之一作為共識機制。
抽彩
在抽彩機制中,唯有摘要小於門檻值的「合法」區塊才會被所有參與者收受。然而,區塊生產者無法預測摘要,且可驗證的摘要使區塊生產者難以作弊。因此若想生產數字小於門檻值的摘要,區塊生產者必須不斷改動區塊內容,例如流水號或者交易順序,直到找到摘要小於門檻值的區塊,就像抽彩一樣。只有合法的區塊才會被區塊生產者散佈給其他 EPC 參與者。
在這樣的規則下,可能會同時出現多個合法區塊。還記得區塊鏈中「鏈」的部分嗎?當收受多個低於門檻的區塊時,該選哪個區塊作為上一個區塊呢?這裡我們可以用一些簡單的規則來做抉擇:選擇合法區塊中高度(Height)最高的區塊,若高度一樣則選擇摘要數字較低的區塊。
區塊紙條的摘要就是正式區塊鏈中的區塊雜湊值。在正式的區塊鏈中,門檻值愈低,困難度(Difficulty)也愈高。區塊的選擇規則也稱為分岔選擇規則(Fork Choice Rule),使用可驗證的亂數作為共識的做法又稱為中本共識(Nakamoto Consensus)。
表決
有別於複雜的抽彩,表決機制相當直觀:所有參與者針對某個預先選出的領袖(Leader)的提案(Proposal),也就是區塊,進行投票。領袖是怎麼選出的?一個直覺的做法是按照假名的順序,按照 Alice / Bob / Charlie 的順序,所有參與者輪流擔任領袖。
所有參與者在收到提案後,可以選擇同意或反對這個區塊的內容,若同意的話,則將自己對提案的同意票記在紙條上,並將這個投票紙條散佈給所有其他參與者。若多數的參與者同意了提案,則所有參與者皆須認定該提案為共識。
然而,表決機制雖然直觀,卻不如抽彩具有可驗證性,參與者若想作弊則相對容易:例如,參與者可以重複投票,或者串通其他參與者一起不投票,以破壞帳本;另一方面,表決比抽彩來得有效率,因其不需要所有參與者都費功去製造可能將不被收受的區塊。
拜占庭錯誤(Byzantine Fault)特指這些不在預期內的行為,表決機制事實上也就是拜占庭容錯(Byzantine-fault-tolerant, BFT)演算法。PBFT 家族的協定是目前拜占庭容錯演算法的主流,然而其至多只能容忍不超過參與者總數一半的拜占庭錯誤。若想了解更多 PBFT 的細節,可以參考筆者日前的撰文:
若想搞懂區塊鏈就不能忽視的經典:PBFT
女巫:如何避免帳本被單一個體掌控?
上文提到:為了保證公平的記帳權,帳本上的識別都是假名,如上文提及,Alice 跟 Bob 實際上都是由同一個參與者王小庭所控制,其他參與者不僅難以得知,而且王小庭喜歡的話,他愛用幾個假名就用幾個假名 — 掌控多個假名的王小庭就成為了「女巫」(Sybil)。
不論是採取何種共識機制,女巫的存在都會破壞分散式帳本的安全性:
在抽彩機制中,如果多數的參與者皆由女巫控制,則女巫有很大的機會可以無視規則,不需抽彩便竄改帳本。
在表決機制中,如果由女巫控制的參與者可以集體進行不在預期內的行為,例如重複投票或者不投票。
因此,抵抗女巫對於分散式帳本的安全至關重要。對此,一個直覺的思路是:讓每個假名的行為都必須付出有限的資源,例如錢跟力。因此有兩種方式可以抵抗女巫:要嘛出錢,要嘛出力。
出力:在抽彩機制中,每個合法區塊的生產都必須附有低於門檻的摘要,而摘要的計算需要參與者出力不斷地重上發條。
出錢:在表決機制中,抵押一定數量 EPC 的參與者才能獲選為領袖被生產提案,且若違反規則,參與者的押金將會被沒收。
出力即是工作證明(Proof of Work, PoW);出錢即是權益證明(Proof of Stake, PoS),抵抗女巫的機制稱為抗女巫機制(Sybil-control Mechanism)。
合約:進行條件式的交易
回顧一下本文開頭所提:區塊鏈技術可以用來打造去中心化的運算平台,它可以用以記錄任何資訊,不止餘額,例如一段合約(Contract)。合約就是指一段會依據不同條件而達成不同執行結果的語句。例如:
CheckAndPay
給定 A、B 兩個假名,若 A 的餘額大於/等於 30 EPC,則 A 支付 20 EPC 給 B ,否則 A 不支付任何 EPC。
這個合約就可以被記錄在帳本中:
Alice 100 EPCBob 0 EPCCharlie 0 EPCDavid 0 EPCEva 0 EPCCheckAndPay "給定 A、B 兩個假名,若 A 的餘額大於/等於 30 EPC,則 A 支付 20 EPC 給 B ,否則 A 不支付任何 EPC。"
之後 Alice 就可以發起像這樣的交易:
Tx 99
CheckAndPay, {[Alice], [Bob]}, ALICE
如此,若 Alice 的 EPC 餘額不足 30 EPC 則不會支付 Bob。
觸發合約的 Tx 99 ,它的執行過程比較煩瑣:執行 Tx 99 的參與者首先會從帳本中尋找 CheckAndPay 的合約內容,並從 Tx 99 中取出合約需要的輸入:A 與 B,接著參與者再解讀合約的語句,依照條件進行帳本的狀態轉換。其中,為了使參與者能解讀合約,合約需用所有參與者皆能看懂的語言書寫。
合約又稱智能合約(Smart Contract)。正式的區塊鏈使用虛擬機(Virtual Machine)來解讀與執行合約。事實上,智能合約能做的事情非常多,這使具有智能合約功能的分散式帳本得以成為去中心化的運算平台,例如以太坊(Ethereum)。
總結: 分散式帳本究竟是一個怎樣的系統?
如果以上環節皆運作順利,那麼便能成功只用紙筆便發行了專由學生使用的貨幣。最後再次強調一次:這是一個為了便於使初學者掌握核心觀念而極度簡化的例子。正式運行的區塊鏈,例如以太坊,其實際運作遠遠複雜得多。
還有一些比較進階的概念,雖然礙於篇幅未在此文章提及,但部分主題筆者曾撰文介紹:
可擴展性(Scalability):第二層方案(Layer 2)與分片(Sharding)
隱私(Privacy)與匿名(Anonymity)
共識機制的安全性(Safety)與活躍性(Liveness)
最後,如果日後朋友/家人問起「什麼是區塊鏈」時,我想你會知道如何解釋了:)
ELI5! 區塊鏈到底在幹嘛? was originally published in Taipei Ethereum Meetup on Medium, where people are continuing the conversation by highlighting and responding to this story.
👏 歡迎轉載分享鼓掌