Chubby

Rationale Easier to migrate (from non-high-available to HA) Store/Fetch small files More familiar to programmers Reduce number of servers Lock Coarse-grained Hold for hours or days Lock-acquisition rate weakly related to client transaction rate Rare acquisition ->Temp lock server unavailability -> No big deal Should not lost lock when lock server reboot System Structure Client + Lib (Link) <-> Server (5 node) Chubby servers called replicas elect a master ask any replicas where the master is all replicas maintain identical database Only master read/write ack write after majority write read by master only Add new replica is one does not recover after a few hours Files Name ex: /ls/foo/wombot/pouch ls: common prefix (lock service) foo: name of a Chubby cell special name: local (local chubby cell) Operations Only whole file read No moving files from one directory (may served by different Chubby master) No soft/hard link Ephemeral Node (tmp files) Metadata ^a9d075 instance number: greater than any previous with same name content generation (files only): change when file are written lock generation number: increase when lock free -> hold ACL generation number: increase when ACL name change 3 ACL Name Checksum File handle ^e25fcd Check digit (No forging handle) Sequence number (if handle generate by previous master?...

March 18, 2022

Oneplus 8 driver

Unlock How to unlock bootloader for OnePlus smart Phone - OnePlus Support - OnePlus (United States) Fastboot Get the Google USB Driver | Android Developers Download and Install Android USB Drivers for popular OEMs (xda-developers.com) MSMTool [OP8][OOS TMO 55CB] Unbrick tool to restore your device to OxygenOS | XDA Forums (xda-developers.com) UPDATE: OnePlus 8 IN2017 T-Mobile to International (with Bootloader Re-LOCK) | XDA Forums (xda-developers.com) instantnoodlet_15_O.06_200411.zip | by Some_Random_Username for OnePlus 8 (androidfilehost....

March 12, 2022

Terminal Shortcut

Lunavim Tab: L H explorer: <space> e format: <space> lf find file: <space> f find text: <space> F Split panel: <C-w> v <C-w> s Close: <C-w> q switch panel: <C-hjkl> popout panel up down: Ctrl-n Ctrl-p goto definition gd move line up/down alt+j alt+k hover K line diagnostic gl Vim HALF Page up/down: <C-U> <C-D> Jump List <C-O> <C-I> Last command: @: word base w b e ge W B E gE...

March 7, 2022

Synology VPN Static IP

Setup a Static IP Address for OpenVPN Clients on your Synology NAS! (wundertech.net) Edit this file whenever the system upgrade /usr/syno/etc/packages/VPNCenter/openvpn/ccd/vpnuser ifconfig-push 10.5.0.10 10.5.0.9

March 2, 2022

Replicated State Machines

Each server stores a log (a series of commands) Its state machine executes the log in order Consensus algorithm ensure logs are consistent Key properties Safety: never return incorrect result available as long as any majority of servers are up Do not depends on timing A command can complete as soon as majority of the cluster responded (no wait for slow servers)

February 25, 2022