设为首页 收藏本站
查看: 805|回复: 0

[经验分享] git 入门学习笔记

[复制链接]

尚未签到

发表于 2018-1-13 08:31:47 | 显示全部楼层 |阅读模式
  学习参考廖雪峰的博客
  安装msysgit (模拟环境Git)
  安装后绑定邮箱和名字
  $ git config --global user.name "Your Name"
  $ git config --global user.email "email@example.com"
  创建一个空目录:
  $ mkdir learngit
  $ cd learngit
  $ pwd
  /Users/michael/learngit
  第二步,通过git init命令把这个目录变成Git可以管理的仓库:
  $ git init
  Initialized empty Git repository in D:/leargit/.git/
  安装了一个空的git仓库在什么路径下
  注:window下路径目录不能中文路径
  要用版本控制文件,就要以纯文本方式编写文件,其他的二进制文件git只能知道文件大小改变了,具体改变了什么git是不能知道的
  用msys的vim编辑readme.txt
  $ vi readme.txt
  按i键入插入模式,正常模式和可视模式都是不能编辑文件的。。。
  编辑文件
  Git is a version control system.
  Git is free software.
  编辑完成后回到正常模式(按Esc或Ctrl+[进入) 左下角显示文件名或为空
  :wq写入退出vim
  cat readme.txt 查看编辑的文件。
  把文件添加到版本库
  第一步,用命令git add告诉Git,把文件添加到仓库:
  $ git add readme.txt
  第二步,用命令git commit告诉Git,把文件提交到仓库:
  $ git commit -m "wrote a readme file"
[master (root-commit) cb926e7] wrote a readme file

  1 file changed, 2 insertions(+)
  create mode 100644 readme.txt
  简单解释一下git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
  git commit命令执行成功后会告诉你,1个文件被改动(我们新添加的readme.txt文件),插入了两行内容(readme.txt有两行内容)
  我们已经成功地添加并提交了一个readme.txt文件,现在,是时候继续工作了,于是,我们继续修改readme.txt文件,改成如下内容:
  Git is a distributed version control system.
  Git is free software.
  查看版本库状态
  git status命令可以让我们时刻掌握仓库当前的状态,上面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。
  现在,运行git status命令看看结果
  deii 1@XURAN /d/leargit (master)
  $ git status
  On branch master
  Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working d
  modified:   readme.txt
  no changes added to commit (use "git add" and/or "git commit -a")
  查看上次修改的readme.txt,所以,需要用git diff这个命令查看
  deii 1@XURAN /d/leargit (master)
  $ git diff
  diff --git a/readme.txt b/readme.txt
  index 16cd577..87aec63 100644
  --- a/readme.txt
  +++ b/readme.txt
  @@ -1,2 +1,2 @@
  -git is a version control system.
  -git is free sofware.
  +Git is a distributed version control system.
  +Git is free software
  在Git中,我们用git log命令查看更新记录
  $ git log
  如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数
  $ git log --pretty=oneline
  5a096c1ce57f6c50c97d587a37f81c4dbdd4e829 add 2 files
  b7159b26ba654c73dc6391eecd2c0cab0e45518a wrote a readme file
  一下就少了很多了。
  在把编辑后的文件添加
  $ git add readme.txt
  用git status 再次查看状态
  $ git status
  On branch master
  Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)
  modified:   readme.txt
  状态告诉我们readme.txt 修改了,没有提交
  提交
  $ git commit -m "add distributed"
