It's not, though. Git is a means of distributing content, not the content itself. The thing analogous to PornHub's porn on GitHub is the source code in the repos hosted there, not Git itself.
Git is a DVCS. GitHub is a place where DVCS repositories are hosted. There are many other places where DVCS repositories can be hosted, but GitHub is the most famous one.. Porn is a type of content. PornHub is a place where porn is hosted. There are many other places where porn can be hosted, but PornHub is the most famous one. It's a pretty good analogy.
Depends on to whom. If you're explaining to your grandma, a small child, a co-worker, or a student under your tutelage, you probably don't want an explanation that relies on reference to a porn site.
And if you're explaining to a novice developer or to an IT person who sometimes might have to work with Git, they deserve an explanation that leaves them with a basic understanding (or at least the names) of the kinds of things Git and GitHub are (VCSes and SCM forges, respectively), not just an inkling that GitHub is not unique in being 'a place to host (some?) Git, whatever that is'.
So... if you don't mind that it suggests 'GitHub is for uploading Git(s)', that line is an okay way to teach 'the difference between Git and GitHub' to non-technical, non-elderly adults who don't really need to know what Git is (and don't work with you or study under you).
That's an explanation of pretty damn narrow usefulness, to put it generously.
Git is a distributed version control system for software development^1.
Version control allows you to manage code versions and changes to code. You take snapshots, so to speak, of every change you make.
Distributed, in this context, means multiple developers can write code on each of their development computers and merge the changes, usually to a centralized git server.
GitHub runs a web-based git server at GitHub.com so teams can store their code in a central location on the internet.
Ok, technically, even though It's often used for software source code, it can be used for any set of files and directories.
I don't see anything you said that it isn't quite right.
Porn is a distributed form of entertainment.
Porn allows you to get your rocks off. You take views, so to speak and do your thing.
Distributed, in this context, means multiple enjoyers can watch porn on each of their entertainment computers and share the videos, usually to a centralized porn server.
PornHub runs a web-based porn server at pornhub.com so viewers can store their porn in a central location on the internet.
Git is a program your computer runs to have a single folder have source control. It does all the hashing and commit chaining that you're used to, branches, that sort of thing.
But if you want it to be on more than one computer, you need to do this complicated "Bare" repository setup on a server computer to do the "git push" stuff you're used to.
Most people, being too lazy to learn bare repositories and the general sysadmin necessary to host a git server themselves, instead just use Microsoft's Github which is a web interface for the server use of git the program.
Microsoft then proceeded with their classic mantra of "Embrace, Extend, Extinguish" and started slapping on more and more features that are incompatible with any other git hosting service: actions, CI, their web VSCode instances, etc. That's all in GitHub too. But it's all just web interface for git the open source program, at the end of the day.
I like shitting on M$FT as much as the next bloke but if you believe Github started being evil when Microsoft entered the picture then your memory is pretty awful.
From it's inception github pushed proprietary tagging and issue numbers that have no meaning outside their platform and a difficult export process to trap projects - especially commercial ones - on their platform.
I remember moving a project from github to gitlab years ago (before MS) and the process to move all the non-git data from github was just as easy as moving the git repo itself. Thanks to gitlab's efforts perhaps, but I didn't expect github to have made it difficult for them based on the experience I ended up having.
I was being diplomatic because I was uncertain how people felt about the issue and PR tracking, considering how Bitbucket and GitLab replicate it. Felt simpler to focus on the since-M$ft egregious steps.
Just a few comments on this. Most people aren't "lazy", they just understand that the effort to run a bare repository is greater than basically any other solution. Also your incompatible features list implies that other git repo sites (gitlab, codecommit, bitbucket, etc) don't have their own form of proprietary stuff that you have to learn. In fact the newest version of gitlab actually changes their web ide into vscode web, because of the obvious, it is much better than their old ide.