Greylisting on EOS

in #eos6 years ago (edited)

<p dir="auto">As of <a href="https://github.com/EOSIO/eos/releases/tag/v1.1.0" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">EOSIO release 1.1.0 (notably almost a month ago), support was added to "greylist" accounts. <p dir="auto"><a href="https://github.com/EOSIO/eos/issues/4368" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">[nodeos] Support for greylisting accounts, preventing access to the unclaimed resources in an uncongested chain (#4368) <p dir="auto">The reason why this was added, according to <a href="https://github.com/wanderingbort" target="_blank" rel="nofollow noreferrer noopener" title="This link will take you away from hive.blog" class="external_link">Bart (wanderingbort), is as follows: <blockquote> <p dir="auto">"...a malicious actor can impose a higher load on an idle network than their stake should allow. Congestion mechanics will prevent this from being a sustainable situation but, accounts which repeatedly abuse this feature should lose access to it." <p dir="auto">"Note, this would not prevent an account from transacting on chain nor would it impede the burst mechanics built into the system. It would only deny access to the additional resources that result from an idle chain in a "relaxed" state." <p dir="auto">Simply put, the goal of the greylist is to constrict access to perform actions beyond what is granted to an account based on their stake weighted limits. <p dir="auto">To be clear, <em>this is not a system of censorship (which could be done with a blacklist), but instead simply disallowing an account to go beyond their normal limits when the chain is underutilized. <p dir="auto">Why would this be used? Perhaps an analogy helps illustrate its need. <h1>A non-technical analogy <p dir="auto">Imagine that every day, you have lunch in the EOS cafeteria. The size of the lunch you receive, your resources, is determined by how many tokens you have staked. Every day, the kitchen in the cafeteria produces enough food so that if every person were to come claim their allowed lunch, there would be enough food for everyone. <p dir="auto">At the end of the lunch hour however, what ends up happening is that not everyone came and ate all their food. Perhaps they were not very hungry, or perhaps they were doing something else. So, the kitchen has leftovers. <p dir="auto">With these leftovers, the cafeteria allows anyone to come and get a second helping, beyond their allocated amount, in case they were hungrier than their allotment provided. <p dir="auto">However, an unfortunate situation can occur with the leftovers: a single account can queue up programmatically, eating up all the leftovers before anyone else has a chance to get seconds. Worse is if that account queues up for the leftovers, takes them all, then dumps it in the floor in front of you, when you just wanted a little more porridge. <p dir="auto">As the kitchen staff observes these individuals consuming all the leftovers, and sometimes wasting them, they could choose not to serve additional leftovers to these specific people. They would create a <strong>greylist of who these people are, and refuse them any of the leftovers. They aren't banning them from the cafeteria, nor are they refusing to feed them - they are just preventing these people from claiming seconds. <h1>Which accounts should be placed on the greylist? <p dir="auto">It is important to differentiate which accounts should be restricted from using beyond their normal limits, and which could be allowed. Being mostly a subjective choice, where each producer is able to decide their own list (as it is not a consensus feature), we believe each producer should be clear about their choices of whom to place on this list. To better explain our choices and our arguments, we will first present two different types of reasons why anyone might greylist an account, and explain how we will choose our list. <h2>What metrics should define restriction? <p dir="auto">Here are some example of metrics one might use to determine greylisting. <p dir="auto"><strong>Subjective metrics <ol> <li>"Unrealistic" usage (nothing "important" in the transactions) <li>"Unnecessary" blockchain bloat <p dir="auto">These subjective metrics are often touted as "Network spam". <p dir="auto"><strong>Objective metrics <ol> <li>Malicious or poorly written software that doesn't back off when detecting low resources <li>TX's that are sent to multiple API endpoints rather than to a single one <p dir="auto">Objective metrics like these are an attempt to address malicious behaviour: someone trying to step on your toes to get the leftovers before anyone else has a chance to. <h1>Our position on greylisting <p dir="auto">Understanding the above reasons why an account might be placed on any producers greylist, here we outline the argument for our decisions: we will only follow the objective metrics, rather than the subjective ones. <p dir="auto">The reason for this is as follows. It is impossible to determine what is "important" or not, as this is a subjective metric that depends on the individual. In the same lines, it is also hard to determine if blockchain bloat is "necessary" or not -- to one individual it might be useful for them, but for another it will not be. When placing an account on our greylist, we will only choose those that can be demonstrated to be performing clear violations of objective metrics. <p dir="auto">As a concrete example, we will take the account <code>blocktwitter (also <code>chaintwitter). It is clear that their usage applies to subjective metrics: many would argue several gigabytes of transactions, comprising of 192 million actions, which is ~95% of all EOS transactions to date, are not important. These transactions all say "WE LOVE BM", which is fairly unnecessary and probably do not need to be immutable forever. However, we need to look at the objective metrics. <ol> <li>This account has malicious or poorly written software. When a transaction is rejected by our API node, citing that they are out of resources, the account <em>immediately tries again by sending a new transaction, without even waiting for the next block. Their software should detect that the next transaction would not be accepted before sending it. <li>This account multicasts transactions to multiple endpoints. While unclear if intended to be a DOS attack, it is clear that this is done to attempt to avoid (1), i.e., the rejecting of new transactions when it becomes clear that usage has been exceeded. <p dir="auto">This account has continuously been performing these actions for over a month, and is the root cause of the inability for the average user to perform "regular" EOS actions -- their behaviour has completely removed anyone else's ability to use from the leftovers. <p dir="auto">For these reasons, we have decided to greylist the two accounts <code>blocktwitter and <code>chaintwitter. As a reminder, this is not a form of censorship -- they will still get their lunch just like everyone else. If they would like a bigger lunch (more "LOVE BM" messages), we recommended that they stake more EOS to do so, and not consume the community leftovers. <h1>A call to action to other Block Producers <p dir="auto">At the moment, we are the first top Block Producer to test greylisting in production. As such, during the period in which we produce blocks there will be more room for others to use the leftover resources -- but this single reduction may not be significant enough to better allocate global resources. We recommend other Block Producers to consider the above metrics we present, as well as their own, and consider greylisting accounts with objectively malicious behaviour. <p dir="auto">Finally, we would also push for development of better resource allocation strategies to avoid the need for this system entirely. An objective blanket that applies to all users will be a better solution compared to the need for Block Producers to be reactive.
Sort:  

Greylisting may be a temporary solution. We'd prefer that block one simply design a system to fairly allocate surplus. In the long term, this should not be a BP issue.

Agreed, it is a temporary solution to the problem using a tool we have at our disposal.

It's just unacceptable right now that users with 1-2 EOS staked can't even perform transactions, and the only reason they can't is the malicious behavior of one account, taking far too many resources from what should be shared.

Thanks for sharing - love the leftovers analogy.

I and many others understood from the original white paper that spamming would not be an issue in EOS. Here's an example discussion:

Its disappointing to see this doesn't seem to be the case.

This issue will be resolved and spam will not be an issue going forward.

Thank you for sharing and for attempting to make eos better for everyone.....

Great practical short term solution. Wonder if medium term solution would be to split excess resources equally over accounts (i.e. not stake weighted)? In long term more sophisticated solutions can be worked out.