this post was submitted on 29 Apr 2025
248 points (98.4% liked)

Technology

69449 readers
4156 users here now

This is a most excellent place for technology news and articles.


Our Rules


  1. Follow the lemmy.world rules.
  2. Only tech related news or articles.
  3. Be excellent to each other!
  4. Mod approved content bots can post up to 10 articles per day.
  5. Threads asking for personal tech support may be deleted.
  6. Politics threads may be removed.
  7. No memes allowed as posts, OK to post as comments.
  8. Only approved bots from the list below, this includes using AI responses and summaries. To ask if your bot can be added please contact a mod.
  9. Check for duplicates before posting, duplicates may be removed
  10. Accounts 7 days and younger will have their posts automatically removed.

Approved Bots


founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] OsrsNeedsF2P@lemmy.ml 28 points 1 day ago* (last edited 1 day ago) (18 children)

Right? Git is literally decentralized. If you choose to use GitHub as a centralized Git service, that's on you.

(I will caveat this by saying we moved 2009scape off GitHub and the number of new contributors probably got cut in half. Mainstream services have a lot more eyes)

[–] Appoxo@lemmy.dbzer0.com 1 points 1 day ago* (last edited 21 hours ago) (13 children)

How come Git is decentralized?
Doesnt it need a central component so I can pull your changes?

Edit: Thanks to all that explained it to me :)

[–] kuberoot@discuss.tchncs.de 4 points 23 hours ago (3 children)

Fundamentally, the repository you have on GitHub is the same thing as the repository you have on your computer when you clone it. Pulling and pushing are shorthands for synchronizing commits between the two repositories, but you could also synchronize them directly with somebody else who cloned the repository. As somebody mentioned, you can also just host the same repository on two servers, and push to both of them.

The issue is that git doesn't include convenient features like issues, pull requests, CI, wikis, etc., and by extensions, those aren't included in your local repository, so if GitHub takes them down, you don't have a copy.

An extra fun fact is that git can be considered a blockchain. It's a distributed ledger of immutable commits, each one representing a change in state relative to the previous one. Everybody who clones a repository gets a copy of its entire history and fast forwards through the changes to calculate the current state.

[–] Appoxo@lemmy.dbzer0.com 1 points 21 hours ago (2 children)

But to push/pull you'd in theory need to port forward your git server/workstation, right?

[–] kuberoot@discuss.tchncs.de 1 points 9 hours ago

Git exposes a lot of internals through odd commands, so I suspect you could manage synchronization by sending changes over email or something.

Bonus fun fact: there's a git bundle command that "dumps" the repository into a single file, that can be interacted with as a remote. So if you're ever working with a local repository and want to put it on a server over ssh or something like that, you can just create a bundle, scp it over, and clone from that on the server.

[–] thevoidzero@lemmy.world 4 points 19 hours ago

Git works through ssh. So you need the same system as sshing into your machine. You just make a user group git and then let git and ssh handle things. And if you don't need people to push to your repo, then it's a lot easier as it's now similar to hosting a website/file server.

load more comments (9 replies)
load more comments (13 replies)