Disclaimer: I like the Fediverse, Lemmy, and the concept of federation, I've been here for two years, and I feel grateful towards people working on this platform - devs and admins and mods and everyone else. As such, I hope that what I'm voicing is interpreted as constructive criticism and food for discussion.
TL;DR: I'll list some issues with Lemmy, how they relate to Reddit, and a few proposals on what should be done to address them.
The issues
When you're posting/commenting you're supposed to acknowledge and follow up to three independent sets of rules: of the comm, of the comm's instance, and of your instance. This is a burden for good users, and yet another excuse for bad users to ignore the rules.
There are also up to three groups of rule enforcers, in any situation: two admin teams and a mod team. If any of those goes rogue (greedy pigboy or powerjanny style), you got a problem.
Usually the ones enforcing the rules - the mods - are the group that, by design, lacks access to user info like IPs. So they either play whack-a-mole with old trolls under new accounts, or they rely on assumptions (i.e. stupidity) to keep control of their comms.
Your feed depends on which instances yours is federated with. So you either deal with the fact that you won't get content that you'd otherwise want, or you register into multiple instances to check multiple, partially overlapping feeds. One by one.
Federated instances mirroring content from each other causes sync issues (got removed from A, but not B? You'll still see it in B), storage issues (raising the requirements for people to create their own instances), and it's a big liability (cue to CP being posted to LW, and every single admin team removing it from their own instances).
The biggest instance (by MAU) is as large as the seven following instances combined. This sort of demographic concentration is bound to defeat the advantages of a federation (sharing the burden, sharing the power) without alleviating its cons (added complexity).
The top 10 instances is mostly populated by general purpose instances, doing redundant efforts to provide the same content to the users.
What do those issues have to do with each other?
Look at Reddit.
- Users want their own Reddit communities, but they can't build new "Reddit instances". So they create their communities as "vassals" (subreddits) of the single Reddit instance.
- Since you always post in the same Reddit instance as you registered to, there are no federation woes like "I want content from instance A, but I'm in instance B and they don't federate", or "admins of my instance vs. admins of the instance where I'm posting".
- Reddit cannot rely on other instances to provide content for its users. As such, it hosts all its content in a single, general-purpose instance.
I believe that, once you apply those three aspects of Reddit to a federation, you get the issues that I mentioned.
In other words those issues are born from trying to replicate a non-federation into a federation.
So, what should be done in your opinion?
I'm no coder, nor I want to pretend to be one, and I'm aware that some of those might not be viable. Still, if I had to propose something...
First of all, a change of paradigm: we (users: including mods, admins, developers, everyone) should see Lemmy first and foremost as a federation of forums and advertise it as such. Similarities with Reddit should be only secondary.
People who code in Rust would do an amazing job if they focused on instance creation and management. Ideally, it should be feasible even for a tech-illiterate granny running a potato computer to spin up her own instance.
I think that content mirroring needs to go away, with the users pulling the content straight from the instances where it's created.
Interface developers should expect users to have 2+ accounts, and to log into all their accounts at the same time. The resulting feed should be a combination of the feed of those instances; handle this through the interface/front-end. And when the user is posting/commenting, ideally they should be able to choose which account to use, on a per-community basis.
Desktop users should be encouraged to migrate from "my instance's website" to instance-agnostic front-ends, such as Alexandrite and Slemmy. [This doesn't affect mobile users, I believe.]
We should be contributing more to specific-purpose instances (for example: mander.xyz, ani.social, etc.), at the detriment of general-purpose instances (for example: lemmy.world). Perhaps, at the start even migrate our comms to those instances.
Eventually [in the far, far future] I think that the concept of subreddit-like communities should be deprecated, with communities becoming simple sub-forums of the instance where they're hosted.
By default, admins should focus mostly on the activity inside their own instances. Let the behaviour of their users in other instances up to those admins; a dog with two owners ends either overfed or starved.
When possible/reasonable, admins should be moderating more communities in their own instances.
I think most of the problems you mention I'm mitigating by hosting my own instance. And that makes me to see lemmy as a set of forums instead of a reddit alternative like you propose.
I would rewrite the second sentence into "As such, content it doesn't like is not possible to be hosted on their single, general-purpose instance."
Instance creation and management does not require coding skills. It's a very different skill set, one of system administration and web hosting.
I think it's the other way around, your feed depends on which instances yours is not defederated with. You can always kick in the federation with an instance by subscribing to their communities and then see all of those.
That is just a ugly workaround, I hope we can come up with something better.
It's interesting how, by hosting your own instance, your view over Lemmy changes. I hope that self-hosters like you become more common.
Or rather, "content not found in their single instance is not present in Reddit as a whole at all".
That's the point here - it's true for Reddit but false for Lemmy, as content available in one instance doesn't need to be hosted yet again in another.
I phrased it poorly. What I tried to convey is that easier instance creation and management should be a priority for coders, so other people have an easier time hosting/managing their Lemmy instances.
Ugly workaround or not, I believe that this would be still sensible given the current state of Lemmy. Because when people want content from non-federated instances, here are their current solutions:
So the current state of the things actively encourages you to hop into big, general-purpose instances. That is bad for the federation, and it aggravates the "three groups to rule you, three sets of rules to follow" problem.
Do you happen to have an alternative for this idea? Preferably, one that would work with the Lemmyverse now?
Alternative would be that defederation happens on user- not admin level, which we're getting closer to with 0.19 where users can block instances and don't need to rely on the admin. This hopefully will lower the need for admins to defederate so many instances them selves.
It might reduce the problem but I don't think that'll solve it, as in some situations instances will still defed each other. For example, where an admin says "users from that instance break my rules, I don't want to deal with it, defed time".