Chronique d'un witness - HF20, freeze et plus encore
Bonjour à toutes et à tous.
Il est parfois difficile de faire une mise à jour de witness quand n'y a pas suffisamment de matière... Mais on va pouvoir remédier à ça.
Je vais profiter des derniers événements pour donner mon avis et aller un peu plus loin qu'un update.
Mais avant cela, on va commencer sagement.
Il faut sauver le soldat Dtube Community Support
Projet créé et maintenu par votre witness, il consiste à faire persister les vidéos dtube francophone sur un de mes serveurs dédiés.
Il se trouve que j'ai de gros problème de stabilité faisant planter très régulièrement mon noeud. Je songe à le migrer sur un serveur disposant de stockage très rapide.
J'espère pouvoir faire ça durant les congés d’août. Je croise les doigts.
SteemActivities
C'est le bébé de @sebbbl et @orlandumike auquel je contribue à ma façon.
Suite aux différents travaux de @planetenamek sur son bot de curation DiscoSteem-Bot, j'ai apporté quelques modifications facilitant le travail de curation.
Concrètement, le bot détecte automatiquement toutes les contributions #steemactivites et les partagent sur le salon discord associé. Ceci permet d'avoir un accès plus rapide aux contributions. D'autre part, un upvote permet de publier automatiquement un commentaire permettant de promouvoir le projet.
Dernier point, j'ai ajouté une fonction de optout pour les steemians ne souhaitant pas recevoir de commentaire de promotion (oui ce n'est pas très RGPD friendly).
Blockchain is freezing
On commence à attaquer le dur...
En début de semaine, la blockchain steem s'est entièrement arrêtée !!
Une dingueurie incompréhensible lorsqu'on est habitué à la résilience du Bitcoin.
Le sujet a été abordé dans plusieurs articles mais en gros, le compte @nijeah a réalisé un power down négatif.
Cette transaction invalide a bloqué la production de blocs de la part des witness.
Heusement, *Steemit Inc a réagit en quelques heures en proposant le correctif suivant https://github.com/steemit/steem/pull/2583/files. Suite à cela, les witness (mais pas tous) ont appliqué le correctif.
Période estival oblige, pas mal de witness n'ont pas encore appliqué le correctif et sont donc exclus de la production de blocs. C'est pour cela que mon witness a légèrement progressé dans le classement.
Au delà de ça, j'ai quand même deux réflexions à ce sujet...
Quand le sage montre la lune...
...l'idiot regarde de le doigt.
Suite à ce bug, un certain nombre de personnes ont accusé le witness @netuoso d'être à l'initiative de la transaction. Erreur de sa part ou exploitation intentionnelle, ce dernier s'est défendu d'être propriétaire du compte @nijeah.
Même si c'était le cas, ce n'est pas vraiment le plus important. Initialement, la blockchain le bitcoin fonctionne dans un système non coopératif et sans besoin de confiance. Par conséquent, les noeuds (full node) ne se font pas confiance pour valider une transaction.
De ce fait, une blockchain doit encore plus reposer sur un mode de fonctionnement paranoïaque... Et en développement, une des règles d'or est de ne jamais faire confiance aux données soumises par un utilisateur.
Je trouve donc effarent qu'on soit si rapide à accuser quelqu'un alors que la démarche serait de se demander pourquoi nous sommes passés à côté d'une faille aussi béante.
Une blockchain est ouverte au quatre vents et il faut donc partir du postulat qu'elle est plus exposée aux attaques... Et je tiens à dire que la bêta ne justifie rien.
Décentralisons le dev
Si j'aime bien comparer sur le plan technique Steem à Bitcoin, c'est qu'il permet de se rendre compte de certains écarts assez incroyables.
Une chose frappante est la diversité des noeuds sur le réseau. Il en existe en C++, en Node.js en GO. Et c'est vraiment là qu'on se rend compte de l'activité de la communauté. Si le développement est poussé par l'équipe Bitcoin CORE, la communauté est suffisamment résiliente.
Et sur STEEM ? il y a :
- steemd
- steemd
- steemd (j'ai failli l'oublier...)
Le malaise vient du fait qu'en l'état, le cycle de développement de la blockchain repose entièrement sur Steemit Inc. A quand de la diversité dans tout ça ? Je pense que cela permettrait d'avoir une expertise supplémentaire sur la compréhension du code.
HF20
C’est LE gros sujet du moment et qui anime les passions.
Steemit Inc a encore récemment fait une publication à ce sujet. Les promesses sont nombreuses :
- modification de la curation
- suppression de la limite des 20 secondes entre chaque commentaire
- expiration des ordres de marchés
- création de compte à prix réduit
- meilleur allocation des ressources
Mais ici, je ne vais pas m’étendre sur chaque nouveauté et correctif. Je vais me concentrer sur l’aspect suivant.
With the current blockchain rules, if authors vote for themselves right away, they get their author rewards, plus 100% of the curation rewards from their vote, plus a portion of the curation rewards coming from everyone who votes for the post after them. Any other curator voting at the same time as the author would get 0% of the curation rewards. This gives the author an unfair advantage over other curators, because the author can earn additional curation rewards through self-voting.
In order to eliminate this advantage, the unused portion of the curation rewards will be returned to the rewards pool instead of being awarded to the author, thereby increasing the overall percentage of rewards that will be paid to curators. This will better serve the original mission of the curation rewards budget: to ensure that the Steem blockchain distributes rewards to the most valuable content.
self vote VS HF20
Steemit Inc explique à juste titre que le self automatique est assez injuste. En plus de ne pas participer à la part des curateurs (100% du vote revient à l’auteur), l’auteur va en plus récupérer une bonne partie de la curation (les 25%).
Pour rappel, quand un vote est réalisé dans les 30 premières minutes, une partie du vote est directement distribué à l'auteur (et pas dans la curation). Par exemple, a 0 minute, l'ensemble du vote est affecté à l'auteur (et rien à la curation).
Si Steemit Inc parle d’une répartition 75% (auteur) / 25% (curateur), la réalité tend plus vers 80/20 (voire plus pour l’auteur).
@paulag a récemment publié une petite étude statistique sur la curation dans la fenêtre des 30 minutes. Vous la trouverez ici.
On y apprend que :
- 47% des votes sont réalisés durant les 30 premières minutes;
- 27% des votes sont réalisés durant les 15 premières minutes;
- 84% des self votes sont réalisés durant les 30 premières minutes;
- 78% des self votes sont réalisés durant les 15 premières minutes.
Si ces chiffres indiquent l'utilisation massive du self vote, ils ne permettent pas de se faire une idée de son impact sur le reward pool. @paulag indique qu'il n'est pas vraiment possible de se faire une idée précise à ce sujet, elle tente tout de même une approximation via une note basée sur le nombre de vote, le nombre de Steem Power et le poids moyen du vote.
On trouve donc ceci.
Ce qui donne sur le mois de mai le top auteur suivant.
Crédit : @paulag
Malheureusement, je n'arrive pas à trouver de données récentes sur la distribution des récompenses.
Ce que promet le HF20, c'est de réduire la fenêtre de 30 à 15 minutes et de redistribuer le non-gain de curation au reward pool...
Pour illustrer mon propos, voici quelques exemples.
Lorsque que vous utilisez l'option self vote de busy, 100% de la curation ira à l'auteur. En HF20, 25% du vote ira dans le pool de récompense.
Lorsqu'un curateur vote à 15 minutes (7min30 en HF20), 75% plus 12.5% (50% des 25%) ira à l'auteur. En HF20, 12% du vote restera dans le pool de récompense.
Par conséquent, la récompense maximal de l'auteur sera capée à 75%.
Pour résumer, le système a été créé pour luter contre le vote automatique. Il a été contourné en permettant aux auteurs de récupérer une partie des 25% de curation.
Le HF20 vise à lutter contre cette dérive...
Une HF20 pour que les riches deviennent plus riches
C'est la thèse soutenue par @davemccoy dans l'article suivant. Redistribuer dans le pool de récompense n'est pas sans conséquence. En effet, ce dernier est réparti en fonction des votes de chaque publication. Ce qui veut dire que votre self vote à 1 cents sera redistribué aux plus gros articles...
Pire encore, l'usage des bid bots permettra de récupérer vos précieux self vote...
Mais attention, le but de Steemit Inc est bien de désinciter le self vote dans les 15 premières minutes.
Concrètement, il faudra que les fronts ends comme condenser (steemit) et busy :
- désactivent l'option de self vote durant la rédaction de la publication
- Avertissent les steemians souhaitant voter durant la fenêtre de 15 minutes
Néanmoins, il subsiste un problème plus gênant. Comme le décrit @tcpolymath dans sa réponse, il y aura également une désincitation forte pour les curateurs souhaitant voter un article publié dans les 15 premières minutes. Imaginons que je tombe sur article publié il y a 7,5 minutes, ais-je vraiment envie qu'une partie de mon vote reste bloqué dans le pool de récompense ?
Heureusement que la fenêtre a été réduite à 15 minutes...
Je suis donc assez dubitatif sur cette évolution. Si je pense que le système est beaucoup trop contournable, je ne suis pas certain que la HF20 aille dans le bon sens.
L'usine à gaz
La curation est un élément majeur de l'écosystème steem. C'est tellement important que le HF17 avait été rejeté par les witness.
1- En récompensant les premiers curateurs d'une publication, Steem Inc vise à promouvoir la recherche de contenu encore sous évalué;
2- Pour éviter que des bots votent en premier, Steemit Inc a instauré un système de "punition". Un vote anticipé récompense l'auteur au détriment du curateur trop pressé;
3- Pour éviter que l'auteur détourne le système à son avantage, on fait en sorte que son vote reste dans le pool de récompense;
4- Pour éviter le détournement du pool de récompense, on... ah zut, je suis dans le futur là.
Vous comprenez la complexité à créer un système juste?
Voter avec ses pieds
Alors après tout ça, on pourrait me demander de ne pas appliquer le hardfork.
C'est tout à fait possible, mais sur steem, c'est marche ou crève. Lorsqu'il y a eu consensus dans le top 20 witness (plus de la moitié), le reste des witness n'ont plus qu'à suivre. Une refus de passer le HF revient à une exclusion dans la production de blocs.
Et contrairement à une blockchain classique, un HF sur *steem ne provoque de séparation de chaîne.
Vous aurez donc compris que pour les witness comme pour les steemians, le meilleur moyen de "protester" contre une consensus majoritaire est de trouver ceci...
Pixabay
You can find me on steemit.chat and on the discord of @francosteemvotes (https://discord.gg/XFGr4jG) / PAL / Busy
If you like my works, you can vote for me as a witness ( Vote with steemconnect)
Last Post :
- Le premier poulet blockchain
- Les projets que je soutiens
- [Dtube Community Support] Bilan 07/04/2018
- Dtube Community Support - un bot qui aidera la communauté dtube francophone
- Une app pour suivre les métriques financières de steem
- Tout savoir sur la création du SBD
- My Contribution as a witness
- Choisir son mode de récompense
- Comment les récompenses sont-elles calculées ?
- Steem, il faut qu'on parle (volume 2)
My App :
- Discord Community Support : Github / Utopian publication
- Steem Supply: App / Github / Utopian publication
- GetMyWitness : App / Github / Utopian contribution
- Show My reward : App / Github / Utopian publication
Super chronique de witness, bravo ! Je dois dire que je n'avais pas bien compris les implications du changement au niveaux des votes et que tu m'as pas mal ouvert les yeux, tout ça me laisse perplexe... Sinon, tu as fait une erreur quand tu parles du freeze de la blockchain. Ce n'est pas un power down supérieur au nombre de vests de @nijeah qui en est la cause mais un power down à nombre négatif de vests (comme indiqué sur la pull request que tu as linké).
Merci beaucoup pour ce post sans langue de bois et pour tous ces éclaircissements. Le parallèle avec la blockchain Bitcoin aidant effectivement à mieux comprendre certaines choses. Pour ma part c'est le post d'un grand et intègre Witness!
Des explications simples et exhaustifs sur les différents événements ainsi que sur ce que l'avenir nous réserve au sujet du fameux HF20. Un point de vue juste de la part d'un witness ! Upvoté à 100% !
Faire planter la blockchain est le meilleur moyen de faire rapidement réagir les devs de Steemit Inc. Même si j’aurait préféré qu’il fasses ses tests (si c’était intentionnel) sur le testnet, je me demandes si le patch aurait été développé aussi rapidement.
La décentralisation du developement de steemd est ouverte à tous. Tout developeur peut faire un fork du repo github et faire ses propres modify et en soumettre l’appli resultante aux top 20 witness. Et pkoi pas réécrire dans un autre language également. En outre la connaissance profonde de la blockchain et du code de steemd il faut aussi surmonter l’obstacle qui est de convaincre les autres witness a utiliser la nouvelle version.
Tout à fait. Mais ça permettrait d'avoir une plus grande base dans la communauté de dev impliqué.
Ça fait plaisir de revoir cette chronique toujours aussi qualitative.
Je suis d'accord avec toi, je trouve ça complètement dingue qu'un tel bugue soit resté sans correction jusqu'à ce que la blockchain.
Concernant le HF20 je suis dubitatif, il est censé apporter des solutions à certains problèmes et au final il complexifi la situation en apportant de nouveaux casse-têtes et en apportant des solutions à des problèmes inexistants. On a attendu 7 mois une nouvelle mise à jour pour ça ? Ce HF20 et le freezer de la blockchain ne font que montrer l'incompétence de Steemit in et la mauvaise gestion de Steem. La direction de Steem est bien trop centralisée donc personne n'a les moyens de contrebalancer les multiples inepties de Steemit inc.
Tu dis que tu as peu de moyen pour t'opposer à ce nouveau HF et c'est là une preuve supplémentaire que Steem n'est rien d'autre qu'un projet non fini et abandonné par son créateur.
Le seul moyen de protester serait de recréer Steem ailleurs et autrement. Tout détruire pour reconstruire, en mieux.
Hey, tu sais que c'est pareil pour EOS ? lorsqu'un consensus est réalisé, il n'est pas possible de dire non.
Mais je ne suis pas d'accord, si je suis aussi critique c'est qu'in fine, j'aime steem... Dans le cas contraire, je ne dirais rien. La HF20 est intéressante à bien des égards. J'espère la création de compte discount ainsi qu'une meilleur gestion de la BP améliorera l'expérience utilisateur.
J'attend également SMT de pieds ferme.
Depuis HF18 et 19, la curation a grandement été améliorée.
J'insiste également que steem est la brique bas niveau et que steemit.com est un des cas d'usage. Il est tout à fait possible de créer son propre frontend nettoyé de la merde. Fundition est un exemple, il suffit :
J'attends justement qu'on n'attende plus tout de Steemit Inc. Et c'est un peu ce qu'ils cherchent à faire.
Le problème c'est qu'actuellement il n'y a que Steemit inc qui développe Steem, comparé à d'autres cryptos la communauté est très peu impliqué. Il y a beaucoup de gens qui développe des dapps ce qui est très bien mais il faudrait aussi penser un peu au backend.
Beaucoup d'informations, merci pour la mention du projet et ces explications!
Il me parait clair que tu es un vrai passionné du steem, pour encore être witness, merci pour ce que tu fais pour la communauté