原文链接:https://blog.csdn.net/weixin_42083008/article/details/109574502
前言
github是一个面向开源及私有软件项目的托管平台,什么叫面向开源呢?说白了就是把代码共享,微软以前并不秉持着开源的态度,企图以windows占有率坐拥江山,可惜开源共享的大势谁都不能阻挡,哪怕是微软帝国。这不,斥资把这个国际知名代码托管平台github给收购了。
那有的同学会说,它有什么用啊,我也不需要把我的代码托管给保管呀。github除了叫代码托管平台,还有一个名字叫版本控制系统(类似的版本控制系统还有TFS、SVN等)。所谓版本控制,就是说一个成品东西有多个版本,比如写小说时,写到某一章,会有多高,在你发布之前这些稿都可能用到。而代码也是一样,在项目开发过程中,项目代码会有多个历史版本,开发人员可以回到任意版本(过去的节点)。比如开发人员小明,今天下班前提交了一下代码,第二天电脑硬盘被烧,数据全部丢失,那他就可以去服务器上找到历史最近提交的一次版本,并将代码拷贝下来。
本地代码备份到github仓库
好了,前面说的,假如公司项目代码就放在一台电脑上,哪天这台电脑嗝屁了,那就gg了。当然你可以把它再拷贝几份到其他电脑上,但是拷贝来拷贝去,一改动都要拷贝不是很麻烦吗?而且你也不能保证万一哪天都嗝屁了呢(#^.^#)。所以一般公司都有自己的服务器,项目一般是建在服务器上。我是平常自己玩,把代码放在服务器(我用的是http://github.com)上,这样子,在家,在公司都能随时更改代码并提交到github上,是不是很方便呢?
首先你得有一个github的账号,去github的官网:https://github.com/

到sign up 上面按步骤将你的昵称、邮箱、密码填上,并注册,之后登陆。
之后新建一个仓库(git的仓库就相当于你一个项目的储存空间)。如下图所示

进入你的仓库
点击绿色new按钮


建完之后如下图所示,里面什么都没有,是空的。下面有提示让我们create一些什么东西

注:到此为止,你相当于在远程服务器(这里是github)上面建了一个仓库(一个代码项目对应着一个仓库),之后需要我们把我们本地的代码和东西上传到github上对应的仓库上备份一份
现在,就需要去安装git工具啦
打开git的下载地址:https://git-scm.com/

点击这里下载,它会自动检测你的系统环境
安装完之后检测一下安装情况 ---cmd命令行(我这里只讲windows环境,其他环境大同小异)-----------win+r 回车

输入git --version (git的版本)
这个工具的命令都是以git开头,就像dotnet core 一样,所有命令以dotnet开头

ok,现在在你的电脑上git工具已经安装好了,(这一步相当于在本地安装了他git的应用,这个应用是我们用来连接服务器(github)的桥梁)
下面开始演示如何将项目上传到我们之前在github上建的仓库
首先进入你项目所在文件夹的根目录,右键 git bash here

进入到git的界面

在其他类似有命令行的地方也可以使用,比如vs code的终端,vs 的nuget 输出窗口,都是可以使用命令的
首先,我们需要初始化一下本地仓库,输入命令 git init

这条命令是把你本地的仓库给建立起来了,就是把你的项目文件给给他git的仓库标识一下,实际上就是在你的目录下建立了一个.git的文件 (没有找到的同学可以去把隐藏文件给打开)

第二步:将本地仓库和远程仓库对应起来
命令:git remote add origin huguangcheng/git-
git remote add 远程仓库名(可以自己定义,默认是origin,初学不要乱改,以免混淆) 远程仓库地址(在这里我填的是我之前建的仓库的地址)
远程仓库的地址,我们回到github的官网,到你的仓库里新建的仓库去:

把这个地址复制,就是你远程仓库的地址
命令回车之后,git就知道你本地这个项目仓库对应的就是github上的那个仓库了
第三步:上传项目或者代码到远程仓库
上传到服务器需要三步曲:
git add . -------------添加所有的文件到缓存区git commit -m "备注" ------------将缓存区的所有改动都给提交到本地仓库管理中心去
3.git push -u origin master ----------将本地所有改动提交都推送到远程仓库
master是github远程仓库分支(master是默认的主干,自己就是一条分支)
输入命令回车:

接着我们去我们的github上看看有没有东西:

这显示的是有的,至此我们的项目文件备份就算成功啦~就算电脑哪一天炸了我也能找回我的项目啦~
那备份有了,万一小编不小心,把公司服务器上的项目给弄炸了,该怎么找回来呢?
本地代码备份到github仓库
从远程仓库上拉取项目:
命令:git clone 远程仓库地址
我在本地一个文件夹git bash here

到下面这个位置点击按钮,复制地址(是https)

输入命令:git clone 远程仓库地址(这一个步骤其实已经将本地仓库和远程仓库对应起来了,后边不必再git remote 了)


东西也找回来了~
综合运用场景:
小编有一个自己学习的小项目,但是小编在家里写了,在公司没事也想敲一敲,学习学习,总不能复制一份到u盘吧,回去之后再赋值粘贴?
我们接着上一章讲,假如小编已经在公司把文件上传到github上了,回到家并且clone下来了,如前面所讲。现在小编写了西游记第二章。

然后晚上睡觉的时候我需要把东西上传到github上,以备在公司继续用
我们先看下此时有什么变动(有时候你可能改动比较多,比如.net项目,一个vs 的解决方案你改动几个地方可能有很多地方或者文件重新生成了)
git status

可以看到,他说我没有仓库
我们进入到下一级
cd git-
在git status

这里我们看到有红色的 改动
我们再重复三部曲 add commit push

我们再回到github刷新一下就看到

好了,第二天去公司,没事又能刷刷西游记了。嘿嘿。
注:关于文件丢失和代码丢失该如何找回,在我的另一篇文章里有提到,希望可以帮助到各位同学。有任何疑问的同学可以看我的签名,我们可以互相交流交流。