git使用小技巧

(1)一次添加多个文件的简单处理办法

依次z所有的文件,只需要一次commit提交文件即可;

(2) git status命令可以让我们时刻掌握仓库当前的状态;

(3)修改文件相关操作:

git status命令可以让我们时刻掌握仓库当前的状态;

git diff查看修改的是什么,以及修改前的文件,放心一些

git add readme.txt提交修改文件

运行git status看看当前仓库的状态

git commit -m "add distributed"提交修改

再用git status命令看看仓库的当前状态

(4)版本回退
回到以前:

git log命令显示从最近到最远的提交日志(以前的版本)

用HEAD表示当前版本

上一个版本就是HEAD^上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

可以使用git reset命令:git reset --hard HEAD^

回到未来(根据commit id)

git reflog回到未来的版本(可以查看这个commit id) git reset --hard 36281645

(5)删除文件

首先在本地仓库的目录文件夹中删除指定文件;

再在本地仓库中删除文件:

git rm 文件

git commit -m "remove"

在上传到github上面

git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。

(6)分支

分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。

现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。

默认状态下面是只有一条主干的(master)

创建新的分支:$ git checkout -b 新分支名称( git checkout命令加上-b参数表示创建并切换)

git branch命令查看当前分支:git branch命令会列出所有分支,当前分支前面会标一个*号。

切换回master分支:$ git checkout master

合并分支 git merge命令用于合并指定分支到当前分支 git merge 新的分支(分支合并之后就实现了吧分支上面的东西添加到主线上面了,在就可以删除分支了)

删除分支:$ git branch -d 新分支x删除分支后可以查看一下当前的分支,确保只有一条主线)

(7)远程仓库

因为一台电脑上搞几个远程库完全没有意义,而且硬盘挂了会导致所有库都挂掉,所以我也不告诉你在一台电脑上怎么克隆多个仓库。

实际情况往往是这样,找一台电脑充当服务器的角色,每天24小时开机,其他每个人都从这个“服务器”仓库克隆一份到自己的电脑上,并且各自把各自的提交推送到服务器仓库里,也从服务器仓库中拉取别人的提交。

完全可以自己搭建一台运行Git的服务器,不过现阶段,为了学Git先搭个服务器绝对是小题大作。好在这个世界上有个叫GitHub的神奇的网站,从名字就可以看出,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号,就可以免费获得Git远程仓库。

第1步:创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsaid_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

$ ssh-keygen -t rsa -C "youremail@example.com"
 

你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码。

如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsaid_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。

第2步:登陆GitHub,打开“Account settings”,“SSH Keys”页面:

然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:

github-addkey-1

点“Add Key”,你就应该看到已经添加的Key:

github-addkey-2

为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。

当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。

最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放进去。

如果你不想让别人看到Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法是自己动手,搭一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。这个方法我们后面会讲到的,相当简单,公司内部开发必备。

确保你拥有一个GitHub账号后,我们就即将开始远程仓库的学习。

要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git

关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

克隆远程库

$ git clone git@github.com:michaelliao/gitskills.git
 



原文地址:https://www.cnblogs.com/myFourLeaf/p/5229474.html