zoukankan      html  css  js  c++  java
  • Git 配置环境及常用命令整理

     

    一、Git教程网站

    廖雪峰网站    

    易百GitHub命令:https://www.yiibai.com/git/git_clone.html

    完成Windows环境命令下Git config配置

    设置好之后,路径C:Users用户名下面有一个.gitconfig生成的配置文件,里面存着你的相关信息。

    如果想要检查你的配置,可以使用

     git config --list 
    

    命令来列出所有 Git 当时能找到的配置

    二、Git 中 SSH key 生成步骤

    由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以必须要让github仓库认证你SSH key,在此之前,必须要生成SSH key。

    第1步:创建SSH Key。在windows下查看[c盘->用户->自己的用户名->.ssh]下是否有id_rsaid_rsa.pub文件,如果没有需要手动生成。

        也可以通过命令探测。  

    ssh -T git@github.com

    若探测失败则需要进行第2步操作。

    第2步: 
    打开git bash,在控制台中输入以下命令。

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

    连续三个回车,输入秘钥后生成密钥,最后得到了两个文件:id_rsa和id_rsa.pub(默认存储路径是:C:UsersAdministrator.ssh)。

    第3步:在GitHub添加公钥

    登陆到自己的gitbub,点击右上角的倒立小三角形。选择 settings->选择SSH and GPG keys。

    第4步:验证。

    二、Git 常用命令

    首先要明白工作区、暂存区、本地仓库、远程仓库的区别。

    初始化命令


    查看当前git配置信息

    显示当前Git配置
    git config --list

    设置git用户信息

    # 设置提交代码时的用户信息
    git config [--global] user.name "[name]"
    git config [--global] user.email "[email address]"

    初始化项目

    # 在当前目录新建一个Git代码库
    git init

    克隆远程仓库代码,url为仓库地址

    # 下载一个项目和它的整个代码版本(但不包含分支,需手动新建分支关联,后面分支会提到)
    git clone [url]

    关联远程库,url为仓库地址

    #与远程仓库关联,也可以直接clone后自动关联
    $ git remote add origin [url]

    增删命令


    添加指定文件

    # 添加指定文件到仓库暂存区,可以指定多个文件用空格隔开
    $ git add [file1] [file2] ...
    # 例子
    $ git add name1.txt name2.txt name3.txt

    添加指定目录

    # 添加指定目录到暂存区,包括子目录
    $ git add [dir]

    添加当前目录下所有文件

    # 添加当前目录的所有文件到暂存区
    $ git add .

    删除指定文件

    # 删除工作区文件,并且将这次删除放入暂存区
    $ git rm [file1] [file2] ...

    删除文件与仓库断开关联

    # 停止追踪指定文件,但该文件会保留在工作区
    $ git rm --cached [file]

    文件改名

    # 改名文件,并且将这个改名放入暂存区
    $ git mv [file-original] [file-renamed]
    # 例子
    $ git mv oldName.txt newName.txt

    显示信息命令

    查看暂存区状态

    # 查看git本地仓库当前状态
    $ git status

    查看暂存区修改情况

    # 查看暂存区文件与仓库文件之间的不同修改
    $ git diff

    查看git日志

    # 查看git详细日志,包含不同版本提交、时间、作者(前面配置email和name这里会有用)
    $ git log
    # 查看简洁化日志 只显示commit信息
    $ git log --pretty=oneline

    查看命令记录

    # 查看命令记录,回退版本时可根据命令编号来
    $ git reflog

    暂存区域最新commit的差异

    # 显示暂存区和最新commit的差异
    $ git diff --cached [file]

    工作区与最新commit的差异

    # 显示工作区与当前分支最新commit之间的差异
    $ git diff HEAD

    某次提交的变化

    # 显示某次提交的元数据和内容变化
    $ git show [commit]

    提交命令


    提交暂缓区全部,并添加描述

    # 提交暂存区到本地仓库区
    $ git commit -m [message]

    提交暂缓区个别文件,并添加描述

    # 提交暂存区的指定文件到本地仓库区
    $ git commit [file1] [file2] ... -m [message]

    提交工作区修改的文件(不需要看暂存区修改的文件)

    # 提交工作区自上次commit之后的变化,直接提交到本地仓库区,只针对修改后的文件
    # 若出现新的文件,还是需要使用add命令,而不是用这个合成后的命令
    $ git commit -am [message]

    修改上一次的提交描述

    # 如果上一次的commit没有push到远程仓库中,使用如下代码可以修改提交描述
    # 前提是没有修改文件,否则是一次新的添加效果
    $ git commit --amend -m [message]
    #----------------------------------
    #通过vim编辑器来修改提交描述,效果一样
    $ git commit --amend

    分支命令


    显示本地所有分支

    # 列出所有本地分支
    $ git branch

    显示所有远程分支

    # 列出所有远程仓库分支
    $ git branch -r

    列出所有分支

    # 列出所有本地分支和远程分支
    $ git branch -a

    新建分支

    # 新建一个分支,但依然停留在当前分支
    $ git branch [branch-name]

    新建并切换到新分支

    # 新建一个分支,并切换到该分支
    $ git checkout -b [branch]

    切换分支

    # 切换到指定分支,并更新工作区
    $ git checkout [branch-name]

    重命名分支

    # 重命名分支,
    $  git branch -m | -M oldbranch newbranch

    新建本地分支与远程分支关联

    # 新建一个分支,与指定的远程分支建立追踪关系
    $ git branch --track [branch] [remote-branch]

    指定分支与远程分支关联

    # 建立追踪关系,在现有分支与指定的远程分支之间
    $ git branch --set-upstream [branch] [remote-branch]

    与当前分支合并

    # 合并指定分支到当前分支
    $ git merge [branch]

    commit合并当前分支

    # 选择一个commit,合并进当前分支
    $ git cherry-pick [commit]

    删除分支

    # 删除分支
    $ git branch -d [branch-name]

    删除远程分支

    # 删除远程分支
    $ git push origin --delete [branch-name]
    $ git branch -dr [remote/branch]

    标签命令


    列出所有标签

    # 列出所有tag
    $ git tag

    当前commit新建一个标签

    # 新建一个tag在当前commit
    $ git tag [tag]

    指定commit新建一个标签

    # 新建一个tag在指定commit
    $ git tag [tag] [commit]

    删除本地标签

    # 删除本地tag
    $ git tag -d [tag]

    删除远程标签

    # 删除远程tag
    $ git push origin :refs/tags/[tagName]

    查看标签

    # 查看tag信息
    $ git show [tag]

    提交指定标签

    # 提交指定tag到远程仓库
    $ git push [remote] [tag]

    提交所有标签

    # 提交所有tag
    $ git push [remote] --tags

    新建分支指向某个tag

    # 新建一个分支,指向某个tag
    $ git checkout -b [branch] [tag]

    远程同步命令


    取回所有分支(branch)的更新

    # 下载远程仓库的所有变动
    $ git fetch [remote]

    显示所有远程仓库

    # 显示所有远程仓库
    $ git remote -v

    显示某个远程仓库

    # 显示某个远程仓库的信息
    $ git remote show [remote]

    增加一个远程仓库

    # 增加一个新的远程仓库,并命名
    $ git remote add [shortname] [url]

    取回远程仓库的变动,与本地分支合并

    # 取回远程仓库的变化,并与本地分支合并
    $ git pull [remote] [branch]

    推送本地指定分支

    # 上传本地指定分支到远程仓库
    $ git push [remote] [branch]

    推送本地所有分支

    # 推送所有分支到远程仓库
    $ git push [remote] --all

    撤销命令


    撤销工作区文件的修改

    # 让工作区文件回到最近一次git commit或git add时的状态
    $ git checkout [file]

    工作区指定文件恢复到某次提交

    # 恢复某个commit的指定文件到工作区
    $ git checkout [commit] [file]

    工作区所有文件恢复到上一次提交状态

    # 恢复上一个commit的所有文件到工作区
    $ git checkout 

    重置指定的暂存区文件

    # 重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
    #等价于取消add操作
    $ git reset [file]

    重置暂存区与工作区

    # 重置暂存区与工作区,与上一次commit保持一致
    $ git reset --hard

    重置本地仓库版本到某次commit提交,暂存区清空

    # 重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
    $ git reset [commit]

    重置本地仓库版本和工作区到某次commit提交,暂存区清空

    # 重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
    $ git reset --hard [commit]

    重置本地仓库版本到某次commit提交,暂存区和工作区不变

    # 重置当前HEAD为指定commit,但保持暂存区和工作区不变
    $ git reset --keep [commit]
  • 相关阅读:
    Servlet 生命周期
    深度学习笔记(十)Augmentation for small object detection(翻译)
    fast.ai(零)windows + pytorch 0.4
    win10 + cuda8.0 + caffe SSD + vs2015 + python3
    PyTorch(二)Intermediate
    PyTorch(一)Basics
    Caffe 使用记录(五)math_functions 分析
    win10 + gluon + GPU
    python tricks
    深度学习笔记(九)感受野计算
  • 原文地址:https://www.cnblogs.com/shuqingstudy/p/10494764.html
Copyright © 2011-2022 走看看