1- git提交(分支合并)操作流程:
git 提交代码到自己的分支,并合并到主分支的完整流程
分支 sml , 主分支, master
分支msl上操作
git status
git add .
git commit -m ‘xxxxxx’
git pull origin master
git push
切换到主分支master上
git checkout master
git pull origin master
git merge sml
git push
2- git提交操作流程,一个分支
1. git stash 或 git stash save "描述" 同步前先暂存你修改的内容
2. git pull 同步服务器最新代码
3. git stash apply 弹出暂存的修改
4 git status 查看修改的文件
5. git add [文件] .表示所有文件,也可以单独指定要提交的文件名
6. git commit -m "描述"
7. git push [远程分支] [本地分支] 或者是 git push - u origin dev 推送到远程服务器
如果有冲突情况下:
1- git pull 提示失败
2- git add . 和 git commit -m '提交本地' 把本地的提交
3- git push 提示 有冲突,解决冲突
4- 解决完后,重新 git add . 和 git commit -m '提交远程解决冲突'
5- git push 提示成功
(1)git stash save "save message" : 执行存储时,添加备注,方便查找,只有git stash 也要可以的,但查找时不方便识别。
(2)git stash list :查看stash了哪些存储
(3)git stash show :显示做了哪些改动,默认show第一个存储,如果要显示其他存贮,后面加stash@{$num},比如第二个 git stash show stash@{1}
(4)git stash show -p : 显示第一个存储的改动,如果想显示其他存存储,命令:git stash show stash@{$num} -p ,比如第二个:git stash show stash@{1} -p
(5)git stash apply :应用某个存储,但不会把存储从存储列表中删除,默认使用第一个存储,即stash@{0},如果要使用其他个,git stash apply stash@{$num} , 比如第二个:git stash apply stash@{1}
(6)git stash pop :命令恢复之前缓存的工作目录,将缓存堆栈中的对应stash删除,并将对应修改应用到当前的工作目录下,默认为第一个stash,即stash@{0},如果要应用并删除其他stash,命令:git stash pop stash@{$num} ,比如应用并删除第二个:git stash pop stash@{1}
(7)git stash drop stash@{$num} :丢弃stash@{$num}存储,从列表中删除这个存储
(8)git stash clear :删除所有缓存的stash
(9)git stash被误删恢复,恢复丢弃的 git stash 数据
场景:
通过stash保存,被使用git stash drop 丢起。
项目开发中,不想commit提交,但要切换到其他commit或者branch,临时处理紧急任务,使用 git stash 备份当前的工作内容。但因不当操作使用“git stash drop”,暂存被删除
方案1要求:知道被删除的ID
通过历史操作记录,查看自己drop的ID,通过“git show ID”,“git stash apply ID” 进行查看和恢复
git fsck --lost-found 或者git fsck --unreachable 找到各丢弃的标识ID,如下
可配合通过方案1进行查看、内容恢复。
缺点:commitID 数量大(几百上千个),而且不是根据顺序进行排列的,找起来麻烦,不太使用
复制dangling commit 的id(其他的dangling blob不用关心)
查看
git show 900d07a43b935220d4e6b7eb36fb4b18c5f7848f(你的id)
还原
git merge 900d07a43b935220d4e6b7eb36fb4b18c5f7848f(你的id)
方案2:要求:知道被删除的大致内容
查询被clear的相关历史
git log --graph --oneline --decorate $(git fsck --no-reflog | awk '/dangling commit/ {print $3}')
找到 被clear 的stash记录
根据自己保存名称,直接 git stash apply ID 进行恢复;不记得名字可通过git show 查看具体内容,筛选需要的ID
git stash apply d052411