[master 4b96eb1] add distributed

  1 file changed, 2 insertions(+), 2 deletions(-)
  再用git status 查看
  $ git status
  On branch master
  nothing to commit, working directory clean
  提示:没有需要提交,工作目录是干净的。
  准备把readme.txt回退到上一个版本
  Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本上一个版本就是HEAD^,
  上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
  1、$ git reset --hard HEAD^
  HEAD is now at ea34578 add distributed
  2、查看readme.txt的内容
  $ cat readme.txt
  Git is a distributed version control system.
  Git is free software.
  3、版本回归

  只要上面的命令行窗口还没有被关掉,找到那个append GPL的commit>  (可以是id的前面几位,但是不能一位两位,至少7位吧)
  $ git reset --hard 3628164
  HEAD is now at 3628164 append GPL
  4、版本记录和恢复
  当你用$ git reset --hard HEAD^回退到add distributed版本时,再想恢复到append GPL,

  就必须找到append GPL的commit>  找到你要的那个commit 的id就可以版本前进和后退了
  工作区和暂存区
  工作区(Working Directory)
  就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:
  版本库(Repository)
  工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
  Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
  前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
  第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
  第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
  因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。
  你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。
  5. 查看命令历史
  $ git reflog
  远程仓库(github)
  1. 在github上创建一个名为`learngit`的空仓库
  2. 在本地`learngit`仓库下运行命令
  $ git remote add origin ‘你的githup仓库’
  3. 把本地内容推送到github远程库上(第一次push 参数带 `-u` 关联远程仓库)
  $ git push -u origin master
  注意:如果在git push -u origin master时出现以下错误,证明电脑没有修改远程仓库的公钥,
  Permission denied (publickey).
  fatal: Could not read from remote repository.
  Please make sure you have the correct access rights
  and the repository exists.
  解决方法:
  1. 在github上点击`Edit profile` --> `SSH and GPG keys` --> `new SSH key` 添加SHH公钥
  2. 打开`id_rsa.pub`文件(/Users/iphone5solo/.ssh/id.rsa.pub)
  3. 将`id_rsa.pub`文件内容拷贝到key就可以了,title随便填。
  7.2 从远程库克隆
  1. 在github上创建一个名为`clonegit`的仓库
  2. 使用命令克隆仓库
  $  git clone 你的githup仓库
  7.3 从远程仓库更新本地仓库(已关联)
  $ git pull origin master
  **关于分支的主要命令如下**
  * 查看分支
  $ git branch
  * 创建`newBranch`分支
  $ git branch newBranch
  * 切换`HEAD`指向`newBranch`分支
  $ git checkout newBranch
  * 创建+切换分支
  $ git checkout -b newBranck
  * 合并某分支到当前分支
  $ git merge newBranch
  * 普通删除`newBranch`分支
  $ git branch -d newBranch
  * 强行删除`newBranch`分支
  $ git branch -D newBranch
  * 查看分支合并状况
  $ git log --graph --pretty=oneline --abbrev-commit
  ### 9. 藏匿当前未提交的分支
  如: 当前在修改自己的分支`dev`,突然项目经理要求修复一个bug-07
  解决方法:
  1. 藏匿当前`dev`分支的工作状态
  $ git stash
  2. 新建一个`bug-07`分支
  $ git branch -b bug-07
  3. 修复bug并提交,合并`bug-07`到`master`分支
  $ git commit -m "fix the bug-07"
  $ git checkout master
  $ git merge --no-ff -m "merge  bug-07" bug-07
  4. 删除`bug-07`分支
  $ git branch -d  bug-07
  5. 查看当前`stash`
  $ git stash list
  6. 恢复`dev`分支的工作状态,并删除stash内容
  $ git stash pop
  ### 10. 多人协作
  * 查看远程库信息
  $ git remote
  * 详细查看远程信息
  $ git remote -v
  * 推送分支到远程库
  $ git remote origin master
  * 抓取远程分支
  $ git pull origin master
  ### 11. 标签管理
  * 创建一个标签,默认为`HEAD`当前分支添加标签
  $ git tag v1.0
  * 为版本号为`e8b8ef6`添加`v2.0`标签
  $ git tag v2.0 e8b8ef6
  * 为版本号为`6cb5a9e`添加带有说明的标签,`-a`指定标签名,`-m`指定说明文字

  $ git tag -a v3.0 -m "version 0.2>  * 根据标签查看指定分支
  $ git show v0.2
  * 查看所有标签
  $ git tag
  * 删除`v1.0`标签
  $ git tag -d v1.0
  * 把`v0.9`标签推送到远程
  $ git push origin v0.9
  * 推送所有尚未推送到远程的本地标签
  $ git push origin --tags
  * 删除远程标签, 先删除本地标签,再删除远程标签
  $ git tag -d v0.9
  $ git push origin :refs/tags/v0.9
  学习过程中出现的问题:
  Git – fatal: Unable to create 'XXX/.git/index.lock’: File exists.的解决办法
  参考 http://blog.csdn.net/phenixyf/article/details/45366101
  1 若在window下远程打开操作窗口(不是console),进入.git目录删除index.lock文件,删除后再commit会自动再次生成index.lock。无法提交。
  2 使用putty console下操作,进入.git目录执行 rm -f index.lock 删除index.lock 虽然能删除,但是也是每次都会再生成。无法提交
  3 在.git同级目录,执行rm -f .git/index.lock (或者rm -f git/index.lock) 删除后可提交。成功!
  failed to push some refs to 方法
  $ git push -u origin master
  To git@github.com:dearMyFriend007/leargin.git
  ! [rejected]        master -> master (fetch first)
  error: failed to push some refs to 'git@github.com:dearMyFriend007/leargin.
  hint: Updates were rejected because the remote contains work that you do
  hint: not have locally. This is usually caused by another repository pushin
  hint: to the same ref. You may want to first integrate the remote changes
  hint: (e.g., 'git pull ...') before pushing again.
  hint: See the 'Note about fast-forwards' in 'git push --help' for details.
  出现错误的主要原因是github中的README.md文件不在本地代码目录中
  可以通过如下命令进行代码合并【注:pull=fetch+merge]
  git pull --rebase origin master
  执行这步后我的仓库里面的代码都没有了。
  附上大神整理的git命令
  http://www.cnblogs.com/vman/articles/Git_cmds.html
  查看、添加、提交、删除、找回,重置修改文件
  git help <command> # 显示command的help
  git show # 显示某次提交的内容 git show $id
  git co -- <file> # 抛弃工作区修改
  git co . # 抛弃工作区修改
  git add <file> # 将工作文件修改提交到本地暂存区
  git add . # 将所有修改过的工作文件提交暂存区
  git rm <file> # 从版本库中删除文件
  git rm <file> --cached # 从版本库中删除文件,但不删除文件
  git reset <file> # 从暂存区恢复到工作文件
  git reset -- . # 从暂存区恢复到工作文件
  git reset --hard # 恢复最近一次提交过的状态,即放弃上次提交后的所有本次修改
  git ci <file> git ci . git ci -a # 将git add, git rm和git ci等操作都合并在一起做 git ci -am "some comments"
  git ci --amend # 修改最后一次提交记录
  git revert <$id> # 恢复某次提交的状态,恢复动作本身也创建次提交对象
  git revert HEAD # 恢复最后一次提交的状态
  查看文件diff
  git diff <file> # 比较当前文件和暂存区文件差异 git diff
  git diff <id1><id1><id2> # 比较两次提交之间的差异
  git diff <branch1>..<branch2> # 在两个分支之间比较
  git diff --staged # 比较暂存区和版本库差异
  git diff --cached # 比较暂存区和版本库差异
  git diff --stat # 仅仅比较统计信息
  查看提交记录
  git log git log <file> # 查看该文件每次提交记录
  git log -p <file> # 查看每次详细修改内容的diff
  git log -p -2 # 查看最近两次详细修改内容的diff
  git log --stat #查看提交统计信息
  tig
  Mac上可以使用tig代替diff和log,brew install tig
  Git 本地分支管理
  查看、切换、创建和删除分支
  git br -r # 查看远程分支
  git br <new_branch> # 创建新的分支
  git br -v # 查看各个分支最后提交信息
  git br --merged # 查看已经被合并到当前分支的分支
  git br --no-merged # 查看尚未被合并到当前分支的分支
  git co <branch> # 切换到某个分支
  git co -b <new_branch> # 创建新的分支,并且切换过去
  git co -b <new_branch> <branch> # 基于branch创建新的new_branch
  git co $id # 把某次历史提交记录checkout出来,但无分支信息,切换到其他分支会自动删除
  git co $id -b <new_branch> # 把某次历史提交记录checkout出来,创建成一个分支
  git br -d <branch> # 删除某个分支
  git br -D <branch> # 强制删除某个分支 (未被合并的分支被删除的时候需要强制)
  分支合并和rebase
  git merge <branch> # 将branch分支合并到当前分支
  git merge origin/master --no-ff # 不要Fast-Foward合并,这样可以生成merge提交
  git rebase master <branch> # 将master rebase到branch,相当于: git co <branch> && git rebase master && git co master && git merge <branch>
  Git补丁管理(方便在多台机器上开发同步时用)
  git diff > ../sync.patch # 生成补丁
  git apply ../sync.patch # 打补丁
  git apply --check ../sync.patch #测试补丁能否成功
  Git暂存管理
  git stash # 暂存
  git stash list # 列所有stash
  git stash apply # 恢复暂存的内容
  git stash drop # 删除暂存区
  Git远程分支管理
  git pull # 抓取远程仓库所有分支更新并合并到本地
  git pull --no-ff # 抓取远程仓库所有分支更新并合并到本地,不要快进合并
  git fetch origin # 抓取远程仓库更新
  git merge origin/master # 将远程主分支合并到本地当前分支
  git co --track origin/branch # 跟踪某个远程分支创建相应的本地分支
  git co -b <local_branch> origin/<remote_branch> # 基于远程分支创建本地分支,功能同上
  git push # push所有分支
  git push origin master # 将本地主分支推到远程主分支
  git push -u origin master # 将本地主分支推到远程(如无远程主分支则创建,用于初始化远程仓库)
  git push origin <local_branch> # 创建远程分支, origin是远程仓库名
  git push origin <local_branch>:<remote_branch> # 创建远程分支
  git push origin :<remote_branch> #先删除本地分支(git br -d <branch>),然后再push删除远程分支
  Git远程仓库管理
  GitHub
  git remote -v # 查看远程服务器地址和仓库名称
  git remote show origin # 查看远程服务器仓库状态
  git remote add origin git@ github:robbin/robbin_site.git # 添加远程仓库地址
  git remote set-url origin git@ github.com:robbin/robbin_site.git # 设置远程仓库地址(用于修改远程仓库地址) git remote rm <repository> # 删除远程仓库
  创建远程仓库
  git clone --bare robbin_site robbin_site.git # 用带版本的项目创建纯版本仓库
  scp -r my_project.git git@ git.csdn.net:~ # 将纯仓库上传到服务器上
  mkdir robbin_site.git && cd robbin_site.git && git --bare init # 在服务器创建纯仓库
  git remote add origin git@ github.com:robbin/robbin_site.git # 设置远程仓库地址
  git push -u origin master # 客户端首次提交
  git push -u origin develop # 首次将本地develop分支提交到远程develop分支,并且track
  git remote set-head origin master # 设置远程仓库的HEAD指向master分支
  也可以命令设置跟踪远程库和本地库
  git branch --set-upstream master origin/master
  git branch --set-upstream develop origin/develop

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-434554-1-1.html 上篇帖子: window系统如何安装Git以及Git小乌龟,实现git命令 下篇帖子: Git的简单安装
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表