最近公司又来一批小伙伴,对git的使用非常陌生,我就安排给大家讲了下git的基本使用,今天也总结下发到博客园上和大家分享
一、git安装
由于公司都是用windows,本屌丝也是用windows,所有这里就只讲windows的安装
windows的安装非常简单
1、下载git:https://git-scm.com/download/win
2、双击后一路下一步即可
3、检查是否安装成功,鼠标右键,有下图所示证明安装成功
data:image/s3,"s3://crabby-images/7cfba/7cfba7b7bb04725a8cd90d2d60bc407e1d499e06" alt=""
4、点击 git bash,查看当前安装的版本
$ git --version
git version 2.30.0.windows.2
到此为止git我们就安装完成
二、基本使用场景及命令
1、创建一个空的文件夹,然后进入该文件,打开 git bash
data:image/s3,"s3://crabby-images/c695c/c695c815c6922f8f02c5f79df39d4ef72292db4a" alt=""
2、初始化git,输入命令:git init,此时我们就可以使用git 管理该文件夹
data:image/s3,"s3://crabby-images/bc8b5/bc8b53a2e009dc04b3d1351d0844e6e0e05b6c8d" alt=""
3、此时我们就需要介绍下git本地管理,一共有三大逻辑区域
data:image/s3,"s3://crabby-images/e4504/e4504d38ca536e4ab0a319a029d61f2ccc434869" alt=""
我们一般就在工作区
a、git status:查看当前工作区的状态
data:image/s3,"s3://crabby-images/0466e/0466e1513a896f5e85c1f7aedbd6a415930629af" alt=""
此时我们新建一个文件,在执行git status命令,可以看到有个test1.txt的文件待提交
data:image/s3,"s3://crabby-images/52204/52204587108d902157d5ed24244fd8a7a39b3936" alt=""
b、此时我们执行 git add命令,将工作区 的文件提交到暂存区
data:image/s3,"s3://crabby-images/a8be6/a8be63076f8333862353f47bbe8900b4e9173d9f" alt=""
c、此时我们执行git commit -m "xxxxx",将暂存区 的文件提交到版本库区
git commit -m "git第一次提交"
data:image/s3,"s3://crabby-images/a91d6/a91d6072110a3ccf381d47092aa9cc36d7737401" alt=""
然后我们可以执行 git log查看提交记录
git log
data:image/s3,"s3://crabby-images/e1459/e1459f7e50e9993b9ad31248e479944fabf35ce6" alt=""
然后我们一般会给这次提交打一个tag,执行 git tag -a 版本号 -m 版本描述
git tags -a v0.1 -m "第一个版本"
data:image/s3,"s3://crabby-images/8dc76/8dc763c0a78ff5d04c9748b32b390751b3c83609" alt=""
此时我们就把最主流的一条路走完
data:image/s3,"s3://crabby-images/7ed41/7ed41b108f6d2794750d440e95b6f3e2e762d491" alt=""
4、前面我们讲了文件如何从左向右移动,这一节我们讲下文件如何从右向左移动
为了让大家看的i清楚,我先修改下文件,然后多提交几次变更到版本库区域
data:image/s3,"s3://crabby-images/c1815/c181525b7701038bfd3c104e3f1172f53c582e33" alt=""
当前的文件处于第四个版本的状态
data:image/s3,"s3://crabby-images/83720/837205bb492d2fcff6798cabbf1f1dd0103563fe" alt=""
a、首先从第四个版本直接回到第一个版本的工作区已经管理的状态
git reset --hard 745cf9a2ec997cf9fca7d9d0f0f655807438eee2
data:image/s3,"s3://crabby-images/ac1b0/ac1b0e31efd0d1dc94d452fd61e4e60ad618aa33" alt=""
b、下面我们演示git checkout功能,从变更区 回到已管理里区
$ git checkout test1.txt
此时我们在修改文件
data:image/s3,"s3://crabby-images/6b141/6b1414319c6821fabee4b08baeb75644f345bf58" alt=""
data:image/s3,"s3://crabby-images/b7652/b765201a533d79aea0d9d34b9bb2454c046ff502" alt=""
此时要注意,我们git log会查不到所有的提交记录,此时查看记录我们需要用git reflog命令
$ git reflog
data:image/s3,"s3://crabby-images/281fd/281fd852c31193ed5bd43ac29e176d6ca49a9754" alt=""
大家观察下,发现这2个命令的区别么
git log是查看当前提交记录之前的提交记录
git reflog是查看当前提交记录之后的提交记录
从右往左的文件流转最常用的命令就讲完了,我们更新下我们的逻辑图
data:image/s3,"s3://crabby-images/ae117/ae117adaa4542bb6b34cae8545b8c70337ac4e3b" alt=""
c、下面我们讲下从右往左一些不常用的命令
从版本库区域 回到暂存区
git reset --soft 745cf9a2ec997cf9fca7d9d0f0f655807438eee2
从暂存区 回到修改过的文件或者新增文件的状态
git reset HEAD test1.txt
data:image/s3,"s3://crabby-images/10986/10986e6732dfbbd5e4fa24fbb4a73fa1fe74a6ac" alt=""
data:image/s3,"s3://crabby-images/10986/10986e6732dfbbd5e4fa24fbb4a73fa1fe74a6ac" alt=""
此时在执行git checkout 回到已经管理的 状态
data:image/s3,"s3://crabby-images/a522d/a522d9bbc797207e3ad80bcb51b31d069925ebeb" alt=""
从版本库回到新增文件或者修改文件文件状态,同样在执行git checkout 可以回到已管理文件区域
git reset --mix 745cf9a2ec997cf9fca7d9d0f0f655807438eee2
data:image/s3,"s3://crabby-images/c290d/c290d76d8f428612a1267ef158a52d617bcabda5" alt=""
最终,我们把整个文件流转的图更新下
data:image/s3,"s3://crabby-images/6a0dc/6a0dca8819611dbe9c8f184d817a8dc7acc6ab83" alt=""
5、讲下git分支
正常情况下,master分支是我们的线上分支,我们实际开发需要在dev分支上开发
a、查看当前分支: git branch
data:image/s3,"s3://crabby-images/699d9/699d9957d8f74eb4d3e7cda23239df2d6167a65c" alt=""
b、创建分支、切换分支、删除分支
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (master)
$ git branch dev
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (master)
$ git checkout dev
Switched to branch 'dev'
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git branch
* dev
master
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git branch -d dev
error: Cannot delete branch 'dev' checked out at 'D:/test'
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git branch
* dev
master
data:image/s3,"s3://crabby-images/f9593/f9593403a9303c185bcc9e894a158cb953bcc498" alt=""
c、在分支上提交代码
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git branch
* dev
master
//切换到dev分支
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git status
On branch dev
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: test1.txt
//修改文件
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git add .
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git commit -m "dev分支第一次提交"
[dev be36c1a] dev分支第一次提交
1 file changed, 3 insertions(+), 1 deletion(-)
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git tag -a v0.0.1 -m "dev第一个版本"
admin@LAPTOP-SDS5GNTD MINGW64 /d/test (dev)
$ git log
commit be36c1aba0d7cbaf7d962f54d24a05ab91cf6889 (HEAD -> dev, tag: v0.0.1)
Author: cuiyuerong <cuiyuerong@126.com>
Date: Thu Oct 12 11:52:18 2023 +0800
dev分支第一次提交
//在dev分支提交代码
data:image/s3,"s3://crabby-images/e8dcc/e8dcc8cf30d90ebaa1575da85ee17a4004b81a04" alt=""
d、此时我们切换回master分支,查看文件的状态
dev分支的文件状态
data:image/s3,"s3://crabby-images/e09d6/e09d6b193849f668f6f17b05b4bf07247c0599c6" alt=""
master分支的文件状态
data:image/s3,"s3://crabby-images/0ac1b/0ac1b21c9c8ee7f94b9b894520b9b29808dfea2e" alt=""
e、如果此时,我们dev分支的功能开发完成了,需要合并到maser分支,让线上使用
此时我们用 git merge命令
先切换到master分支,然后 执行 git merge dev ,合并dev分支到master分支
data:image/s3,"s3://crabby-images/1ab75/1ab75fa8912d1618a8510ace131600e2700b27b6" alt=""
f、正常情况下,dev分支的代码已经合并到master分支了,dev分支就没有存在的必要了,我们需要把他删除掉
$ git branch -d dev
Deleted branch dev (was be36c1a)
三、结合gitlab
1、如何更新本地代码到gitlab
git remote add origin 你的仓库地址
git push origin master
git remote add origin xxxxx 的意思是,以后origin就代指远程仓库的地址,以后就不用写那么长的远程仓库的地址了,也就是给远程仓库起别名,这里不一定要用origin,可以用任何名字
git push origin master的意思是,推送本地master分支的代码到远程仓库,也就是origin代指的仓库
2、首次如何拉取远程仓库代码到本地
git clone 远程仓库地址
3、后续如何更新本地的代码和远程一致
git pull origin dev
拉取远程仓库的dev分支代码到本地
4、gitlab如何配置免密登录
a、http的方式
git remote add origin https://用户名:密码@仓库地址
git push origin master
b、ssh的方式
本地生成公钥和私钥
$ ssh-keygen.exe
data:image/s3,"s3://crabby-images/d550b/d550bbf25be90c9f322fd759bab08da9fd879fbf" alt=""
c、然后拷贝公钥到github的ssh密钥的地方
data:image/s3,"s3://crabby-images/4005d/4005dcbacafa53054ec7c444a796492c73d1501a" alt=""
d、本地用ssh的方式配置远程仓库地址即可
git add remote origin git@仓库地址
四、解决冲突
我们在合并merge经常会有文件冲突,此时我们只能手动解决冲突。此时我们借助软件beyond compare来解决
我们可以做如下配置
data:image/s3,"s3://crabby-images/e4ef7/e4ef70e44fb0ec85dccc40df3f2bd6d3c56fc206" alt=""
配置:--local的意思是只对当前的项目生效;
git config --local mergetool.keepbackup false的意思 解决完成冲突后的旧文件不要做备份
如果出现冲突,则调用git mergetool 就可以开始解决冲突
五、gitignore文件
配置忽略文件,常用的语法如下
data:image/s3,"s3://crabby-images/f57d5/f57d56470aaec38acc3b08dd7f0aa1c9d2b592ff" alt=""
data:image/s3,"s3://crabby-images/fa54d/fa54d46616c8c2ec31bedc2439f99629820dbf2d" alt=""