Git

git

git基本操作

获取与创建项目命令

  1. git init : 初始化一个Git仓库,执行完后会生成一个.git

    创建一个项目(空文件夹或者已有的项目),在终端中打开这个项目,执行仓库初始化。

    $mkdir runoob
    $cd runoob/
    $git init
    Intialized empty Git repository in /user/tuanqixin/www/.git/
    # 在/www/runoob/.git/目录初始化空 Git仓库完毕
    
  2. git clone : 拷贝一个Git仓库到本地,可以查看并修改。或者复制一个项目,查看代码

    $git clone [url(远程仓库)]
    

基本快照

  1. git add : 可将创建的文件从工作区添加到暂存区,如果添加后的文件有所改动,会自动回到工作区,需要再次添加到暂存区,然后再提交。

    • git add . 命令来添加当前项目的所有文件(新项目中添加所有文件很普遍)
  2. git status 命令用于查看项目的当前状态(如果没有需要添加或者提交的文件,或者没有改动的文件则会显示nothing to commit, working tree clean。)

  3. git diff 来查看执行git status 的结果的详细信息

  4. git commit :将想要快照的内容写入缓存区,而执行命令(add)后将缓存区内容添加到仓库中。Git为你的每一个提交都记录你的名字与电子邮箱地址,第一步要配置用户名和邮箱地址

    git config --global uesr.name "your name"
    git config --global user.email "your email"
    git conmmit -m
    # -m选项在命令行中提交注释
    git commit -am
    # 添加和提交文件合并成一步
    
  5. git reset HEAD : 用于取消已缓存的文件,文件回到工作区

  6. git rm : 从Git中移除某个文件,将该文件提交以后执行此项命令即可删除。

    • git rm <file>
      
    • 如果提交文件以后,对文件进行修改,文件自动回到工作区,在add到暂存区,如果此时想要删除文件用强制删除选项 -f

     git rm -f <file>
    
    • 如果把文件从暂存区域移除,但仍希望保留在当前工作目录中,即:仅从跟踪清单中删除,使用--cached选项即可。

      git rm --cached <file>
      
  7. git mv : 用于移动或重命名一个文件、目录、软连接。

    git mv
    

Git分支管理

1. 创建分支命令

  • git branch (branchname)
    

2.切换分支命令

  • git checkout (branchname)
    git checkout -b (branchname)
    # 创建并切换到分支branchname
    

3.合并分支:

  • 一旦某分支有了独立的内容,希望将它合并回到主分支,可以使用该命令。

  • 可以多次合并到统一分支,也可以选择在合并之后直接删除被并入的分支。

  • git merge
    

4.列出分支

  • git branch
    * master
    # 没有参数时,git branch会列出你在本地的分支
    # *号显示当前所在的分支
    # 当执行git init的时候,默认情况下Git就会创建master分支
    

4.删除分支命令:

  • git branch -d (branchname)
    

合并冲突:

  • 合并并不仅仅是简单的文件添加、移除的操作,Git也会合并修改。

  • $ git branch
    * master
    $ cat hello.py
    $ git branch yyp
    $ vim hello.py
       hello yyp!
    $ git commit -am 'change the hello.py'
    $ git checkout master
    Switched to branch 'master'
    $ cat hello.py
    $ vim hello.py
    $ cat hello.py
      hello python!
    $ git commit -am "修改代码"
    $ git merge yyp
    $ cat hello.py
     hello python!
     ============
     hello yyp!
    $ vim hello.py
    $ cat hello.py
     hello yyp!
    $ git status -s
    D hello.php
    AA hello.py
    $ git commit
    [master 7732186] Merge branch 'yyp'
     
    

Git查看提交历史

  • git log:在使用Git提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,使用git log 命令查看。

  • git log --oneline:查看历史记录的简洁的版本。(项目的开发历史)

  • git reflog :简洁显示所有的提交记录

  • git log --graph :查看历史中什么时候出现了分支、合并。开启了拓扑图选项。(何时工作分叉、又何时归并)

  • git log --reverse 参数来逆向显示所有日志。

  • git log --author :查找指定用户的提交日志

  • git log --since和--before

  • git reset --hard 版本号(42cb617)(HEAD{0})

    git log --onelinr --before={3.weeks.ago} --after={2010-04-18} -- no merges
    # 查看Git项目中三周前在四月十八日之后的所有提交,——no merges 选项以隐藏并提交
    

