This is the biggest flaw and issue with the fediverse and Lemmy, it’s too damn fragmented with no good way to easily consolidate content from similar, or even identical, communities across instances. So people end up gravitating towards the same few that have the most content.
True, but the same issue happens with reddit as well, for example gaming vs games vs truegaming. Over time those communities either found their niche (gaming sub became mostly memes, games sub became news and discussions and truegaming tried to become a more serious discussing sub). Actually there were way more gaming subs but unless they found their niche they died out. So people gravitating towards specific communities is a natural occurrence.
As for trying to automatically consolidate communities across instances, it sounds like a great idea on paper but seems like technical she moderation headache, because you won’t have a clear source of truth. Let’s say instance A and instance B both have a community called news. The same news article with the same title is posted on both communities on both instances by different users. Assuming we want to consolidate those posts into one, which instance post will be shown or in more technical terms, which instance becomes the source of truth for that post? Who makes that decision? What if there’s also instance C with the same community and the same post but that instance isn’t federated with instance A, how do we consolidate posts? Each community has its own moderators and moderation rules, who is allowed to moderate the post? What if the moderation rules contradict between instances and both instances want to apply the rules independently, are they supposed to split the post?
Maybe there is an elegant solution to all the problems but I don’t see there being one. I’m not against the idea, the problem is you want to solve its something I have given some thought and because of that I just don’t see it working out the way you’re imagining it.
It would be a fundamental change, but communities should be global and not tied to instances. This would allow for the necessary centralization and reduce duplication. It could also be used to ensure communities survive a in instance going down scenario.
How would that even work? Imagine you spin up a brand new instance and create a new user and want to subscribe to a community. Because there is no one source of truth does the new instance simply not have the posts and comments that were made before the instance was created? If it’s supposed to get historic data as well from where is it getting from? Does it pick a random instance and pull all the posts and comments from that instance?
What if that instance is defederated from another instance with the same community and doesn’t contain the posts and comments from the defederated instance? Does your new instance have to go ask all the posts and comments from all the other instances to rebuild the community dataset on your instance? What if these two instances that are defederated both create the same post with the exact same content? Is that one or two posts?
What if user on one instance changes the name of the post but there’s some weird bug that allows only half the instances to register that change. Did that change actually happen or not? How do you solve the data inconsistencies if there’s no central source of truth?
What about moderation? There’s no central authority to define moderators or moderation policies. How do you verify who is actually a moderator and not someone trying to impersonate a moderator? What if different instances have different moderation policies, how would communities agree on a moderation policy if in essence both instances can claim authority over the community?
And these are still pretty high level questions. It would get more complex if we were to dig deeper into a possible solution. Even if it’s all technically solvable I think the solution would probably be so complex that it becomes unmaintainable which means it becomes unusable.
Setting up a new instance wouldn’t be significantly different than today. The difference would be instead of asking each instance individually for what communities they have you would use a distributed ledger to contain a list of communities with their primary and secondary instances. This would create the sigle source of truth for communities. As communities still have to physically exist somewhere, the designated primary instance would have the master record for the community and you could designate secondary instances for resilience and possibly spread out pulling that information.
Moderation doesn’t change significantly, primary instance admins would still be the fallback, but they could designate any user to be a moderator.
Defederation would be a little messy, but not a ton more than it is now. The primary would be the source of truth, if they don’t accept writes from an instance, then those posts and comments wouldn’t exist, (this is basically the same as one way federation now). If an instance wants to read from a community it’s on that instance to drop anything from instances they don’t federate with from the response from the primary.
As above, the primary instance is the source of truth, if a change doesn’t get there. There could be an eventually consistent cache on other instances for usability.
The difficult part would be how to handle changing the primary instance, or designating the primary for a newly created instance.
But that’s effectively what we’ll have right now. You can create multiple communities of the same name but one will eventually become the main community that people will visit. And we could already create “backup” communities because I’m pretty sure the data from the main community is already sent to all the instances that have users who are subscribed to said community. The data is already in other instances, it’s just a matter of reusing the data.
So the only crux of your solution is how the possible instance for the community would be chosen. And that’s a whole can of worms. It can’t be the same instance the community creator is a part of because that’s the solution we have right now. It can’t be completely random because I’m pretty sure there are instances that legally can’t have porn or piracy on their instance, or maybe the instance owner simply doesn’t want that on their instance. If there’s supposed to be distributed ledger that effectively prevents creating duplicate communities and that ledger is the same for all instances, then there must be a possibility that the new community ends up in an instance the community creators instance might be defederated from, otherwise a “pariah” instance (who are pretty much defederated from the majority of Lemmy) can reserve community names by defederating everyone and then creating communities. So that decision starts to have a lot factors which lets instances influence the decision. And in some ways there’s even an incentive to influence the decision because the more communities one instance has the more power they have over the entire lemmy side of the fediverse. If they defederate from another instance that instance can’t create those communities for the people on that instance (unless you go down the reddit route of having gaming vs games vs truegames).
And that’s just the decision of the primary source. There’s a whole other bucket of questions about the distributed ledger. For example how does the ledger change? If one community needs to be moved to a different instance who makes that decision? If it’s the primary source instance then how do other instances verify the ledger? If you have Instances A, B, C and C and instances A and B are defederated from C. Instance A has a community that gets assigned to instance D. Instance A sends a ledger change to instances B and D and then instance D send the change to C, but how does instance C know that the sent data is correct? Instance D could send the message that instance A set the community to instance B and there’s no way for instance C to verify that message. In fact most of my questions in my previous comment apply to the ledger as well because the ledger would have to exists on every instance.
And then there are other factors like what if Mbin sets up a community/magazine? Mbin doesn’t care about any ledger. Will we turn Lemmy into a walled garden and prevent Mbin from participating because they don’t want our ledger?
Backup communities don’t really exist right now. There are copies of things on other servers l, but they can’t become functioning communities. This has caused some communities to disappear when their instance went down. The biggest I remember is movies and TV related things.
Having a ledger helps with discovery, because instances now don’t know about other communities by default, it requires extra effort to seek them out until someone else has found them and subscribed. It’s not a big deal for established communities, but it does hurt building a new one.
I don’t have a great solution for admin of creation/movement of communities, but this isn’t meant to be a 100% solution. Distributed consensus is a concept that exists though. There’s no reason a community can’t go on a users instance as default, it just enables a community to potentially migrate for various reasons.
This doesn’t necessarily create a walled garden, as no one owns the walls. It does encourage everyone within Lemmy to maximally federate. I can’t say it significantly changes integration with other implementations as they were never very robust in the first place.
I think you’re now suggesting things that have nothing to do with consolidating communities.
Backup communities don’t really exist right now. There are copies of things on other servers l, but they can’t become functioning communities. This has caused some communities to disappear when their instance went down. The biggest I remember is movies and TV related things.
They don’t exists right now, but the foundation is there. I checked the old kbin.social communities that users from lemm.ee had subscribed to. All the posts seem to be there right until kbin.social got shut down. The data exists on your instance even if the original instance went down. It’s just a matter of figuring out and creating a new functionality to revive those communities on a new instance. This suggestion has nothing to do with consolidation, it’s just a backup solution that can already be done.
Having a ledger helps with discovery, because instances now don’t know about other communities by default, it requires extra effort to seek them out until someone else has found them and subscribed. It’s not a big deal for established communities, but it does hurt building a new one.
I don’t see how that specifically requires a ledger but I guess we can call it a ledger. The solution itself is fairly simple, each instance publishes whenever a new community is created or deleted and federated instances can store that data on their side to have a list of all the communities to search for. For already existing we can create a “publish all existing communities” so each instance can update their lists accordingly. That’s effectively a ledger but once again, it has nothing to do with consolidating communities.
I don’t have a great solution for admin of creation/movement of communities, but this isn’t meant to be a 100% solution. Distributed consensus is a concept that exists though.
Distributed consensus is a concept but is such complexity necessary? Especially when the end result isn’t that much different to what we already have.
There’s no reason a community can’t go on a users instance as default, it just enables a community to potentially migrate for various reasons.
It can, but it doesn’t really matter because that’s exactly how the current system works. As for migrations, if we solve the “backup community” problem then that functionality can just as well be used for migrations because right now we can just duplicate data. If you want to add the one community restriction that migration actually gets harder to implement.
This doesn’t necessarily create a walled garden, as no one owns the walls. It does encourage everyone within Lemmy to maximally federate. I can’t say it significantly changes integration with other implementations as they were never very robust in the first place.
Kbin/Mbin integrations with Lemmy worked pretty well, but if you force all Lemmy instances to use a solution unique to Lemmy then you’re pretty much building a wall because integrations with other similar implementations become less likely. Nobody owns the wall but it would create an “in” group and an “out” group. We already kinda have that with Lemmygrad and Hexbear and the rest of Lemmy, but those two instances can exists independently from the rest of Lemmy so the “in” and “out” groups can easily coexists. But if you force communities across instances you’re going to also force friction between the “in” and “out” groups. There can only be one “c/europe” but there’s one on Lemmygrad and there’s also one on feddit. If you keep the feddit one then Lemmygrad and Hexbear can’t have c/europe and if you let Lemmygrad have c/europe then the rest of Lemmy can’t have c/europe. It’s unnecessary friction.
I guess it would work if Lemmygrad and Hexbear were federated with the rest of Lemmy, but that’s not happening.
lol I’m trying to follow along with all your comments but it just feels like you’re trying to recreate reddit but with some type of block-chain servers handling the load instead of centralized servers.
Like, I get it. When you break it down, what’s the difference between reddit and Lemmy? You don’t like c/Games@lemmy.world, you can make c/Games@sh.itdoesnt.work. On reddit if you don’t like r/games, you can make r/games! or some other bullshit.
Only 2 big differences for me is 1. the hope that just having different instances gets people away from the “Main Hub” communities, 2. multiple instances means less chance of corporation enshittification. Your solution would just promote the eventual lose of both of the reasons I’m on Lemmy to begin with.
I do heavily encourage cross-posting though. Would love some sort of “tag” or something where it’s easier to cross-post to all of the communities that opt-in to be tagged in that category. Could have it so you can filter multi-posts using this feature so you’re not blanketed with the post if you’re subscribed to multiple communities in that category (could even choose a default like only the one with the most comments or your most active community gets highlighted while blocking all the rest, while still having the links in the post like how crosspost currently displays).
It’s not so much recreating reddit, as it is realizing that the content is the important part, not what server holds it. I want centralized content, because that’s how you get critical mass for communities to flourish. Decentralizing the ownership and hosting is where the federation benefits are anyway.
Ahh, I believe we just have a different perspective on what the best outcome for the lemmyverse is. If this place was as popular as Reddit I would want to see hundreds of communities for a subject and not have one that has a majority of users. You can have a main link one like r/science I guess that has super strict posting/commenting regulations and discussions get branched off into subcommunities maybe.
Honestly, even .ml feels too big for me atm and I’m thinking of switching out soon. I believe, if you actually use this site to engage in conversation and read through the links/articles people post, that you really only have time for a few interactions. If you’re just doom scrolling and voting away I guess I would want something like Reddit but I’m already neglecting conversations I want to have on here because there’s so many people and things to talk about all the time (and memes, can’t forget them).
The same way it does now, maybe more open as users could be from any instance. Instance admins could still have control of communities they are the primary for.
I would recommend a button that switches between local and all for a community. So people can look at it with their particular rule set in play if they wish.
That just gives you a jumbled mess of everything, which is IMO pretty useless. I want everything pertaining to a subject/interest in a single place, despite being scattered over multiple subs in multiple instances.
/all + new + comments is like my main use case, yet it’s frustrating because I can only view a tiny amount of comments at once, and only the first page of them. Hoping that gets fixed at some point.
This is the biggest flaw and issue with the fediverse and Lemmy, it’s too damn fragmented with no good way to easily consolidate content from similar, or even identical, communities across instances. So people end up gravitating towards the same few that have the most content.
While this is true, I think this post is more a reminder that .ml is garbage.
The fact alone that you made that comment proves otherwise
True, but the same issue happens with reddit as well, for example gaming vs games vs truegaming. Over time those communities either found their niche (gaming sub became mostly memes, games sub became news and discussions and truegaming tried to become a more serious discussing sub). Actually there were way more gaming subs but unless they found their niche they died out. So people gravitating towards specific communities is a natural occurrence.
As for trying to automatically consolidate communities across instances, it sounds like a great idea on paper but seems like technical she moderation headache, because you won’t have a clear source of truth. Let’s say instance A and instance B both have a community called news. The same news article with the same title is posted on both communities on both instances by different users. Assuming we want to consolidate those posts into one, which instance post will be shown or in more technical terms, which instance becomes the source of truth for that post? Who makes that decision? What if there’s also instance C with the same community and the same post but that instance isn’t federated with instance A, how do we consolidate posts? Each community has its own moderators and moderation rules, who is allowed to moderate the post? What if the moderation rules contradict between instances and both instances want to apply the rules independently, are they supposed to split the post?
Maybe there is an elegant solution to all the problems but I don’t see there being one. I’m not against the idea, the problem is you want to solve its something I have given some thought and because of that I just don’t see it working out the way you’re imagining it.
It would be a fundamental change, but communities should be global and not tied to instances. This would allow for the necessary centralization and reduce duplication. It could also be used to ensure communities survive a in instance going down scenario.
…
It’s still decentralized control, but the content becomes more searchable.
How would that even work? Imagine you spin up a brand new instance and create a new user and want to subscribe to a community. Because there is no one source of truth does the new instance simply not have the posts and comments that were made before the instance was created? If it’s supposed to get historic data as well from where is it getting from? Does it pick a random instance and pull all the posts and comments from that instance?
What if that instance is defederated from another instance with the same community and doesn’t contain the posts and comments from the defederated instance? Does your new instance have to go ask all the posts and comments from all the other instances to rebuild the community dataset on your instance? What if these two instances that are defederated both create the same post with the exact same content? Is that one or two posts?
What if user on one instance changes the name of the post but there’s some weird bug that allows only half the instances to register that change. Did that change actually happen or not? How do you solve the data inconsistencies if there’s no central source of truth?
What about moderation? There’s no central authority to define moderators or moderation policies. How do you verify who is actually a moderator and not someone trying to impersonate a moderator? What if different instances have different moderation policies, how would communities agree on a moderation policy if in essence both instances can claim authority over the community?
And these are still pretty high level questions. It would get more complex if we were to dig deeper into a possible solution. Even if it’s all technically solvable I think the solution would probably be so complex that it becomes unmaintainable which means it becomes unusable.
Setting up a new instance wouldn’t be significantly different than today. The difference would be instead of asking each instance individually for what communities they have you would use a distributed ledger to contain a list of communities with their primary and secondary instances. This would create the sigle source of truth for communities. As communities still have to physically exist somewhere, the designated primary instance would have the master record for the community and you could designate secondary instances for resilience and possibly spread out pulling that information.
Moderation doesn’t change significantly, primary instance admins would still be the fallback, but they could designate any user to be a moderator.
Defederation would be a little messy, but not a ton more than it is now. The primary would be the source of truth, if they don’t accept writes from an instance, then those posts and comments wouldn’t exist, (this is basically the same as one way federation now). If an instance wants to read from a community it’s on that instance to drop anything from instances they don’t federate with from the response from the primary.
As above, the primary instance is the source of truth, if a change doesn’t get there. There could be an eventually consistent cache on other instances for usability.
The difficult part would be how to handle changing the primary instance, or designating the primary for a newly created instance.
But that’s effectively what we’ll have right now. You can create multiple communities of the same name but one will eventually become the main community that people will visit. And we could already create “backup” communities because I’m pretty sure the data from the main community is already sent to all the instances that have users who are subscribed to said community. The data is already in other instances, it’s just a matter of reusing the data.
So the only crux of your solution is how the possible instance for the community would be chosen. And that’s a whole can of worms. It can’t be the same instance the community creator is a part of because that’s the solution we have right now. It can’t be completely random because I’m pretty sure there are instances that legally can’t have porn or piracy on their instance, or maybe the instance owner simply doesn’t want that on their instance. If there’s supposed to be distributed ledger that effectively prevents creating duplicate communities and that ledger is the same for all instances, then there must be a possibility that the new community ends up in an instance the community creators instance might be defederated from, otherwise a “pariah” instance (who are pretty much defederated from the majority of Lemmy) can reserve community names by defederating everyone and then creating communities. So that decision starts to have a lot factors which lets instances influence the decision. And in some ways there’s even an incentive to influence the decision because the more communities one instance has the more power they have over the entire lemmy side of the fediverse. If they defederate from another instance that instance can’t create those communities for the people on that instance (unless you go down the reddit route of having gaming vs games vs truegames).
And that’s just the decision of the primary source. There’s a whole other bucket of questions about the distributed ledger. For example how does the ledger change? If one community needs to be moved to a different instance who makes that decision? If it’s the primary source instance then how do other instances verify the ledger? If you have Instances A, B, C and C and instances A and B are defederated from C. Instance A has a community that gets assigned to instance D. Instance A sends a ledger change to instances B and D and then instance D send the change to C, but how does instance C know that the sent data is correct? Instance D could send the message that instance A set the community to instance B and there’s no way for instance C to verify that message. In fact most of my questions in my previous comment apply to the ledger as well because the ledger would have to exists on every instance.
And then there are other factors like what if Mbin sets up a community/magazine? Mbin doesn’t care about any ledger. Will we turn Lemmy into a walled garden and prevent Mbin from participating because they don’t want our ledger?
Backup communities don’t really exist right now. There are copies of things on other servers l, but they can’t become functioning communities. This has caused some communities to disappear when their instance went down. The biggest I remember is movies and TV related things.
Having a ledger helps with discovery, because instances now don’t know about other communities by default, it requires extra effort to seek them out until someone else has found them and subscribed. It’s not a big deal for established communities, but it does hurt building a new one.
I don’t have a great solution for admin of creation/movement of communities, but this isn’t meant to be a 100% solution. Distributed consensus is a concept that exists though. There’s no reason a community can’t go on a users instance as default, it just enables a community to potentially migrate for various reasons.
This doesn’t necessarily create a walled garden, as no one owns the walls. It does encourage everyone within Lemmy to maximally federate. I can’t say it significantly changes integration with other implementations as they were never very robust in the first place.
!showsandmovies@lemm.ee
I think you’re now suggesting things that have nothing to do with consolidating communities.
They don’t exists right now, but the foundation is there. I checked the old kbin.social communities that users from lemm.ee had subscribed to. All the posts seem to be there right until kbin.social got shut down. The data exists on your instance even if the original instance went down. It’s just a matter of figuring out and creating a new functionality to revive those communities on a new instance. This suggestion has nothing to do with consolidation, it’s just a backup solution that can already be done.
I don’t see how that specifically requires a ledger but I guess we can call it a ledger. The solution itself is fairly simple, each instance publishes whenever a new community is created or deleted and federated instances can store that data on their side to have a list of all the communities to search for. For already existing we can create a “publish all existing communities” so each instance can update their lists accordingly. That’s effectively a ledger but once again, it has nothing to do with consolidating communities.
Distributed consensus is a concept but is such complexity necessary? Especially when the end result isn’t that much different to what we already have.
It can, but it doesn’t really matter because that’s exactly how the current system works. As for migrations, if we solve the “backup community” problem then that functionality can just as well be used for migrations because right now we can just duplicate data. If you want to add the one community restriction that migration actually gets harder to implement.
Kbin/Mbin integrations with Lemmy worked pretty well, but if you force all Lemmy instances to use a solution unique to Lemmy then you’re pretty much building a wall because integrations with other similar implementations become less likely. Nobody owns the wall but it would create an “in” group and an “out” group. We already kinda have that with Lemmygrad and Hexbear and the rest of Lemmy, but those two instances can exists independently from the rest of Lemmy so the “in” and “out” groups can easily coexists. But if you force communities across instances you’re going to also force friction between the “in” and “out” groups. There can only be one “c/europe” but there’s one on Lemmygrad and there’s also one on feddit. If you keep the feddit one then Lemmygrad and Hexbear can’t have c/europe and if you let Lemmygrad have c/europe then the rest of Lemmy can’t have c/europe. It’s unnecessary friction.
I guess it would work if Lemmygrad and Hexbear were federated with the rest of Lemmy, but that’s not happening.
lol I’m trying to follow along with all your comments but it just feels like you’re trying to recreate reddit but with some type of block-chain servers handling the load instead of centralized servers.
Like, I get it. When you break it down, what’s the difference between reddit and Lemmy? You don’t like c/Games@lemmy.world, you can make c/Games@sh.itdoesnt.work. On reddit if you don’t like r/games, you can make r/games! or some other bullshit.
Only 2 big differences for me is 1. the hope that just having different instances gets people away from the “Main Hub” communities, 2. multiple instances means less chance of corporation enshittification. Your solution would just promote the eventual lose of both of the reasons I’m on Lemmy to begin with.
I do heavily encourage cross-posting though. Would love some sort of “tag” or something where it’s easier to cross-post to all of the communities that opt-in to be tagged in that category. Could have it so you can filter multi-posts using this feature so you’re not blanketed with the post if you’re subscribed to multiple communities in that category (could even choose a default like only the one with the most comments or your most active community gets highlighted while blocking all the rest, while still having the links in the post like how crosspost currently displays).
It’s not so much recreating reddit, as it is realizing that the content is the important part, not what server holds it. I want centralized content, because that’s how you get critical mass for communities to flourish. Decentralizing the ownership and hosting is where the federation benefits are anyway.
Ahh, I believe we just have a different perspective on what the best outcome for the lemmyverse is. If this place was as popular as Reddit I would want to see hundreds of communities for a subject and not have one that has a majority of users. You can have a main link one like r/science I guess that has super strict posting/commenting regulations and discussions get branched off into subcommunities maybe.
Honestly, even .ml feels too big for me atm and I’m thinking of switching out soon. I believe, if you actually use this site to engage in conversation and read through the links/articles people post, that you really only have time for a few interactions. If you’re just doom scrolling and voting away I guess I would want something like Reddit but I’m already neglecting conversations I want to have on here because there’s so many people and things to talk about all the time (and memes, can’t forget them).
. . . And how would moderation work?
The same way it does now, maybe more open as users could be from any instance. Instance admins could still have control of communities they are the primary for.
I would recommend a button that switches between local and all for a community. So people can look at it with their particular rule set in play if they wish.
That doesn’t solve the three different news communities, or the 5 dead communities that could have been one small one.
Yall can view All to right? I know it defaults to local, but you can press one button and see everything not defederated.
That just gives you a jumbled mess of everything, which is IMO pretty useless. I want everything pertaining to a subject/interest in a single place, despite being scattered over multiple subs in multiple instances.
I like the idea of having the ability to browse communities with the same name in one place.
Where you can set it to local to have it as it is now, and also being able to browse all of them at once.
/all + new + comments is like my main use case, yet it’s frustrating because I can only view a tiny amount of comments at once, and only the first page of them. Hoping that gets fixed at some point.
Have a look at https://piefed.social/ topics
Crossposting
That relies on users knowing every sub similar to the one they want to cross post to. It also still fragments comments to each instance.
Consolidation is still worse long term. There’s not that many competing communities.
Lock one community, pin a post to the community you are merging with. Done.
!casualconversation@lemmy.world as an example