Git快速上手

本文详细介绍了Git的下载与安装过程,包括从淘宝镜像下载,无脑下一步安装,以及GitBash、GitCMD和GitGUI的启动。接着,讲解了Git的配置,包括用户配置、环境变量配置和远程配置,如设置用户名、邮箱,以及码云和GitHub的SSH公钥配置。此外,还涵盖了Git在IDEA中的集成,基本工作流程,如创建仓库、添加与提交、分支与合并、更新与标签的使用,以及一些常用的Git命令和技术要点。
摘要由CSDN通过智能技术生成

Git安装与环境配置

下载Git

淘宝镜像下载:http://npm.taobao.org/mirrors/git-for-windows/

直接下载最新版本。

安装:无脑下一步即可!安装完毕就可以使用了。

启动Git

安装成功后在开始菜单中会有Git项,菜单下有3个程序:任意文件夹下右键也可以看到对应的程序。

图片

**Git Bash:**Unix与Linux风格的命令行,使用最多,推荐最多。

**Git CMD:**Windows风格的命令行。

Git GUI:图形界面的Git。

Git配置

Git 提供了一个叫做 git config 的工具,专门用来配置或读取相应的工作环境变量。

Git环境变量,决定了 Git 在各个环节的具体工作方式和行为。这些变量可以存放在以下三个不同的地方:

  • /etc/gitconfig 文件:系统中对所有用户都普遍Git适用的配置。若使用 git config 时用 --system 选项,读写的就是这个文件。
  • ~/.gitconfig 文件:用户目录下的配置文件只适用于该用户。若使用 git config 时用 --global 选项,读写的就是这个文件。
  • 当前项目的 Git 目录中的配置文件(也就是工作目录中的 .git/config 文件):这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置,所以 .git/config 里的配置会覆盖 /etc/gitconfig 中的同名变量。

Git本地配置

1.设置用户名与邮箱(用户标识,必要)

当你安装Git后首先要做的事情是设置你的用户名称和e-mail地址。这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到了你的提交中:

# 设置自己的用户名称
$ git config --global user.name "username"

# 设置自己的邮箱地址
$ git config --global user.email xxx@mail.com

图片

2.检查配置信息(个人配置是否设置好)
# 查看配置
$ git config --list

# 查看系统config
$ git config --system --list  

# 查看当前用户(global)配置
$ git config --global  --list

Git远程配置

1.码云配置

Github有墙比较慢,国内一般使用 gitee ,公司会搭建自己的gitlab服务器。

1、注册登录码云,完善个人信息。

图片

2、设置本机绑定SSH公钥,实现免密码登录!(免密码登录,这一步挺重要的,码云是远程仓库,我们是平时工作在本地仓库!)

# 1.进入 C:\Users(用户)\Administrator(用户)\.ssh目录
# 2.第一次创建不存在.ssh文件夹,自己创建.ssh文件夹并进入
# 3.目录内右键选择git Bash进入命令行

# 生成公钥
$ ssh-keygen -t rsa

# 检查是否能够通信(以下代码针对于gitlab)
$ ssh -T git@github.com

图片

3、将公钥信息public key 添加到码云账户中。

图片

4、使用码云创建一个自己的仓库。

图片

5.仓库设置。

图片

6.克隆到本地,点击文件目录右上角的克隆/下载。

图片

2.Github配置

1.登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库:

Git相关软件配置

IDEA中集成Git

1、新建项目,绑定git。

图片

注意观察idea中的变化。

图片

2、修改文件,使用IDEA操作git。

  • add添加到暂存区
  • commit 提交
  • push到远程仓库

3、提交测试

图片

4.完成

Git工作流程

你的本地仓库由 git 维护的三棵“树”组成。第一个是你的 工作目录,它持有实际文件;第二个是 暂存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,它指向你最后一次提交的结果。

img

0.设置个人配置

配置好个人设置后,提交代码就能自动上传到指定位置提高效率

# 显示当前的Git配置
$ git config --list

# 编辑Git配置文件
$ git config -e [--global]

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

1.创建仓库

创建本地仓库的方法有两种:一种是创建全新的仓库,另一种是克隆远程仓库。

1、创建全新的仓库,需要用Git管理的项目的根目录执行(右键选择Git Bash Here):

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

# 执行后可以看到,仅仅在项目目录多出了一个.git目录,关于版本等的所有信息都在这个目录里面。
# !!!不过一般不推荐这个方法,需要比克隆远程仓库多一些设置!!!

2、另一种方式是克隆远程目录,由于是将远程服务器上的仓库完全镜像一份至本地。

# 克隆一个项目和它的整个代码历史(版本信息)
$ git clone [url]  # 例子[url]=https://gitee.com/kuangstudy/openclass.git

