一、Git环境配置
二、获取本地仓库
三、基础操作指令
四、分支
Git Bash 使用到基本 Linux 命令
在使用 Git 进行版本控制时,经常需要在 Git Bash 或其他终端中使用一些基本的 Linux 命令。以下是常见的 Git 命令和基本的 Linux 命令示例。
基本 Linux 命令
-
ls/ll:查看当前目录
# 列出当前目录中的文件和文件夹 ls # 列出当前目录中的文件和文件夹,显示详细信息 ll
-
cat:查看文件内容
# 查看文件内容 cat <filename>
-
touch:创建文件
# 创建一个新文件 touch <filename>
-
vi:vi 编辑器
# 使用 vi 编辑器打开文件 vi <filename> # vi 编辑器的基本使用: # 进入插入模式:按 'i' # 保存并退出:按 'Esc',然后输入 ':wq',再按 'Enter' # 退出不保存:按 'Esc',然后输入 ':q!',再按 'Enter'
通过上述命令,开发者可以在 Git Bash 中高效地进行版本控制操作,同时掌握基本的 Linux 命令,有助于更好地管理和操作项目文件。
一、Git环境配置
1.1、下载与安装
下载地址: https://git-scm.com/download
1.下载完成后,直接点击安装包安装,即可。
2.开始安装,然后下一步
3.可以在此处自定义地址,然后下一步
3.选择组件
此处默认即可,但我选择了一个新功能。
配置一是 “仅从 Git Bash 使用 Git” 。这是最安全的选择,因为您的 PATH 根本不会被修改。您只能使用 Git Bash 的 Git 命令行工具。但这将不能通过第三方软件调用 Git 。
配置二是 “从命令行以及第三方软件启用 Git” 。该选项被认为是安全的,因为它仅向 PATH 添加了一些最小的 Unix 命令解析器,以避免使用时造成系统环境混乱。您将能够从 Git Bash ,命令提示符和 Windows PowerShell 以及在 PATH 中寻找 Git 或是在任何第三方软件中使用 Git 。这也是推荐的选项。
配置三是 “从命令提示符使用 Git 和可选的 Unix 命令” 。警告:这将覆盖 Windows 命令,如:find 和 sort。你只有在了解其含义后才使用此选项。
一般默认即可。
如果没有特殊习惯,默认即可。
8.选择在加密连接时使用的证书
选项一是服务器证书将使用 ca-bundle.crt 文件进行验证。这也是默认的选项。
选项二是“使用本地 Windows 安全通道库”。服务器将使用 Windows 证书验证,此选项还允许您使用公司的内部根 CA 证书,例如使用 Active Directory Domain Services.
一般默认即可
选项一是“查看时使用 Windows 风格的行尾,保存时使用 Unix 风格的行尾”。查看文本文件时,Git 会将 LF 转换为 CRLF 。保存文本文件时, CRLF 将转换为 LF 。对于跨平台项目十分有用,这里是 Windows 上的推荐设置(core.autocrlf设置为true)
选项二是“查看时按原样展示,保存时使用 Unix 样式的行尾”。查看文本文件时,Git 不会执行任何转换。 保存文本文件时,CRLF 将转换为 LF 。对于跨平台项目比较有用,这是 Unix 上的建议设置(core.autocrlf设置为input)
选项三是“查看时按原样展示,保存时按原样保存”。当查看或保存文本文件时,Git 不会执行任何转换。不建议跨平台项目选择此选项(core.autocrlf设置为false)。
一般默认即可。
10.配置终端模拟器以与Git Bash一起使用
选项一是“使用 MinTTY( MSYS2 的默认终端)”。Git Bash 将使用 MinTTY 作为终端模拟器,该模拟器具有可调整大小的窗口,非矩形文本选择和显示 Unicode 字体。但 Windows 控制台程序(例如交互式 Python )必须通过“ winpty ”启动才能在 MinTTY 中运行。
选项二是“使用 Windows 的默认控制台窗口”。Git 将使用 Windows 的默认控制台窗口cmd.exe,该窗口可以与 Windows 控制台程序(如交互式 Python 或 node.js )一起使用,但默认的回滚非常有限,需要配置 Unicode 字体才能正确显示非 ASCII 字符,并且在 Windows 10 之前,其窗口不能自由调整大小,并且只允许矩形文本选择。
一般默认即可。
11.使用git pull命令时默认的模式
一般默认即可。
12.是否启用 credential helper 登录凭证管理助手
一般默认即可。
13.配置额外的选项
一般默认即可。
14.是否启用实验功能
这里不勾选,默认选择,如果想尝试新功能,可官网查阅资料了解即可
15.开始安装,等待片刻,最后finish
安装完成后在电脑桌面(也可以是其他目录)点击右键,如果能够看
到如下两个菜单则说明Git安装成功。
备注:
Git GUI:Git提供的图形界面工具
Git Bash:Git提供的命令行工具
1.2、基本配置
当安装Git后首先要做的事情是设置用户名称和email地址。
这是非常重要的,因为每次Git提交都会使用该用户信息
git config --global user.name “GLNG”
git config --global user.email “GLNG@gmail.con”
查看配置信息
git config --global --list
git config --global user.name
git config --global user.email
1.3、为常用指令配置别名(可选)
有些常用的指令参数非常多,每次都要输入好多参数,我们可以使用别名。
- 打开用户目录,创建
.bashrc
文件
部分windows系统不允许用户创建点号开头的文件,可以打开gitBash,执行touch ~/.bashrc
touch ~/.bashrc
- 在
.bashrc
文件中输入如下内容:
#用于输出git提交日志
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
#用于输出当前目录所有文件及基本信息
alias ll='ls -all'
- 打开gitBash,执行
source ~/.bashrc
source ~/.bashrc
1.4、解决GitBash乱码问题
- 打开GitBash执行下面命令
git config --global core.quotepath false
${git_home}/etc/bash.bashrc
文件最后加入下面两行
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
二、获取本地仓库
要使用Git对我们的代码进行版本控制,首先需要获得本地仓库
- 在电脑的任意位置创建一个空目录(例如test)作为我们的本地Git仓库
- 进入这个目录中,点击右键打开Git bash窗口
- 执行命令git init
- 如果创建成功后可在文件夹下看到隐藏的.git目录。
三、基础操作指令
Git工作目录下对于文件的修改(增加、删除、更新)会存在几个状态,这些修改的状态会随着我们执行Git的命令而发生变化。
如何使用命令来控制这些状态之间的转换:
git add (工作区 --> 暂存区)
git commit (暂存区 --> 本地仓库)
3.1、*查看修改的状态(status
)
作用:查看的修改的状态(暂存区、工作区)
命令形式:
git status
3.2、*添加工作区到暂存区(add
)
作用:添加工作区一个或多个文件的修改到暂存区
命令形式:
git add 单个文件名|通配符
将所有修改加入暂存区:
git add .
3.3、*提交暂存区到本地仓库(commit
)
作用:提交暂存区内容到本地仓库的当前分支
命令形式:
git commit -m '注释内容'
3.4、*查看提交日志(log
)
在 1.3、中配置的别名 git-log 就包含了这些参数,所以后续可以直接使用指令 git-log
作用:查看提交记录
命令形式:
git log [option]
git log --all --pretty=oneline --abbrev-commit --graph
options:
--all 显示所有分支,获得整个仓库的完整提交视图
--pretty=oneline 简化了每条提交信息的显示方式,使得每条提交记录只占用一行
--abbrev-commit 使得Git在显示提交commitID(也称为commit hash)更简短哈希值
--graph Git会在输出中加入ASCII字符构成的图形
--decorate 此选项会在提交历史旁边标注出分支名、标签名等(新版本默认开启的)
3.5、版本回退
作用:版本切换
命令形式:
git reset --hard commitID
commitID 可以使用 git-log 或 git log 指令查看
如何查看已经删除的记录?
git reflog
这个指令可以看到已经删除的提交记录
ctrl + L
清屏
clear 清除
3.6、添加文件至忽略列表
一般我们总会有些文件无需纳入Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以在工作目录中创建一个名为 .gitignore
的文件(文件名称固定),列出要忽略的文件模式。
下面是一个示例:
# Ignoring .a file
*.a
# but do track lib.a, even though you're ignoring .a files above
!lib.a
# only ignore the TODO file in the current directory, not subdir/TODO
/TODO
# ignore all files in the build/ directory
build/
# ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt
# ignore all .pdf files in the doc/ directory
doc/**/*.pdf
example
#####################仓库初始化######################
# 创建目录(Git_repository)并在目录下打开git bash
略
# 初始化git仓库
git init
#####################创建文件并提交#####################
# 目录下创建文件 test.txt
touch test.txt
# 将修改加入暂存区
git add .
# 将修改提交到本地仓库,提交记录内容为:commit 001
git commit -m '注释内容'
# 查看日志
git log
####################修改文件并提交######################
# 修改test.txt的内容
vim test.txt
# 将修改加入暂存区
git add .
# # 将修改提交到本地仓库,提交记录内容为:update file01
git commit --m 'update test01'
# 查看日志
git log
# 以精简的方式显示提交记录
git-log
####################将最后一次修改还原##################
# 查看提交记录
git-log
# 版本回退 找到倒数第2次提交的commitID
git reset --hard commitID
# 查看已经删除的记录
git reflog
四、分支
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
4.1、查看本地分支
git branch
4.2、创建本地分支
git branch 分支名
我们还可以直接切换到一个不存在的分支(创建并切换)
git checkout -b 分支名
4.4、*切换分支(checkout)
git checkout 分支名
4.6、*合并分支(merge)
一个分支上的提交可以合并到另一个分支
git merge 分支名称
4.7、删除分支
不能删除当前分支,只能删除其他分支
git branch -d 分支名称 // 删除分支时,需要做各种检查
git branch -D 分支名称 // 不做任何检查,强制删除
4.8、解决冲突
当两个分支上对文件的修改可能会存在冲突,例如同时修改了同一个文件的同一行,这时就需要手动解
决冲突,解决冲突步骤如下:
- 处理文件中冲突的地方
- 将解决完冲突的文件加入暂存区(add)
- 提交到仓库(commit)
冲突部分的内容处理如下所示:
4.9、开发中分支使用原则与流程
几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离
开来进行重大的Bug修改、开发新的功能,以免影响开发主线。
在开发中,一般有如下分支使用原则与流程:
- master (生产) 分支
线上分支,主分支,中小规模项目作为线上运行的应用对应的分支; - develop(开发)分支
是从master创建的分支,一般作为开发部门的主要开发分支,如果没有其他并行开发不同期上线要求,都可以在此版本进行开发,阶段开发完成后,需要是合并到master分支,准备上线。 - feature/xxxx分支
从develop创建的分支,一般是同期并行开发,但不同期上线时创建的分支,分支上的研发任务完成后合并到develop分支。 - hotfix/xxxx分支,
从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、develop分支。 - 还有一些其他分支,在此不再详述,例如test分支(用于代码测试)、pre分支(预上线分支)等等。
exmple
###########################创建并切换到develop分支,在develop分支提交
# [master]创建分支develop
git branch develop
# [master]切换到develop
git checkout develop
# [develop]创建文件test.txt
touch test.txt
# [develop]将修改加入暂存区并提交到仓库,提交记录内容为:add test on dev
git add .
git commit -m 'add test on dev'
# [develop]以精简的方式显示提交记录
git-log
###########################切换到master分支,将develop合并到master分支
# [develop]切换到master分支
git checkout master
# [master]合并develop到master分支
git merge develop
# [master]以精简的方式显示提交记录
git-log
# [master]查看文件变化(目录下也出现了test.txt)
略
##########################删除develop分支
# [master]删除develop分支
git branch -d develop
# [master]以精简的方式显示提交记录
git-log