「你懂得如何找到適合自己的工具,改善自己的工作流程嗎?」
這個人手一機、動不動就帶著筆電趴趴走的年代
我大概已經好幾年沒有過過出門不攜帶 3C 產品的一天了。
不管是筆記軟體、鬧鐘、待辦事項、記帳軟體、通訊軟體、社群軟體,都充斥著我們的生活
今天其實只是想分享我自己發的一篇新部落格教學文啦
不過還是跟大家小聊一下。
-
「我何時開始學會活用軟體、改善我的生活或工作流程的呢?」
大概從三四年前,我就開始會在電腦上裝一些有的沒的軟體
有截圖錄影軟體、有監控軟體、有快捷鍵操控視窗的軟體、也有協助思考的軟體
有的軟體學習曲線較高(比如心智圖軟體我到現在還是只會用來Brainstorming)
有的軟體則是一學就通(比如 CleanShot X 截圖錄影軟體實在超好用)
-
「回想那些接案的日子、把電腦操到極致的日子。」
而之前有在接案的時候,工作上最常用到的就是 Parallels Desktop 這個虛擬機軟體了
當時接到的專案是一個牙醫內部影像系統,因為一些讀取檔案目錄的程式關係,必須使用 Windows 系統才能正確運行
還記得三月我被困在武漢持續接案那陣子,常運行 Parallels Desktop 把電腦搞到當機
照慣例上 IG 抱怨一下之後,繼續等電腦自己恢復運行
後來回台灣後換了最頂規最新的 Mac 電腦,但也剛好停掉了接案,所以比較沒有在操電腦了
-
「軟體一年年推陳出新,真的有必要年年跟上腳步嗎?」
最近發現 Parallels Desktop 推出 16 版本,聽說效能有變好
剛好有在寫 Blog 的我就想說:「咦!不然寫篇評價文章,順便看可不可以跟廠商凹到折扣好了」
因此就花了快兩週時間規劃+寫了一篇超詳細的 Parallels Desktop 16 完整教學文
寫得過程中也調查了最新版跟舊版的差異之處
其實軟體這種東西就像 iPhone 一樣:「跟上最新潮流會很爽,不跟上好像也不痛不癢」
所以要不要花錢跟上,大家還是要理智去做抉擇
-
還是跟大家推薦一下 Parallels Desktop 這款真的蠻實用的雙系統/虛擬機軟體,它對 Mac 電腦的優化還是真的不錯的!
有興趣的人可以看看這篇文,另外雙十一聽說有7折優惠,如果有需求要續約或購買的人,自己計好日期唷!(文中也有提到折扣日期,可以參考)
【Parallels Desktop 16 教學】超方便 Mac 雙系統軟體:Windows、Linux都可裝!還支援最新的 macOS Big Sur 系統!
文章連結:https://leadingmrk.com/parallels-desktop-review/
linux 家目錄 在 劉奶爸網路行銷sop-標準流程-創業故事 Facebook 的最佳解答
【你是豬還是神? 在家工作的起源】
1999年在貿易公司上班,某天老闆要我下午去一個合作廠商哪裏拿一片光碟,裏頭是存放著我們公司的新版LOGO與目錄冊的原稿,因為檔案很大,不方便發Email 。剛好該廠商就在萬華莒光路離我住家很近,我就很開心的前往,順便下班了…
印像中那裏沒有什麼公司才對,到達目的地之後,果然是個住家,裏頭就兩夫妻,兩部電腦在工作著,電腦螢幕上顯示著 PhotoShop 的軟體畫面!
我很好奇的問他們:「你們都在家裏工作嗎? 沒有員工? 收入夠用嗎?」 一連串好多問題…因為那時候我總覺得公司要很多人才叫做會賺錢的公司啊!!
「是啊,好多年了! 就兩個人,收入高高低低,還可以啦! 比較自由…」老闆娘很保守的回答我,嘴角卻難掩那一絲藏不住的自豪與喜悅。
從那一刻起,我就重新對電腦燃起興趣,瘋狂學習,到了巨匠報名600小時的網管認證課程、網頁設計課、美工設計… 為的不只是賺錢,而是「在家賺錢,在任何一個可以上網的地方就能賺錢…」
後來我發現我最大的興趣原來不是學電腦,而是「用電腦賺錢」
原來我討厭的不是「去公司上班」,而是「比較喜歡與好控制又沒脾氣的電腦共事」
後來電腦進步的速度快過許多同事的學習速度,很多人為了難以控制的電腦而花了好多時間卻不得其門而入,例如學不會寫程式、不懂網路運作原理、天生沒有美編的天份,為了迎合公司主管的要求,仍然辛苦的學著Office軟體、進銷存軟體,甚至用 PPT 製作公司海報… 而我當然是自告奮勇幫公司做網站,因為我明白所有電腦的技能裏,做網站才是最快與世界接軌的技能(當時沒有社交平台),而且是最快能離職自立的技能!
而現在這個時代愈來愈逼近「不會架網站」就很難快速賺錢的情勢,人人只靠「自媒體」是不夠的,因為你最後總會被平台剝削,例如演算法可以送你上天堂,也可以送你上西天 XD ,對你好的時候讓你賺錢,不讓你曝光的時候就讓你跌落谷底!
於是獨立架站的需求就是每個想自主掌握命運的前瞻者一直在追求的專業技能,這十年來,從各家CMS(內容管理系統)的演進,最後由 WordPress 軟體勝出,幹掉了Joomla ,成為最多人使用的架站軟體,佔據了全世界 35% 網站的超高比例,也為那些不懂得寫程式的站長們取得了獨立架站不靠任何人的榮耀與尊嚴!
我們不需依靠任何一家一定要繳高昂年費的平台,我們不需被合法勒索就能架設想要的網站,這些 LINUX 、WordPress 開源軟體,就是為了不被單一公司軟體綁架而由全世界眾人維護的自由軟體,我們感謝這些人的貢獻造就了我們可以利用極少的金錢就能實現架站的願望… 但是…
如果你不學習駕御這些軟體,你的命運將會和別人一樣,被其他人駕御,因為知識落差,就是財富的落差… 當我們每年省下7~10萬元 Clickfunnel 、Teachable 的費用,再把這些錢拿去打廣告多賺70萬100萬的時候,再過5年…10年,財富的差距就是千萬以上的退休金了…
10萬買不到一張台積電股票,卻能讓你學到賺到未來千萬的退休金! 與其怨嘆沒有早點買到低價好股票,不如投資自己的腦袋,提升技術能力,不用事事靠別人,拿回人生自主權!
豬隊友一堆,神隊友難尋! 先讓自己成為別人眼中的神隊友,你才有資格挑選你的合作夥伴!
懶人包2.0 讓你成為神…隊友,點擊: https://mlm.contentismoney.com/lazybone2/
.
#229天了我與兒子的300天跑步拿IPhone12計畫倒數71天😀
linux 家目錄 在 Taipei Ethereum Meetup Facebook 的最讚貼文
By Frank Wang
[使用 go-ethereum 1.6 Clique PoA consensus 建立 Private chain (1)] -- by Frank Wang
Ethereum Proof of Authority
在 Ethereum 官方的共識機制是使用 PoW,Miner 必須靠使用算力去解決密碼學問題來取得寫帳(打包 Block)權。但 PoW 機制在私有鏈或聯盟鏈上並不是一個那麼有效率的共識機制,私有鏈的維運者必須花費多餘的算力來維持私有鏈的運作。
而 Proof of Authority 思維是直接指定哪些節點有寫帳權,其他節點透過演算法如果是被授權的節點打包 Block 則判定 Block 有效。
Ethereum Client 中有不同語言的實作,之前 Parity 版本的實作就有提供 PoA 的共識機制(介紹)。而在前段時間發佈的 geth 1.6 也支援了 PoA 的共識機制。不過 geth 的 PoA 使用方法跟機制和 Parity 的版本不同,geth 實作了 ethereum/EIPs#225 一個稱作 Clique 的共識機制。所以這篇主要筆記如何建立一個 geth Clique Private chain。
情境中會使用 4 個節點,分別代表兩個普通的節點發起交易,一個創世塊指定的授權節點,一個後期加入的授權節點來玩玩 Clique 。
安裝 geth
由於 go-ethereum 使用 golang 開發的,所有的程式都被編譯成單一的可執行檔了,執接下載下來就可以直接執行。
geth & tools 1.6 — https://ethereum.github.io/go-ethereum/downloads/
找到相對應 OS 後下載,記得下載 geth & tools 的版本,接下來會使用 geth 1.6 版本的一個創 Private chain 的工具 puppeth 來建立 Clique Private chain。
最後記得將這些執行檔加入 PATH 方便呼叫。
環境準備
待會要建置的環境將會使用 4 個 ethereum 節點,並且全部節點跑在同一台機器上,這樣比較省事。先創好 4 個資料夾,分別叫 node1 node2 signer1 signer2 ,node 是一般的 ethereum client,signer 在接下來的情境中當成打包 block 的角色。
-> % lsnode1 node2 signer1 signer2
建立 Ethereum 帳號
接著我們要替這四個角色各建立一個 Ethereum 帳號。
frank@frank-linux [10:51:22 AM] [~/src/eth-poa] -> % cd node1
frank@frank-linux [10:55:08 AM] [~/src/eth-poa/node1] -> % geth --datadir ./data account newWARN [04–18|10:55:30] No etherbase set and no accounts found as default Your new account is locked with a password. Please give a password. Do not forget this password.Passphrase: Repeat passphrase: Address: {c7873030c2532aafe540d9dfd02a08330ee06465}
在這步驟切換到每個目錄底下,指令 geth --datadir ./data account new 這段指令是指要使用當下目錄底下的 data 目錄當作 geth 存放資料的地方,並且創一個新的 Account。在剛剛建立的 node1, node2, signer1, signer2 都下相同指令創一個帳號。
一下是我創好的每個角色的 Account address:
node1: c7873030c2532aafe540d9dfd02a08330ee06465
node2: 6d650780d493056f679a30b2c65cfa5e07835ad6
signer1: 5cc640ae524f70c39081d65bc699b3b61a67bd3f
signer2: 0fe2d8747d24156b342c9fa5c5e7138cf4047a8d
創好帳號後就可以開始建立 Private chain 了
建立創世塊設定
由於 Clique 並不像 Parity 版本的 PoA 靠設定檔設定授權的節點。Clique 是將授權節點的相關資訊放在 Block Header 中,所以我們必須對創世塊做一些設定才可以讓授權機制生效。(但這並不意味著新增或刪除授權節點需要更換創世塊,晚點介紹怎麼新增授權節點)
Clique 是將授權的資訊放在 extraData 中,但資料結夠的格式並沒有那麼直覺,所以在此使用 geth 1.6 提供的建立 Private Chain 的工具 puppeth 來建立創世塊,puppeth 是各互動式的程式,直接啟動照著指示輸入相關資訊。
frank@frank-linux [11:19:16 AM] [~/src/eth-poa] -> % puppeth+ — — — — — — — — — — — — — — — — — — — — — — — — — — — — — -+| Welcome to puppeth, your Ethereum private network manager || || This tool lets you create a new Ethereum network down to || the genesis block, bootnodes, miners and ethstats servers || without the hassle that it would normally entail. || || Puppeth uses SSH to dial in to remote servers, and builds || its network components out of Docker containers using the || docker-compose toolset. |+ — — — — — — — — — — — — — — — — — — — — — — — — — — — — — -+
Please specify a network name to administer (no spaces, please)> poa_for_fun
這裡會希望你給你的 Private chain 一個名字
Sweet, you can set this via — network=poa_for_fun next time!
INFO [04–18|11:19:21] Administering Ethereum network name=poa_for_funWARN [04–18|11:19:21] No previous configurations found path=/home/frank/.puppeth/poa_for_fun
What would you like to do? (default = stats) 1. Show network stats 2. Configure new genesis 3. Track new remote server 4. Deploy network components> 2
這裡選 2 ,要建立一個新的創世塊設定
Which consensus engine to use? (default = clique) 1. Ethash — proof-of-work 2. Clique — proof-of-authority> 2
共識機制,選 2,Clique PoA
How many seconds should blocks take? (default = 15)> 10
多少秒數會產出一個 Block,在這裡設 10 秒。當然你可以自己設定你想要的
Which accounts are allowed to seal? (mandatory at least one)> 0x5cc640ae524f70c39081d65bc699b3b61a67bd3f> 0x
指定一個 Account address 作為授權打包的角色。這裡使用上面產出的 Signer1 的 address。
Which accounts should be pre-funded? (advisable at least one)> 0xc7873030c2532aafe540d9dfd02a08330ee06465> 0x5cc640ae524f70c39081d65bc699b3b61a67bd3f> 0x
指定要不要事先給一些 ether。這裡選 node1 和 signer1 的 address,當然這隨你指定
Specify your chain/network ID if you want an explicit one (default = random)>
Network Id,直接用 random
Anything fun to embed into the genesis block? (max 32 bytes)>
沒什麼需要特別加入 genesis 的,留空
What would you like to do? (default = stats) 1. Show network stats 2. Save existing genesis 3. Track new remote server 4. Deploy network components> 2
選 2 存檔
Which file to save the genesis into? (default = poa_for_fun.json)> INFO [04–18|11:19:50] Exported existing genesis block
What would you like to do? (default = stats) 1. Show network stats 2. Save existing genesis 3. Track new remote server 4. Deploy network components> ^C
ctrl+c 離開,會在當下目錄看到一個 poa_for_fun.json 檔案。
替 4 個節點初始化 Private chain
使用 geth init 指令,分別替換 4 個 node 的 datadir
frank@frank-linux [11:38:07 AM] [~/src/eth-poa] -> % lsnode1 node2 poa_for_fun.json signer1 signer2frank@frank-linux [11:38:07 AM] [~/src/eth-poa] -> % geth --datadir node1/data init poa_for_fun.json INFO [04–18|11:39:10] Allocated cache and file handles database=/home/frank/src/eth-poa/node1/data/geth/chaindata cache=128 handles=1024INFO [04–18|11:39:10] Writing custom genesis block INFO [04–18|11:39:10] Successfully wrote genesis state hash=5722d7…47e737frank@frank-linux [11:39:10 AM] [~/src/eth-poa] -> % geth --datadir node2/data init poa_for_fun.jsonINFO [04–18|11:39:14] Allocated cache and file handles database=/home/frank/src/eth-poa/node2/data/geth/chaindata cache=128 handles=1024INFO [04–18|11:39:14] Writing custom genesis block INFO [04–18|11:39:14] Successfully wrote genesis state hash=5722d7…47e737frank@frank-linux [11:39:14 AM] [~/src/eth-poa] -> % geth --datadir signer1/data init poa_for_fun.jsonINFO [04–18|11:39:21] Allocated cache and file handles database=/home/frank/src/eth-poa/signer1/data/geth/chaindata cache=128 handles=1024INFO [04–18|11:39:21] Writing custom genesis block INFO [04–18|11:39:21] Successfully wrote genesis state hash=5722d7…47e737frank@frank-linux [11:39:21 AM] [~/src/eth-poa] -> % geth --datadir signer2/data init poa_for_fun.jsonINFO [04–18|11:39:24] Allocated cache and file handles database=/home/frank/src/eth-poa/signer2/data/geth/chaindata cache=128 handles=1024INFO [04–18|11:39:24] Writing custom genesis block INFO [04–18|11:39:24] Successfully wrote genesis state hash=5722d7…47e737
到目前我們已經準備好讓節點可以啟動和互相連線了。
啟動 geth client 並設定 peers 間的連線
分別在 node1, node2 目錄使用指令啟動 geth
geth --datadir ./data --networkid 55661 --port 2000 console
這裡需要注意的是 datadir 參數沒問題,先前的步驟已經在每個節點各自的目錄都建立了 data 目錄。networkid 大家一定都要用同一個值才可以互相連線。port 用來讓 geth 跟其他 geth 連線所 listen 的一個 port,由於四個節點都在本機,所以這裡必須都指定不同的值。以下使用 node1 2000, node2 2001, signer1 2002, signer 2003 當範例。
如果節點是授權打包 block 的節點,那你啟動時要先 unlock 你的 account,這樣才可以進行交易的打包。多帶一個 unlock 參數,以及你要解鎖的 account address。啟動後會要求輸入當時創 account 時的 passphrase。所以在這裡啟動 signer1 和 signer2 時都要用 unlock 參數帶入他們各自的 address 解鎖。
geth --datadir ./data --networkid 55661 --port 2002 --unlock 5cc640ae524f70c39081d65bc699b3b61a67bd3f console
啟動後會看到這樣的結果,如果沒噴任何錯誤就是啟動成功了,同時會啟動一個 console 的互動介面,可以打像是 admin.nodeInfo 這類的指令來操作 geth。
在啟動訊息中有一段
INFO [04–18|12:01:31] RLPx listener up self=enode://87692411dd1af113ccc04d3f6d3d7d47366c81e595525c861c7a3c902ca0a86f46e8d7a837f431536822dbb012f68d942ed96910385805864e990efdf3839a1e@[::]:2000
由於目前是在 private chain 上,沒有設定啟動節點也沒設定 static node,各節點啟動後是沒辦法找到對方的。所以在此我們把 node2, singer1, signer2 都加入 node1 為自己的節點連上。geth 要連上對方的節點就必須好 enode://
在 node2, signer1, signer2 的 geth console 頁面分別打入指令
>admin.addPeer(“enode://87692411dd1af113ccc04d3f6d3d7d47366c81e595525c861c7a3c902ca0a86f46e8d7a837f431536822dbb012f68d942ed96910385805864e990efdf3839a1e@127.0.0.1:2000”)
完成後回到 node1 的 geth console 打入 admin.peers 應該要看到三個節點資訊。
到這步 geth 節點已經連上可以開始進行 PoA 挖礦和交易了。
啟動 Miner
到 signer1 的 console 打入 miner.start() 這時候如果你本機之前沒有啟動過 miner,geth 會先產生 DAG 等 DAG 產生完後就會開始挖礦了。
在 signer1 的 console 會出現正在 mining 的訊息。
其他節點則會收到 import block 的訊息。
Make a transaction
到這裡 Clique 的 Private chain 已經設定完成了,我們可以開始在這條鏈上做一些交易。接下來為了方便會使用 geth 的 console 來做 send ether 交易,如果你不習慣的話也可以使用 mist 這類的 UI 錢包來做。
node1 console
還記得在建立創世塊的時候有先給了 node1 和 signer1 的 address 一些 ether 吧?先用這令看看這些 ether 有沒有真的在鏈上。使用指令 ")" target="_blank">eth.getBalance("") 來查詢。
> eth.getBalance(“c7873030c2532aafe540d9dfd02a08330ee06465”)9.04625697166532776746648320380374280103671755200316906558262375061821325312e+74> eth.getBalance(“6d650780d493056f679a30b2c65cfa5e07835ad6”)0>
確定 node1 有 ether 但 node2 沒有,接著用 eth.sendTransaction 指令來把一些 ether 從 node1 轉到 node2 吧。
現在 node1 的 console 把自己的 Account unlock
> personal.unlockAccount("c7873030c2532aafe540d9dfd02a08330ee06465")
Unlock account c7873030c2532aafe540d9dfd02a08330ee06465Passphrase:true>
轉出 0.05 ether 到 6d650780d493056f679a30b2c65cfa5e07835ad6
>eth.sendTransaction({from:"c7873030c2532aafe540d9dfd02a08330ee06465", to:"6d650780d493056f679a30b2c65cfa5e07835ad6", value: web3.toWei(0.05, "ether")})INFO [04-18|12:39:53] Submitted transaction fullhash=0xa7a9da239b8f96b9f6fe4007ee88773915f034be2365b2dab234fd8c0545aa37 recipient=0xc7873030c2532aafe540d9dfd02a08330ee06465"0xa7a9da239b8f96b9f6fe4007ee88773915f034be2365b2dab234fd8c0545aa37">
如果你 singer1 的 miner 沒關掉的話,在幾秒後就會看到一個含有一筆交易的 block 產出
再來看看 node1 和 node2 的 ether
> " target="_blank">eth.getBalance("c7873030c2532aafe540d9dfd02a08330ee06465")9.04625697166532776746648320380374280103671755200316906558211535061821325312e+74> " target="_blank">eth.getBalance("6d650780d493056f679a30b2c65cfa5e07835ad6")50000000000000000>
交易完成!
加入一個新的信任節點
在 Clique 共識機制中是使用 Clique 提供的 API 來做節點管理,現在只 demo 加入節點進入信任名單。
signer2
signer2 是一開始沒設定在創世塊中信任列表的節點,如果這時候讓它啟動 miner 會怎麼樣呢?會噴一個未授權的錯誤
> miner.start()INFO [04-18|12:49:51] Starting mining operationnull> INFO [04-18|12:49:51] Commit new mining work number=46 txs=0 uncles=0 elapsed=284.189µsWARN [04-18|12:49:51] Block sealing failed err=unauthorized
必須回到已經在授權名單內的節點將新的節點加入。
signer1
回到 signer1 的 console 輸入加入的指令
> clique.propose("0x0fe2d8747d24156b342c9fa5c5e7138cf4047a8d", true)
singer2
接著回到 signer2 的 cosole
開始打包交易了
結語
由於 geth 1.6 才發佈不久,關於 Clique 的相關文章還蠻少的。提供如何使用 geth 1.6 建立一個 Clique private chain 的簡單教學,其實大部分都是我自己在建置時的筆記,內容省略了很多關於 Clique 的一些特性和原理,有興趣的建議直接看 ethereum/EIPs#225。希望這篇可以幫助到使用 geth 但又想用用 PoA 共識機制的同伴們XD