git 是一个代码协同管理工具,也称之为代码版本控制工具,代码版本控制或管理的工具用的最多的: svn、 git。
SVN
是采用的 同步机制
,即本地的代码版本和服务器的版本保持一致(提交版本时,直接提交到服务器);
Git
是采用 异步机制
(分为本地仓库和远程仓库),本地提交的版本不会影响服务器的版本,只有本地的代码上传到服务器时才会同步。
git 是一个开源分布式版本控制系统,可用于高效的管理不同大小的项目, 05 年创造的,由林纳斯(Linux 之父)发明的。
代码版本管理工具主要的功能是 多人协同开发
,其 作用
是:
commit
版本号下载地址:https://git-scm.com/downloads
一路next
在Ubuntu系统下,基于apt安装
命令:
sudo apt-get install git -y
三种配置级别
(1) 系统中所有的用户
都可以使用该配置,配置文件是: /etc/gitconfig
git config --system 配置信息
(2) 当前用户可使用该配置:配置文件是: ~/.gitconfig
git config --global 配置信息
(3) 当前项目可使用该配置,配置文件是:当前项目下的 ./.git/config
git config
给定git用户的名称(自定义)
git config --global user.name "zhb-git"
同配置用户名相同,自定义git用户的邮箱
git config --global user.email "[email protected]"
配置信息后,可以查看配置信息,确认是都OK。
git config --list
#或
git config -l
在某个目录下,将当前目录作为本地仓库使用时。需要将此目录进行初始化:
git init
初始化命令执行成功后,会在当前目录下创建 .git
子目录。
将当前目录下的文件添加到暂存区中,
查看文件的状态:
git status
添加文件到暂存区:
git add <文件或> ... | . | *
.
表示当前工作目录<文件>
表示具体的某一个文件全名(带后缀名)*
表示任意多个任意字符的文件,代表所有的文件及目录(目录中国的子文件及子目录)注意:添加到暂存区的文件没有存放在本地仓库中
可以将暂存区的文件删除:
git rm --cache <文件名> #删除暂存区的指定文件
#或
git rm --cache -r . #递归删除所有文件(将暂存区的所有文件恢复到工作区)
注意:
git rm --cache -r .
命令可能会将仓库中的文件删除,如果出现这种情况,可以使用下面命令恢复:git restore --staged <file>...
git restore --staged
命令可以将暂存区文件还原...
将暂存区的文件,提交到本地仓库中,产生一个新的提交版本号(世界上唯一的)
git commit -m <提交说明> #将文件同步到本地仓库并且设置提示说明
注意:
- 一般提示时需要附加一些同步信息,在-m 后添加
- 所有对工作区的修改,如果想同步到仓库,都需要执行当前命令(add --> commit)
提交的版本 可以通过命令查看:
git log
可以限制显示版本号的数量:
git log -n 版本数量(具体的值: 1,2,3 等)
如果只想显示版本号和消息,可以单行显示:
git log --pretty=oneline
在将文件提交到本地仓库之后,再次修改文件时,可以比较本地文件与仓库中的文件内容
比较:
git diff <file>
git checkout <文件名>
aaa.txt 中的内容恢复到未修改之前的:
git checkout -- <文件名> #丢弃本地指定文件中的已经修改的内容( --两边都有空格)效果同上
无论移动还是删除,都会影响本地文件,修改后,必须再次提交版本 (再次执行 git commit)
git mv <源文件> <目的目录> #在本地仓库中将源文件移动目的目录中(本地也会移动)
删除:
git rm <文件名> # 在本地仓库中删除指定的文件(本地也会删除)
git reset --hard HEAD^ # HEAD 后面的^数量决定了回到上几个版本
git reset --hard <commit_id> #只需要 commit id 的唯一的前几位(至少4位)即可
git reflog #最新的操作始终在最上边
标签是在当前工作的位置添加的快照,用于保存工作状态,一般用于版本的迭代。
在当前提交的版本上创建标签,如:
git tag 标签名 [-m "标签的消息"]
如果为指定提交版本号创建标签也可以的,如:
git tag <标签名称> <commit id> #指定某一个 commit id 处创建标签
git tag
#或
git show <标签名称>
注意:如果出现了 : ,则需要按 q 退出。也可以在show命令上加参数 -q 。
可以将标签(从版本号上)删除
git tag -d <标签名称>
标签和版本号绑定的,在恢复代码版本时,可以使用标签
git reset --hard <标签名称>
临时工作区可以理解为某个区间,如:暂存区、当前工作区等。
目的:保存未提交文件的状态
git stash
git stash list
注意:最近创建的临时工作区在列表的最上面,即 0号位置为最新创建的临时工作区。
git stash apply stash@{编号}
注意:在使用临时工作区时,当前工作区不能存在未提交的文件(暂存区必须是空的)
git stash pop
git stash drop stash@{编号}
git stash clear
分支主要用于多人协作工作,分支即获取原有代码,在此基础上创建自己的工作环境,单独开发,不会影响其他分支的操作,开发完成后再统一合并到主线分支中
创建分支的好处:安全,不影响其他人工作
按工程的项目进行代码分支的管理:以项目为准,存在master、develop
project(项目库)
master(主线分支)
hotfix(线上紧急 bug 修复分支)
develop(开发分支)
feature(功能分支)
release(发布分支)
bugfix(bug 修复分支)
git branch
git branch <分支名称>
git checkout -b <分支名称>
git checkout <分支名称>
如果在当前分支下创建的新的分支存在新的提交的版本,则需要切换到当前分支下,可以将心的分支合并到当前分支。即父分支可以合并子分支。
如:
git merge <后代分支名称>
- 合并过程中如果没有冲突,直接合并后当前分支即为干净的状态,直接保存在本地仓库中
- 如果产生冲突,需要人为的选择,然后在进行 add 和 commit 的操作
- 在创建分支前,尽量保证当前分支是干净的,以减少冲突的发生
feature2
是develop分支的子分支, 子分支已提交了两个版本。
如果将feature2分支合并到develop分支上,则 需要先切换再合并。
git branch -d < 分支名称>
git rebase <分支名>
效果同合并分支,但是不会创建新的版本号,只会更新父分支上最近提交的版本号(是在子分支创建之后提交的)
远程仓库:中心服务器上的git仓库
- gitee:目前使用较多的是gitee(国内免费)
- github:国外免费,网速比较慢
- gitlab:私有仓库,企业内部搭建
gitee的网址:https://gitee.com/
需要注册账号,并登录。
gitee 支持http和ssh两个协议,http协议每次使用时,都需要手动输入用户名和口令,比较麻烦。
可以使用ssh协议,ssh协议支持公钥与私钥实现免密。
在gitbash的窗口中,生成公钥与私钥
命令如下
ssh-keygen
产看公钥:
cat ~/.ssh/id_rsa.pub
将此公钥粘贴在 gitee网页 —> 头像 下来菜单
选择 账号设置
菜单,在 设置页面,从 左边菜单
找到 SSH公钥
,点击之后,打开公钥设置界面,填写公钥名称和内容:
确认信息之后,点击【确定】
点击用户头像左边的 + 图标,在弹出的子菜单中选择 新建仓库 ,在打开页面,输入仓库的名称及介绍即可点击【创建】按钮。
先将远程仓库的位置(ssh仓库位置)添加到本地仓库的配置中,
然后再上传,上 传时必须带 -u <远程仓库的名称> <分支名称>
git remote add origin [email protected]:disenQF/testgit2302.git
git push -u origin "master"
origin
是远程仓库的名称,可以自定义;
master
是远程仓库的分支名(默认的主分支名)。
git push
远程仓库的代码完全由本地仓库的代码替换
git push -u --force origin master
通过
克隆
的方式下载的远程仓库
git clone [email protected]:用户名/仓库名
git pull