# 克隆下来的.git目录已经将本地与远程主机origin连接

2.添加与提交

(工作目录) --add–> (暂存区) --commit–> (本地仓库) --push–> (远程仓库)

# 添加<filename>文件到暂存区
$ git add <filename>

# 添加所有文件到暂存区 
$ git add .

# 提交暂存区中的内容到本地仓库 -m 代码提交信息(不填写这个会弹出新窗口让你填写,较为麻烦)
$ git commit -m "代码提交信息"   

# 将改动内容提交到远端仓库,origin为默认远程仓库名称,master为推送分支名称
$ git push <远程主机名> <本地分支名>:<远程分支名>
$ git push origin master

# 如果还没有克隆现有仓库,想将你的本地仓库连接到远程服务器,你可以使用如下命令添加:
$ git remote add origin git@server-name:path/repo-name.git

其他命令

# 显示文件提交状态
$ git status

# 显示当前分支的版本历史
$ git log

3.分支与合并

分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。

分支:它们只是简单地指向某个提交纪录,commit时从这个分支源头开始,不影响其他分支,即“我想基于这个提交以及它所有的父提交进行新的工作”

合并:新建一个分支,在其上开发某个新功能,开发完成后再合并回主线,即“我要把这两个父节点本身及它们所有的祖先都包含进来”

img

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

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

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

# 切换回主分支:
$ git checkout master

# 再把新建的分支删掉:
$ git branch -d [new-branch-name]

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

# 除非你将分支推送到远端仓库,不然该分支就是不为他人所见:
$ git push origin <branch>

4.更新与标签

# 获取远程仓库更新到本地
$ git pull <远程主机名> <远程分支名>:<本地分支名>

# 创建一个叫做 1.0.0 的标签:
$ git tag 1.0.0 1b2e1d63ff

# 使用下列命令获取提交 ID:
$ git log

5.替换本地改动

Git基本理论(重要)

三个区域

Git本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。如果在加上远程的git仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:

图片

  • Workspace:工作区,就是你平时存放项目代码的地方
  • Index / Stage:暂存区,用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息
  • Repository:仓库区(或本地仓库),就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中HEAD指向最新放入仓库的版本
  • Remote:远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换

img

查看文件状态

文件有4种状态,通过如下命令可以查看到文件的状态:

# 查看指定文件状态
$ git status [filename]

# 查看所有文件状态
$ git status

# 添加所有文件到暂存区 
$ git add .

# 提交暂存区中的内容到本地仓库 -m 提交信息
$ git commit -m "消息内容"    

忽略文件

有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设计文件等

在主目录下建立".gitignore"文件,此文件有如下规则:

  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。
  2. 可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,…})代表可选的字符串等。
  3. 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。
  4. 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。
  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)。
