美文网首页
Git和GitHub的使用

Git和GitHub的使用

作者: 爱吃油果子 | 来源:发表于2019-12-25 14:24 被阅读0次

    一、简介

    对照下图细细品味Git中远程仓库、本地仓库、暂存区、工作区的关系:


    Git架构

    二、环境准备(略过)

    整体思路:

    1、mac安装Git
    2、注册GitHub账号
    3、本机创建SSH Key
    4、和GitHub相连,打开公共id_rsa.pub
    5、使用Git相关命令

    三、常用命令行

    A、新建命令:

    首先在Github上去新建项目,然后将本地Git同它关联

    • 1、本地没有创建Git项目,创建并关联到GitHub
      …or create a new repository on the command line
    git init 
    git add . 
    git commit -m "first commit"
    git remote add origin https://github.com/storyxiao/annotation-project.git
    git pull origin master
    # 如果远程仓库已有文件,出现错误fatal: refusing to merge unrelated histories,先用以下命令pull
    # git pull origin master --allow-unrelated-histories
    git push -u origin master
    
    • 2、本地已经创建Git项目,关联到GitHub
      …or push an existing repository from the command line
    git remote add origin https://github.com/storyxiao/annotation-project.git 
    # 一般会要求先拉取远程仓库代码才可以提交
    # git pull origin master 或 git pull 
    git push -u origin master
    
    • 3、如果是线下接收的项目包没有.git文件或本地.git文件被误删,将失去与GitHub的关联。

    方法一:备份本地代码,重新clone代码,接着用本机备份覆盖它,然后提交本地变更

    git clone https://github.com/storyxiao/annotation-project.git
    git add . 
    git commit -m "recommit" 
    git push -u origin master
    

    方法二:重新生成本地仓.git文件,关联拉取GitHub后提交代码

    git init
    git remote add origin https://github.com/storyxiao/annotation-project.git
    git pull origin master
    git add . 
    git commit -m "recommit" 
    git push -u origin master
    

    B、操作命令:

    对于复杂操作如:合并、删除、对比等,个人觉得命令行始终不方便,
    在IDE工具中操作比较好,或下载客户端

    • 1、从远程库克隆项目:
      git clone [项目地址]
    # ssh方式,clone时需要密码,提交时不需要密码,适合开发需要提交代码:
    git clone git://git.kernel.org/pub/scm/git/git.git
    # https方式,clone时不需要密码,提交时需要密码,适合只是下载下来看看不提交:
    git clone http://www.kernel.org/pub/scm/git/git.git
    
    • 2、新增文件
      git add 文件到暂存区
    # 常用-将当前目录所有修改添加到暂存区(不包括忽略文件):
    git add .
    # add文件到暂存区几种方式的区别:
    git add -u:包括文件的修改、删除(update)
    git add .:包括文件的修改、新建
    git add -A:包括文件的修改、删除、新建(ALL)
    # 将某个文件或文件夹添加到暂存区:
    git add <file_name.txt>/<path>
    # 一次add多个文件的方法,多个文件用空格隔开
    git add file1 file2 file3
    # 提交文件夹的方法
    git add catalog_name
    
    • 3、提交分支
      git commit
     # 提交所有改动并写提交日志:
     git commit -m "<改动日志说明>"
    
    • 4、pull和push
      git pull <远程主机名> <远程分支名>:<本地分支名>
      git pull相当于git fetch + git merge FETCH_HEAD
    # 取回origin主机的dev分支,并与本地的master分支合并
    git pull origin dev:master
    # 如果远程分支(dev)要与当前分支合并,则冒号后面的部分可以省略
    git pull origin dev
    # 默认进一步省略,按照git branch的默认跟踪的服务器和分支来拉取
    git pull
    

    git push <远程主机名> <本地分支名>:<远程分支名>
    git push命令用于将本地分支的更新,推送到远程主机

    # (1) 如果省略远程分支名,则表示将本地分支推送与之存在"追踪关系"的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
    git push origin master
    # 如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略
    git push origin
    # 如果当前分支只有一个追踪分支,那么主机名都可以省略
    git push
    # (2) 如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支
    # 慎用!删除远程仓库的分支
    git push origin :master
    # 等同于
    git push origin --delete master
    # (3) 如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push
    git push -u origin master
    # (4) 忽略自动测试
    # If you don't want to run tests, please add `--no-verify` in command, such as:
    git push --no-verify
    

    Push报错:Push to origin/master was rejected 解决方法

    # 依次输入以下命令解决
    git pull
    git pull origin master
    git pull origin master --allow-unrelated-histories
    
    • 5、checkout
      (1)基础用法:分支切换
    # 工作分支的切换
    git checkout branchName
    # 创建并切换分支
    git checkout -b newBranch
    该命令相当于执行下面两条命令
    1. git branch newBranch 
    2. git checkout newBranch
    

    (2)深入用法:检出文件
    未使用git add缓存代码时:

    # 放弃单个文件修改(中间有"--")
    git checkout -- readme.md
    // 放弃所有的文件修改
    git checkout .
    

    已经使用了git add缓存了代码:

    # 放弃指定文件的缓存
    git reset HEAD readme.md
    # 放弃所有的缓存
    git reset HEAD .
    

    已经用git commit提交了代码:

    # 回退到上一次commit的状态
    git reset --hard HEAD^
    # 回退到任意版本
    git reset --hard commitid 
    
    • 6、git fetch origin && git merge origin/next
    • 7、create patch && diff
    • 8、stash
      存储当前工作状态到git栈,在需要的时候再恢复
    # git stash 这个命令可以多次使用,每次使用都会新加一个stash@{num},num是编号,最新一条的内容为stash@{0}
    # 执行存储
    git stash save "savemessage" # 也可以不写备注,直接git stash,但个人不推荐
    # 查看所有的存储列表
    git stash list
    # 显示某个存储所做改动
    git stash show # 默认显示最新一条的内容,即stash@{0}
    git stash show stash@{1}
    # 恢复某个存储,但不会把存储从存储列表中删除
    git stash apply # 默认使用第一个存储,即stash@{0},建议在git栈中只有一条的时候使用,以免混乱
    git stash apply stash@{1} # 恢复num为1的存储
    # 恢复某个存储,并将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下
    git stash pop # 默认恢复stash@{0}
    git stash pop stash@{1}
    # 当我们执行git stash apply之后发现所有的文件都变成了未暂存的,如果想维持原来的样子,即暂存过的依旧是暂存状态,那么可以使用 git stash apply --index
    # 删除指定存储
    git stash drop # 默认删除stash@{0}
    git stash drop stash@{1}
    # 删除所有存储的进度
    git stash clear
    

    C、常用命令

    # 查看代码版本
    git remote -v
    # 查看合并状态
    git status
    # 查看log
    git log
    # 显示当前的Git配置
    git config --list
    # 切换版本到1.9,Flink遇到过的坑,注意切换到分支而不是tag
    git checkout release-1.9(不是1.9.0)
    # 切换到master
    git checkout master
    # 合并单个commit
    git cherry-pick 0437ad2fce8a064424522b4b01d3dcea55597033
    
    

    相关文章

      网友评论

          本文标题:Git和GitHub的使用

          本文链接:https://www.haomeiwen.com/subject/pescoctx.html