关于Git与Github的相关操作

请点击该链接,里面的内容已经十分详尽!!

以下是鄙人的一些总结:

git:

-----当安装成功后,因为git是分布式版本控制系统,你需要运行命令来配置你的用户名和邮箱:
$ git config --global user.name "superGG1990"
$ git config --global user.email "[email protected]"
注意:初次安装git需要配置用户名和邮箱,否则git会提示:please tell me who you are.

-----基本步骤:
1.先在github上新建一个远程仓库;
2.本地新建文件夹;
3.git init:把这个文件夹变成Git可管理的仓库;
4.把项目粘贴到工作区workspace;
5.git add 项目名:添加到暂存区index/stage,或(git add .)把该目录下的所有文件添加到暂存区,注意点是用空格隔开的;
6.$ git commit -m "注释内容":把项目提交到本地仓库repository;
7.在Github上设置好SSH密钥。(首先$ ssh -T [email protected]:验证是否已经配置成功)
本地创建ssh key:$ ssh-keygen -t rsa -C "[email protected]",剩余的步骤手动操作;

8.$ git remote add origin [email protected]:用户名/仓库名.git:将本地仓库和远程仓库进行关联;
9.$ git push (-u) origin master:将本地仓库repository主分支master内容提交到远程仓库origin的master分支,由于新建的远程仓库是空的,所以要加上-u这个参数,等远程仓库里面有了内容之后,下次再从本地库上传内容的时候,可去掉-u。


另外,这里有个坑需要注意一下,就是在创建远程仓库的时候,如果你勾选了Initialize this repository with a README(就是创建仓库的时候自动给你创建一个README文件),那么到了第九步你将本地仓库内容推送到远程仓库的时候就会报一个failed to push some refs to https://github.com/guyibang/TEST2.git的错。
这是由于你新创建的那个仓库里面的README文件不在本地仓库目录中,这时我们可以通过以下命令先将内容合并一下:$ git pull --rebase origin master【作用:拉取远程的文件把本地的覆盖,再上传】

a.Git中从远程的分支获取最新的版本到本地有这样2个命令:
  1. git fetch:相当于是从远程仓库获取最新版本到本地仓库,不会自动merge【合并】;
    首先从远程的origin的master主分支下载最新的版本到origin/master分支上
    然后比较本地的master分支和origin/master分支的差别
    最后进行合并 。
    即:从远程获取最新的版本到本地的tmp分支上,之后再进行比较合并
    git fetch origin master:tmp
    git diff tmp
    git merge tmp;
  2.git pull:相当于是从远程获取最新版本并merge到本地;
    git pull origin master
    上述命令其实相当于git fetch 和 git merge;
    在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并。

b.git中checkout和pull的区别:
  1.从远程仓库中下载新的改动;
    git pull origin master
  2.更新本地文件;
    git checkout file。
    pull只是单纯地把远程服务器最新的改动更新到本地,假如本地删除了文件或者修改了文件,则此操作不会更新本地的文件。
    本地删除了文件或者修改了文件,如果需要恢复,则直接从本地把文件checkout出来就可以了,用不着从远程服务器上pull下来。因为,所有的历史版本你的本地都有的。

c.git status:用于显示工作目录和暂存区的状态。使用此命令能看到那些修改被暂存到了(绿色), 哪些没有, 哪些文件没有被Git tracked到(红色)。

d.master指的是分支(branch)名字。一个仓库中默认的分支名字就是master,以后,你可以有别的branch。


如何操作?
-----创建版本库:
-----版本回退:git reset --hard HEAD^(一个^,代表回退一个版本。若要回退100个版本,
则:git reset --hard HEAD~100)。
-----理解工作区和暂存区:
-----撤销修改和删除文件:
-----撤销:3种方法【直接修改再重新来过、版本回退、checkout命令】。
-----删除:直接删或者rm命令。想彻底删除的话,再执行commit命令提交掉。
-----远程仓库:
-----配置SSH密匙;
-----远程仓库有了更新,如何克隆到本地仓库?: git clone [email protected]:用户名/仓库名.git;
-----创建与合并分支:
-----master分支就是主分支。HEAD不是指向提交,而是指向master,master才指向提交。所以,HEAD指向的就是当前分支。
-----查看当前分支:git branch;当前分支前面会添加一个星号。
-----创建分支:git branch name;
-----创建+切换分支:git checkout -b 分支名;【-b参数是指创建并切换】
-----切换分支:git checkout 分支名;

-----dev分支合并到master分支:git merge dev;
-----合并后可删除dev分支:git branch -d dev;
-----如何解决冲突?
-----知道冲突后,手动解决冲突,然后在合并分支;
-----分支管理策略:
-----git使用"fast forward"模式,这种模式删除分支后会丢掉分支信息。可以使用带参数 -no-ff 来禁用"fast forward"模式。
  Demo》合并dev分支:git merge -no-ff -m "注释" dev;合并后删除不会丢失分支信息;