Git标签

  • git tag -a : 创建一个带注解的标签,指定标签信息
  • git lag --decorate:查看标签
  • git show v1.0:查看v1.0标签的注释
  • git tag -a v0.9 85fc7e7: 给85fc7e7追加标签v 0.9
  • git tag :查看所有标签
  • git tag -s <tagname> -m ’runoob.com标签‘:PGP签名标签

Github

  • git remote add [shorttime] [url]:添加一个新的远程仓库,可以指定一个简单的名字,以便将来引用

  • ssh-keygen -t rsa -C 'yourmain@example.com'(Github注册的邮箱)

  • cat ~/.ssh/id_rsa.pub : 查看ssh

  • ssh -T git@github.com : 验证是否成功连接Github

  • 本地的内容推送到GitHub仓库

    $ mkdir yyp-git-test      #创建测试目录
    $ cd yyp-git-test/        #进入测试目录
    $ echo '#yyp' >>README.md  #创建README.md文件,并写入内容
    $ ls                       #查看目录下的文件
    README.md
    $ git init                #初始化
    $ git add README.md       #添加文件
    $ git commit -m "添加README.md文件" #提交并备注信息
    #提交到Github
    $ git remote add origin git@github.com.yyp-223/yyp.git
    $ git push -u origin master
    
    • # 远程命令  添加  远程仓库的别名 远程仓库的地址
      git remote add origin 远程仓库地址
      
    • 推送master分支到远程仓库

       向origin 仓库上推送 master分支
      git push -u origin master 
      #-u指定默认,以后git push 默认推送mast分支(不建议使用-u)
      
  • 拉取远程仓库

    git clone 远程地址
    git branch
    # 此时本地只显示master地址,但所有的分支都已经拉取下来了
    git pull origin dev 
    # 只拉取dev分支
    
  • 拉取最新的仓库代码时如果与本地冲突

    • 先将发生冲突的本地代码提交后再拉取,手动处理冲突。

    • git pull origin dev 
      #等同于
      git fetch origin dev(避免产生分叉)
      git merge origin/dev
      

变基

  • 场景一:多个记录整合成一个记录

    git rebase -i #某一次的提交记录信息,合并到当期那提交记录
    git rebase -i HEAD~3 #最近的三次提交记录合并
    #出现 Vi 编辑区域
    根据下面提示选择
    一般我们会将 pick 修改为 s
    # 保存退出 再次出现 vi 的编辑区
    列出要合并的提交记录
    例如修改为 v1 & v2 & v3
    # 保存
    git log #查看提交记录
    注意:尽量不要合并已经提交到远程仓库的(提交记录)
    
  • 场景二:

master c1 - c2 -c4 -c5

dev c3

Mater c1 -c2 -c3 -c4-c5

将c3在其他分支上的提交记录 合并到master分支上

git checkout dev
git rebase master # 变更当前dev分支的基
git checkout master
git merge dev
  • 场景三:远程拉取代码,会有合并冲突,产生分叉

     git pull origin dev
    #可能产生记录分叉
    git fetch origin dev
    git rebase origin/dev
    #不产生记录分叉
    
  • 注意事项

    • git rebase 产生冲突怎么办?
    • 会提示
      • 1、解决冲突
      • 2、git add
      • 3、Git rebase --contine
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 一、基本概念: 注:对于git的分布式概念及其优点,不重复说明,自己百度或谷歌。本文中涉及到指令前面有$的,在cm...
    大厂offer阅读 1,423评论 0 3
  • 一、Git学习总结的命名 初始化一个Git仓库。 添加文件到Git仓库步骤分两步:使用命令git add <fil...
    Cheriez阅读 452评论 0 1
  • 2016.12.4 虽然14年开发第一个项目时就已经接触了git,当时xcode已经开始支持git,在github...
    張小明阅读 402评论 1 0
  • 该篇文章为学习廖雪峰git教程的总结,具体可移步廖雪峰老师git教程网站 Git介绍 Git是分布式版本控制系统。...
    Pig_deng饲养员阅读 968评论 0 1
  • 1. GIT命令 git init在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个re...
    江边一蓑烟阅读 798评论 0 0