summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhil Burton <phil@d3r.com>2019-02-21 12:26:55 +0000
committerPhil Burton <phil@d3r.com>2019-02-21 12:26:55 +0000
commit33ee7c6ba6eee86dcadb0fa2b8781ae932c8e2d3 (patch)
treedac1ab08b6e36c6c09fc194bfb8665ed1cce491b
parentd13515f6e0eabe8fd58af996471ec4e5e8069e09 (diff)
SEcond talk on block chain
-rw-r--r--first-talk.txt2
-rw-r--r--second-talk-microservices.txt87
2 files changed, 89 insertions, 0 deletions
diff --git a/first-talk.txt b/first-talk.txt
index cbf2556..ffd2f65 100644
--- a/first-talk.txt
+++ b/first-talk.txt
@@ -1,3 +1,5 @@
+micro services - perf
+
glu mobile - 1st speakers company (microservices)
couch base
php_swoole
diff --git a/second-talk-microservices.txt b/second-talk-microservices.txt
new file mode 100644
index 0000000..199e557
--- /dev/null
+++ b/second-talk-microservices.txt
@@ -0,0 +1,87 @@
+Block chain
+
+- Block chain is a database
+- Bespoke data structure
+
+"Not crpyto"
+
+General Purpose block chain:
+
+Why?
+- Data in block is immutable
+- Don't edit or remove, you append
+- traceability (Auditing / logging)
+- Verifiability (Data must be fully valid)
+- reproducibility
+- decentralisation
+- Trust-less (Removes need for trust)
+- transparency
+
+How?
+- What type?
+ - public - will be hacked
+ - shared - shared ledger
+ - private
+- Cryptography
+ - pub/rivate keys
+ - sign information
+ - verifablity
+ - Elliptic Curves
+ - openssl ecparam -list_curves
+ - Addressing
+ - can shorten public keys massively
+ - Hash algorithm
+ - Integrity
+ - 2x sha256 (sha256(sha256($data)))
+ - 4B version, 32B hash of last Block, 32B hash of data block, 4B timestamp, 4B difficulty, 4B nonce
+ - Merkle tree - binary hash tree
+ - Merkle path - list of hashes through the tree
+ - Genesis block - First block in the chain
+ - Special as it's first
+ - Prevents exploitation by being hardcoded
+
+- consensus
+ - Confidence
+ - chain forking needs resolution
+ - bitcoin users longest chain wins
+ - proof of work / proof of stake
+ - difficulty is no of zeros that need to be at the start of the hash
+ - others (proof of burn, proof of time, proof of ....)
+
+
+- Smart contracts
+ - Programs that are included in the chain
+ - e.g. A loan paid by the chain
+
+- Lighting network (drawback off blockhain is it focuses on integrity not perf)
+ - Off chain transactions with on-chain settlement
+
+- Not all blockchains are chains
+ - IOTA Tangle
+
+- Challenges
+ - Fault tolerance
+ - You lose control of public/shared blockchains
+ - Now way to enforce software updates
+ - Conflict resolution
+ - Integration with current systems
+ - Security
+ - Cryptography is first and last line of defence
+
+- Not perfect for:
+ - scalability
+ - performance
+ - throughput
+
+- Incentives
+ - Mining in currencies
+ - Power for money
+- Privacy
+ - Protect data
+
+- Hard forks
+- 51% attacks
+
+- Right solution for the right kind of problem
+
+- Event sourcing on steroids