-----分支策略:master主分支非常稳定,用来发布新版本,一般不允许在上面干活;干活一般情况下在新建的dev分支上干活,干完后,比如要发布或者说dev分支代码稳定后可以合并到主分支master上来。
-----bug分支:每个bug都可以通过一个临时分支来修复,修复完成后,合并分支,然后将临时的分支删除掉。
  --比如我在开发中接到一个404 bug时候,我们可以创建一个404分支来修复它,但是,当前的dev分支上的工作还没有提交;并不是我不想提交,而是工作进行到一半时候,我们还无法提交;Git还提供了一个stash功能,可以把当前工作现场 ”隐藏起来”,等以后恢复现场后继续工作【git stash】。

  --确定在哪个分支上修复bug;比如我现在是在主分支master上来修复的, 现在我要在master分支上创建一个临时分支issue-404;
  --修复完成后,切换到master分支上,并完成合并,最后删除issue-404分支。
  --现在,我们回到dev分支上干活了。
  --工作现场还在,Git把stash内容存在某个地方了,但是需要恢复一下,可以使用如下2个方法:
   这里可能使用到》git stash list:列举隐藏现场;
    1.git stash apply恢复,恢复后,stash内容并不删除,你需要使用命令git stash drop来删除。
    2.另一种方式是使用git stash pop,恢复的同时把stash内容也删除了。
-----多人协作:当你从远程库克隆时候,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且远程库的默认名称是origin。
  --要查看远程库的信息 使用 git remote;
  --要查看远程库的详细信息 使用 git remote –v;
-----推送分支:把该分支上所有本地提交到远程库中,推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:
  使用命令 git push origin master;
  如果我们现在要推送到其他分支,比如dev分支上,我们还是那个命令 git push origin dev;
-----那么一般情况下,哪些分支要推送呢?
  master分支是主分支,因此要时刻与远程同步。
  一些修复bug分支不需要推送到远程去,可以先合并到主分支上,然后把主分支master推送到远程去。
-----抓取分支:多人协作时,大家都会往master分支上推送各自的修改。
  --首先要把dev分支也要推送到远程去,如下:git push origin dev;
  --克隆远程的库到本地来:git clone 远程库地址;
  --现在我们的小伙伴要在dev分支上做开发,就必须把远程的origin的dev分支到本地来,于是可以使用命令创建本地dev分支:git checkout –b dev origin/dev;
  --小伙伴开发完成后把dev分支推送到远程库:add+commit+【git push origin dev】;
  --小伙伴们已经向origin/dev分支上推送了提交,而我在我的目录文件下也对同样的文件同个地方作了修改,也试图推送到远程库时:推送失败,因为我的小伙伴最新提交的和我试图推送的有冲突,解决的办法也很简单,上面已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后在本地合并,解决冲突,再推送。
  --git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,
   设置dev和origin/dev的链接:git branch --set-upstream dev origin/dev;
  --这回git pull成功,但是合并有冲突,需要手动解决,解决的方法和分支管理中的 解决冲突完全一样。解决后,提交,再push;

-----因此:多人协作工作模式一般是这样的:
  首先,可以试图用git push origin branch-name推送自己的修改.
  如果推送失败,则因为远程分支比你的本地更新早,需要先用git pull试图合并。
  如果合并有冲突,则需要解决冲突,并在本地提交。再用git push origin branch-name推送。


注意点:
1、写错远程仓库地址可以直接到.config配置文件中修改。

3、git checkout -- 文件名:未提交前,把文件在工作区做的修改全部撤销。
4、查看做了哪些修改:git diff 文件名
5、提交修改和提交文件是一样的2步【git add+git commit】。
6、查看历史记录:git log (--pretty=oneline:这个可以简化查看)
7、查看文件内容:cat 文件名;

Git基本常用命令如下:
mkdir: XX (创建一个空目录 XX指目录名)
pwd: 显示当前目录的路径。
git init 把当前的目录变成可以管理的git仓库,生成隐藏.git文件。
git add XX 把xx文件添加到暂存区去。
git commit –m “XX” 提交文件 –m 后面的是注释。
git status 查看仓库状态
git diff XX 查看XX文件修改了那些内容
git log 查看历史记录
git reset --hard HEAD^ 或者 git reset --hard HEAD~ 回退到上一个版本
(如果想回退到100个版本,使用git reset –hard HEAD~100 )
cat XX 查看XX文件内容
git reflog 查看历史记录的版本号id
git rm XX 删除XX文件
git remote add origin https://github.com/tugenhua0707/testgit 关联一个远程库
git push –u(第一次要用-u 以后不需要) origin master 把当前master分支推送到远程库
git clone https://github.com/tugenhua0707/testgit 从远程库中克隆到本地仓库

git checkout –b dev 创建dev分支 并切换到dev分支上
git checkout -- XX 把XX文件在工作区的修改全部撤销。
git checkout master 切换回master分支
git merge dev 在当前的分支上合并dev分支
git branch 查看当前所有的分支
git branch –d dev 删除dev分支
git branch name 创建分支

git stash 把当前的工作隐藏起来 等以后恢复现场后继续工作
git stash list 查看所有被隐藏的文件列表
git stash apply 恢复被隐藏的文件,但是内容不删除
git stash drop 删除文件
git stash pop 恢复文件的同时 也删除文件
git remote 查看远程库的信息
git remote –v 查看远程库的详细信息
git push origin master Git会把master分支推送到远程库对应的远程分支上

猜你喜欢

转载自www.cnblogs.com/lryepoch/p/10022160.html