windows下貌似已经有了很不错的GUI 但是比较耗费资源,所以研究了一下github的shell命令
首先发两个传送门
https://help.github.com/articles/set-up-git ——github的官方简单入门
http://www.worldhello.net/gotgithub/index.html ——某大神蒋鑫的个人网站中关于github的部分讲解
本篇文章中的很多内容来自以上两个网站 同时又结合了自己小白的特点 把其中最简单实用的部分 结合自己的理解记录了下来
1. 什么是git和github
git本来是为进行linux内核源码编写而开发出来的工具,听说过git的同学一定都知道“版本控制”的说法。而github就是一个以git为基础的网络代码或者文件仓库。
2. 在本地登录github
如果下载了github for windows 只要在GUI中登录一下 就会自动把用户密码配置好 并且保存起来
如何在命令行验证是否配置好用户密码了呢?
输入命令:
ssh -T git@github.com
如果返回结果
则证明登入成功
3. 利用github建立资源库并且与本地资源库建立联系
最简单的方式是在github网站建立资源 这步比较简单 不再赘述
说起建立联系一般有两种情况,下面一一进行表述
3.1. github中有我们想要的资源,我们需要下载到本地并且进行track(包括进行修改等)
这种情况很简单,就一句命令
git clone git@github.com:lawlietxxl/testGithub.git
成功!
下面进入该文件夹,我们能看到很神奇的东西
master表示testGithub这个资源对应的master的branch(分支),浅蓝色表示没有提交(猜测,待定)
然后我们尝试做一些改变 任何改变都可以
发现master后面有着 +0 ~0 -1 的字样 表示 我刚刚删除了1文件,改动0文件,增加0文件;并且红字代表着我们并没有加入到index索引中,github并没有跟踪到改变的文件
为了把这些改变的内容加入到索引,我们输入命令
git add -A . (-A表示将删除也算作改变之中)结果:
后面的数字变绿了,表示已经成功加入index索引,但是没有提交给远程服务器
输入命令
git commit -m 'test' (-m表示提交commit的时候显示的commit信息,可以在github的网页上显示出来)
结果
mater字符变成了绿色(猜测,待定)
3.2. 本地有我们想要上传到远地服务器的资源
我们先去建立一个新的资源 我的叫做testGithub2
赫然发现 建立完毕之后自动跳转到一个帮助页 把命令全都写好了
当我们按照文章输入到origin那一句命令时可能会出错:
fatal: remote origin already exists.
这说明在远程服务器上origin这个名称已经指向某一个资源库了 所以我们可以换一个名字
git remote add origin2 git@github.com:lawlietxxl/testGithub2.git (表示在远程服务器上 origin2这个名字指向testGithub2.git这个资源库)
git push -u origin2 master (表示把本地master分支推向origin2指向的资源库)
#################################################################################################这里需要注意的是:上文中的实际上是一个空资源库,但是如果你建立了一个README的话,当再次按照上文操作,就会出现问题
error: failed to push some refs to 'git@github.com:lawlietxxl/ClawlerPython.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Merge the remote changes (e.g. 'git pull')
hint: before pushing again.
所以我们需要先把资源从github上拉到本地,然后再进行push就不会报错了,这样github中的资源也在了,我们要推送的东西也在了,就同步了
git pull origin2 master
git push -u origin2 master
#################################################################################################
4. 利用github为资源建立分支(branch)
下面是比较有意思的地方了 因为我们使用github的目的其实就在于此
当我们用3中说的方法将本地与remote联系起来后,我们通过shell进入到资源文件夹,后面显示的就是分支名称(default为master)
输入命令
git checkout -b mybranch
这样就会进入名为mybranch的分支下
然后我们进行更改资源 add commit push 就可以添加并且更改一个新的分支
关于这一部分还是需要多动手 多探索才行 下面写出一些十分常用的命令 以作备忘
git checkout -b newbranch (新建一个名为newbranch的新分支)
git checkout master (进入master的分支中)(并且会在本地更新文件 神奇!)
git branch -m newname 重命名
这一部分不截图了
待续