Git的使用
基本概念
三种状态
已提交: 数据已经安全地保存在本地数据库中
已修改: 修改了文件,但还没保存在数据库中
已暂存: 对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中
三个工作区域
Git 仓库目录:Git 用来保存仙姑的元数据和对象数据库的地方;拷贝的就是这里的数据.
工作目录: 对项目的某个版本独立提取出来的内容。这些从 Git仓库的压缩数据库中提取出来的文件,放在磁盘上供修改
暂存区域:是一个文件,保存了下次将提交的文件列表信息,一般在 Git 仓库目录中。
基本的 Git 工作流程如下:
- 在工作目录中修改文件。
- 暂存文件,将文件的快照放入暂存区域。
- 提交更新,找到暂存区域的文件,将快照永久性存储到 Git 仓库目录。
常用操作
git init # 初始化git仓库, 会创建一个名为.git 的子目录。但尚未跟踪任何文件。
git add file # 跟踪
git commit -m 'inital project version' 提交
git clone # 区别于 checkout, 会对所有数据进行完整复制,包括整个项目历史中每个文件的所有历史版本都拉取下来。
状态都是已跟踪未修改。
git status #查看文件的状态, -s 得到简短输出
git diff #查找具体修改了什么地方,你可能通常会用它来回答这两个问题:当前做的哪些更新还没有暂存?有哪些
#更新已经暂存起来准备好了下次提交?只显示尚未暂存的改变
#若要查看已暂存的将要添加到下次提交里的内容,可以用 git diff --cached 命令。或者 git diff --staged.
git rm #要从 Git 中移除某个文件,就必须要从已跟踪文件清单中移除(确切地说,是从暂存区域移除),然后提交。可
#以用 git rm 命令完成此项工作,并连带从工作目录中删除指定的文件,这样以后就不会出现在未跟踪文件清单中了。
git log # 查看提交历史
git log --pretty=oneline # 单行显示
git log --since=2.weeks # 限制显示时长
git reset HEAD <file> # 撤销操作
gitignore
分支
## 查看所有分支
git branch
## 创建新分支
git branch test
### 切换新分支
git checkout testing
## 创建并切换
git checkout -b testing
### 合并操作
git checkout master
git merge testing
## 删除分支
git brach -d testing
## 合并冲突处理
## 手动处理完冲突后,执行git add 将每个文件标记为冲突已解决的状态。
git status
远程分支
远程引用是对远程仓库的引用。
git ls-remote (remote) #显式地获得远程引用的完整列表,或者通过
git remote show (remote) #获得远程分支的更多信息
远程跟踪分支
远程跟踪分支是远程分支状态的引用。以 (remote)/(branch) 命名。
如果你想要看你最后一次与远程仓库 origin通信时 master 分支的状态,你可以查看 origin/master分支。你与同事合作解决一个问题并且他们推送了一个 iss53分支,你可能有自己的本地 iss53分支;但是在服务器上的分支会指向 origin/iss53的提交。
远程仓库名字 “origin” 是当你运行 git clone时默认的远程仓库名字。如果你运行 git clone -o booyah,那么你默认的远程分支名字将会是 booyah/master。
抓取
如果要同步服务器上的工作,运行 git fetch origin, 命令会查找 origin 是哪一台服务器,从中抓取本地没有的数据数据,更新本地数据库,并移动 origin/master 指针指向新的位置。
git fetch # 从服务器抓取本地没有的数据
git pull # 等于 git fetch then git merge
推送
git push (remote) (branch)
git push [remote-name] [local-branch]:[remote-branch]
git push origin dev:master # 将本地的 dev 分支推送到远程的 master 分支
git push origin serverfix # 推送本地的 serverfix 分支来更新远程仓库的 serverfix 分支; 等同于 git push origin serverfix:serverfix
跟踪分支
从一个远程跟踪分支检出一个本地分支会自动创建一个叫做 “跟踪分支”(有时候也叫做 “上游分支”)。跟踪分支是与远程分支有直接关系的本地分支。如果在一个跟踪分支上输入 git pull,Git 能自动地识别去哪个服务器上抓取、合并到哪个分支。
当克隆一个仓库时,它通常会自动地创建一个跟踪 origin/master的 master分支。然而,如果你愿意的话可以设置其他的跟踪分支 - 其他远程仓库上的跟踪分支,或者不跟踪 master分支。最简单的就是之前看到的例子,运行 git checkout -b [branch] [remotename]/[branch]。这是一个十分常用的操作所以 Git 提供了 --track快捷方式:
git checkout -b [branch] [remotename]/[branch]
git checkout --track origin/serverfix
git checkout -b sf origin/serverfix # 本地分支为不同名字 sf
git branch -vv # 将所有本地分支列出来,并可以看到每一个分支正在跟踪哪个远程分支以及领先或落后情况
上游快捷方式
当设置好跟踪分支后,可以通过 @{upstream}或 @{u}快捷方式来引用它。所以在 master 分支时并且它正在跟踪 origin/master时,如果愿意的话可以使用 git merge @{u}来取代 git merge origin/master。
删除远程分支
git push origin --delete serverfix
常见场景
场景一
将本地已有文件夹 push 到远程文件夹里面
git init # 将当前文件夹初始化为git 文件夹
git remote add origin <git_url>
git pull origin master --allow-unrelated-histories
git push -u origin master
场景二
将本地已有文件夹 push 到远程文件夹里面
git submodule add <git_url> <本地地址>
场景三
远程分支拉到本地仓库
git checkout --track origin/分支名
场景四
git branch develop # 创建分支
git checkout develop 切换到该分支下
git push --set-upstream origin <分支名称> 把分支提交到远程仓库中
git push --set-upstream origin develop
指定分支克隆
git clone -b 分支名称 地址
git checkout --track origin/feature/home
场景五:同步远程的 master 信息到本地
git pull origin master
场景六:merge 分支到 master
合并其他分支代码至master分支
1.当前分支所有代码提交
# 将所有代码提交
git add .
# 编写提交备注
git commit -m "修改bug"
# 提交代码至远程分支
git push origin dev
2.切换当前分支至主干
# 切换分支
git checkout master
# 如果多人开发建议执行如下命令,拉取最新的代码
git pull origin master
3.合并分支代码并提交
git merge dev
# merge完成后可执行如下命令,查看是否有冲突
git status
git push origin master