git版本控制
安装git
1. linux 安装
sudo apt-get install git
2. 查看安装结果 git
3. 创建项目
在桌面上创建test文件夹,表示工作项目
4. 创建本地仓库
- 进入test,创建本地仓库 .git
- 新创建的本地仓库 .git 是个空仓库
- 创建本地仓库后 test会有一个.git 文件夹
cd ~/Desktop/test
git init
5. 配置个人信息
git config user.name 'zheng'
git config user.email '[email protected]'
配置个人信息后,会在.git文件夹下面出现刚配置的个人信息
命令
git status 查看文件状态 (如果文件名红色,证明在工作区)
git add . 添加项目中所有文件 添加文件到暂存区
git add 文件名 添加指定文件到暂存区
(此时文件名是绿色的)
# 将暂存区的文件提交到仓库区
git commit -m '版本描述'
git status 无文件提交,干净的工作区
git commit -am '版本描述'
# 查看历史
git log
git reflog
# 回退版本
方案一
HEAD表示当前最新版本
HEAD^表示当前最新版本的前一个版本
HEAD^^表示当前最新版本的前两个版本
方案二
通过每个版本的版本号回退到指定版本
....
git reset --hard HEAD^
git reset --hard 版本号
# 撤销更改
- 只能撤销工作区、暂存区的代码,不能撤销仓库区的代码
- 撤销仓库区的代码就相当于回退版本操作
# 撤销工作区的代码
git checkout 文件名
# 撤销暂存区的代码
1. 将暂存区代码撤销到工作区 git reset HEAD 文件名
2. 撤销工作区代码 git checkout 文件名
#对比版本
#对比版本库到工作区
git diff HEAD -- 文件名
#对比版本库
git diff HEAD HEAD^ --login.py
# 删除文件
确认删除
rm 文件名
# git 确定删除文件,对比天剑文件git add
git rm 文件名
# 删除后记录删除操作版本
git commit -m '删除描述'
误删
# 删除文件
rm 文件名
# git 撤销修改
git checkout -- 文件名
git 远程仓库 GitHub
克隆仓库 git clone
拉取仓库 git pull
推送到仓库 git push
总结
- 要使用git命令操作仓库,需要进入到仓库内部
- 要同步服务器代码就执行:git pull
- 本地仓库记录版本就执行:git commit -am ‘版本描述’
- 推送代码到服务器就执行:git push
- 编辑代码前要先pull,编辑完再commit,最后推送是push
代码冲突
提示: 多人协同开发时,避免不了会出现代码冲突的情况
原因: 多人同时修改了同一个文件
危害: 会影响正常的开发进度
注意: 一旦出现代码冲突,必须先解决再做后续开发
解决冲突
原则: 谁冲突谁解决,并且一定要协商解决
方案: 保留所有的代码,或者 保留某一个人的代码
解决完冲突代码后,依然需要add、commit、push
补充
容易冲突的操作方式
- 多个人同时操作了同一个文件
- 一个人一直写不提交
- 修改之前不更新最新代码
- 提交之前不更新最新代码
- 擅自修改同事代码
减少冲突的操作方式
- 养成良好的操作习惯,先pull在修改,修改完立即commit和push
- 一定要确保自己正在修改的文件是最新版本的
- 各自开发各自的模块
- 如果要修改公共文件,一定要先确认有没有人正在修改
- 下班前一定要提交代码,上班第一件事拉取最新代码
- 一定不要擅自修改同事的代码
打标签
在本地打标签
git tag -a 标签名 -m ‘标签描述’
推送标签到远程仓库
git push origin 标签名
删除标签
git tag -d 标签名
git push prigin –delete tag 标签名
分支
查看当前分支 git branch
创建并切换到dev 分支 git checkout -b dev
设置本地分支跟踪远程制定分支 git push -u origin dev
dev 分支合并到master分支
切换到master分支 git checkout master
dev分支合并到master分支 git merge dev
合并分支到远程仓库 git push