antioch-network_subtitles.srt 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. 1
  2. 00:00:01,199 --> 00:00:05,680
  3. Ok, so what is the Antioch network?
  4. 2
  5. 00:00:05,680 --> 00:00:20,800
  6. Now, about a week ago or so…I think it’s two weeks ago now. The time flies. We were trying to make a small not very invasive upgrade to the Babylone network
  7. 3
  8. 00:00:20,800 --> 00:00:25,840
  9. which had been humming along for about, well, I want to say, three months or so.
  10. 4
  11. 00:00:25,840 --> 00:00:29,670
  12. Mainly to tweak a little bit of tokenomics parameters.
  13. 5
  14. 00:00:29,679 --> 00:00:38,160
  15. We wanted to increase the number of simultaneous proposals there could be. Just a few minor things like that to improve the effectiveness of the testnet.
  16. 6
  17. 00:00:38,160 --> 00:00:55,360
  18. And it wasn’t expected to be a big deal but what happened was not that long after the upgrade happened, so just for context, for people that may not know,
  19. 7
  20. 00:00:55,360 --> 00:01:08,080
  21. the blockchain system or variety that the Joystream platform is built on allows you to upgrade the rules of the chain itself in flight using a special kind of transaction.
  22. 8
  23. 00:01:08,080 --> 00:01:12,150
  24. And that’s great for lots of reasons that we’ll probably cover in the future.
  25. 9
  26. 00:01:12,159 --> 00:01:23,200
  27. And we tried to use this on-chain upgradability feature at this time, at that time, and that was supposed to be fine but what happened was in a matter of a few,
  28. 10
  29. 00:01:23,200 --> 00:01:34,240
  30. I want to say 20 blocks or so after the upgrade, there was a split in the network which ended up partitioning the validators into two separate polls.
  31. 11
  32. 00:01:34,240 --> 00:01:40,400
  33. One group thought that the new runtime was in play, and one group thought that the old runtime was in play.
  34. 12
  35. 00:01:40,400 --> 00:01:42,479
  36. That is obviously very undesirable.
  37. 13
  38. 00:01:42,479 --> 00:01:50,150
  39. The whole point of your consensus system is to have agreement upon what the history and, therefore, the state of your blockchain is.
  40. 14
  41. 00:01:50,159 --> 00:01:53,600
  42. So that’s obviously a serious problem.
  43. 15
  44. 00:01:53,600 --> 00:01:59,840
  45. And, you know, we’ve gone through a lot of effort trying to get to the bottom of what happened.
  46. 16
  47. 00:01:59,840 --> 00:02:09,520
  48. Trying to figure out the root cause of live failures and distributed systems is notoriously difficult, in particular if you haven’t actually
  49. 17
  50. 00:02:09,520 --> 00:02:15,360
  51. prepared yourself for trying to debug those sorts of failures to begin with which we hadn’t.
  52. 18
  53. 00:02:15,360 --> 00:02:25,200
  54. And so, we’ve gone through lots of different iterations of or, I should say, possible hypothesis for what the cause could be.
  55. 19
  56. 00:02:25,200 --> 00:02:34,800
  57. The best hypothesis that we have at the current time is that there is a specific bug in the version of substrate.
  58. 20
  59. 00:02:34,800 --> 00:02:42,640
  60. So, taking a step back here as well in case you don’t know, the joystick blockchain is built on the substrate blockchain framework
  61. 21
  62. 00:02:42,640 --> 00:02:47,680
  63. which is the framework that the Polkadot blockchain is built on.
  64. 22
  65. 00:02:47,680 --> 00:02:56,480
  66. And, in general, the framework that’s used to build pair chains which are blockchains that connect to Polkadot which Joystream itself may or may not end up doing.
  67. 23
  68. 00:02:56,480 --> 00:03:02,720
  69. It’s a great framework because it means you don’t have to focus on peer-to-peer networking or consensus
  70. 24
  71. 00:03:02,720 --> 00:03:08,950
  72. or any of these very low-level things similarly as if you were deploying on Ethereum, let’s say.
  73. 25
  74. 00:03:08,959 --> 00:03:14,950
  75. And it really allows you to focus on building exactly the business logic that’s specific to your blockchain.
  76. 26
  77. 00:03:14,959 --> 00:03:20,310
  78. So just mentioning where does this substrate thing come from.
  79. 27
  80. 00:03:20,319 --> 00:03:30,950
  81. So, we are using the substrate, we are using a specific version of substrate, it isn’t particularly new, and the best hypothesis we could really come up with,
  82. 28
  83. 00:03:30,959 --> 00:03:36,310
  84. for which there is limited evidence I should say, was that there was a specific kind of bug in the version of substrate
  85. 29
  86. 00:03:36,319 --> 00:03:43,120
  87. that we are relying on, and that’s the best candidate for what’s causing the failure.
  88. 30
  89. 00:03:43,120 --> 00:03:52,950
  90. So, what we’ve been working on for the past two weeks or so has been to obviously figure that out, and then to migrate to a newer version of substrate.
  91. 31
  92. 00:03:52,959 --> 00:03:55,590
  93. So, that’s what we have done.
  94. 32
  95. 00:03:55,599 --> 00:04:00,950
  96. We used to be on version two release candidate four, now we are on 201.
  97. 33
  98. 00:04:00,959 --> 00:04:10,480
  99. And we are going to be launching a new chain, namely the Antioch network, that’s probably going to be in two or three days from now
  100. 34
  101. 00:04:10,480 --> 00:04:15,510
  102. so that actually wrong on the slides because I just made them a few or a while back.
  103. 35
  104. 00:04:15,519 --> 00:04:28,080
  105. And that would be based on a new version of substrate which has benefits of its own, I should say, but we are mainly doing it to hopefully resolve this problem.
  106. 36
  107. 00:04:28,080 --> 00:04:34,960
  108. Of course, we would then get the runtime that we were trying to get initially with these improvements of the parameters for the proposal system
  109. 37
  110. 00:04:34,960 --> 00:04:41,750
  111. so on, there has also been some other changes to the way the council work.
  112. 38
  113. 00:04:41,759 --> 00:04:46,960
  114. I think we expanded from…Actually I don’t remember now, to be honest.
  115. 39
  116. 00:04:46,960 --> 00:04:50,000
  117. There are so many things going on but it is a bigger council.
  118. 40
  119. 00:04:50,000 --> 00:04:51,120
  120. The council period is not shorter.
  121. 41
  122. 00:04:51,120 --> 00:04:56,160
  123. So there are a few things that have happened that have independent benefits but the main issue here in Antioch
  124. 42
  125. 00:04:56,160 --> 00:05:06,080
  126. is really to get back to the core, use case that Babylon already had with these small improvements.
  127. 43
  128. 00:05:06,080 --> 00:05:09,120
  129. And then we are trying to get to Sumer as soon as possible.
  130. 44
  131. 00:05:09,120 --> 00:05:11,120
  132. So, that’s the story on Antioch.
  133. 45
  134. 00:05:11,120 --> 00:05:21,440
  135. It’s a big, you know, inconvenient departure from the focus that we had but we had to do it, and now Sumer is hopefully next within a short while.
  136. 46
  137. 00:05:21,440 --> 00:05:24,320
  138. So that’s it on Antioch.
  139. 47
  140. 00:05:24,320 --> 00:05:26,960
  141. Join me again for Sumer.