# 为注释
*.txt        # 忽略所有 .txt结尾的文件,这样的话上传就不会被选中!
!lib.txt     # 但lib.txt除外
/temp        # 忽略temp本文件夹下的某些文件
build/       # 忽略build/目录下的所有文件
doc/*.txt    # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

常用技术

rebase

在这里插入图片描述

rebase(一般不建议用这种方法):可以直接理解为改变基底,相当于此时要用master上新的提交B来作为feature分支的新基底上面的例子可抽象为如下实际工作场景:张三从B拉了代码进行开发,目前提交了两次,开发到D了;李四也从B拉出来开发了并且开发完毕,他提交到了M,然后合到主干上了。此时张三想拉下最新代码,于是他在feature分支上执行了git rebase master,即把master分支给rebase过来,由于李四更早开发完并合了主干,如此就相当于张三是基于李四的最新提交M进行的开发了。

# 重新改变自己分支开始的位置(一般不建议用这种方法)
$ git rebase

修改HEAD指针位置/分支头移动操作(强制改变位置/撤销)

# HEAD与分支头可分离操作------------------------------------
# 修改HEAD指向记录节点(绝对位置)使用哈希值搜索节点(可缩写)
$ git checkout address_hash_mane

# 修改HEAD指向记录节点(绝对位置)^代表向上移动一次,~num表示向上移动num次
$ git checkout master^^/HEAD~6

# HEAD与分支头合并时操作------------------------------------
# 强制修改某分支位置(将 master 分支强制指向 HEAD 的第 3 级父提交)
$ git branch -f master HEAD~3

# (本地运用,本地分支)把分支记录回退n个提交记录来实现撤销改动
$ git reset address

# (合作开发,远程分支)撤销更改并分享给别人
$ git revert address

整理提交记录

# 将一些提交复制到当前所在的位置(HEAD)下面
$ git cherry-pick <提交号>...

# 当不知道每个节点的hash值时,可以只用rebase -i交互式方法选择提交
$ git rebase -i master~5

小技巧

# 当调试完代码后,不想把调试历史过程保留而只输出最后正确结果(整理提交记录)
$ git cherry-pick <提交号>.../git rebase -i master~5

Git 常用命令字典

仓库

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

# 新建一个目录,将其初始化为Git代码库
$ git init [project-name]

# 下载一个项目和它的整个代码历史
$ git clone [url]

配置

# 显示当前的Git配置
$ git config --list

# 编辑Git配置文件
$ git config -e [--global]

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

增加/删除文件

# 添加指定文件到暂存区
$ git add [file1] [file2] ...

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

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

# 添加每个变化前,都会要求确认
# 对于同一个文件的多处变化,可以实现分次提交
$ git add -p

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

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

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

代码提交

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

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

# 提交工作区自上次commit之后的变化,直接到仓库区
$ git commit -a

# 提交时显示所有diff信息
$ git commit -v

# 使用一次新的commit,替代上一次提交
# 如果代码没有任何新变化,则用来改写上一次commit的提交信息
$ git commit --amend -m [message]

# 重做上一次commit,并包括指定文件的新变化
$ git commit --amend [file1] [file2] ...

分支

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

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

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

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

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

# 新建一个分支,指向指定commit
$ git branch [branch] [commit]

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

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

# 切换到上一个分支
$ git checkout -

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

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

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

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

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

标签

# 列出所有tag
$ git tag

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

# 新建一个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
$ git checkout -b [branch] [tag]

查看信息

# 显示有变更的文件
$ git status

# 显示当前分支的版本历史
$ git log

# 显示commit历史,以及每次commit发生变更的文件
$ git log --stat

# 搜索提交历史,根据关键词
$ git log -S [keyword]

# 显示某个commit之后的所有变动,每个commit占据一行
$ git log [tag] HEAD --pretty=format:%s

# 显示某个commit之后的所有变动,其"提交说明"必须符合搜索条件
$ git log [tag] HEAD --grep feature

# 显示某个文件的版本历史,包括文件改名
$ git log --follow [file]
$ git whatchanged [file]

# 显示指定文件相关的每一次diff
$ git log -p [file]

# 显示过去5次提交
$ git log -5 --pretty --oneline

# 显示所有提交过的用户,按提交次数排序
$ git shortlog -sn

# 显示指定文件是什么人在什么时间修改过
$ git blame [file]

# 显示暂存区和工作区的差异
$ git diff

# 显示暂存区和上一个commit的差异
$ git diff --cached [file]

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

# 显示两次提交之间的差异
$ git diff [first-branch]...[second-branch]

# 显示今天你写了多少行代码
$ git diff --shortstat "@{0 day ago}"

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

# 显示某次提交发生变化的文件
$ git show --name-only [commit]

# 显示某次提交时,某个文件的内容
$ git show [commit]:[filename]

# 显示当前分支的最近几次提交
$ git reflog

远程同步

# 下载远程仓库的所有变动
$ 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] --force

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

撤销

# 恢复暂存区的指定文件到工作区
$ git checkout [file]

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

# 恢复暂存区的所有文件到工作区
$ git checkout .

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

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

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

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

# 重置当前HEAD为指定commit,但保持暂存区和工作区不变
$ git reset --keep [commit]

# 新建一个commit,用来撤销指定commit
# 后者的所有变化都将被前者抵消,并且应用到当前分支
$ git revert [commit]

暂时将未提交的变化移除,稍后再移入
$ git stash
$ git stash pop

其他

# 生成一个可供发布的压缩包
$ git archive

其他知识

常用的Linux命令

# 改变目录
$ cd
# 回退到上一个目录,直接cd进入默认目录
$ cd ..
# 显示当前所在的目录路径
$ pwd
# 列出当前目录中的所有文件,ll列出的内容更为详细
$ ls 
$ ll

# 新建一个文件 如 touch index.js 就会在当前目录下新建一个index.js文件
$ touch create_file_name
# 新建一个目录,就是新建一个文件夹
$ mkdir new_dir_name

# 删除一个文件, rm index.js 就会把index.js文件删除
$ rm delete_file_name
# 删除一个文件夹, rm -r src 删除src目录
$ rm -r delete_dir_mane

# 移动文件, mv index.html src,index.html 是我们要移动的文件, src 是目标文件夹。这样写必须保证文件和目标文件夹在同一目录下
$ mv move_file_name save_dir_name

# 重新初始化终端/清屏
$ reset
# 清屏
$ clear
# 查看命令历史
$ history
# 帮助
$ help
# 退出
$ exit
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值