Git 常用操作与注意事项全攻略

1. 基本配置

bash 复制代码
git config --global user.name "你的名字"
git config --global user.email "你的邮箱"
git config --list   # 查看当前配置

建议全局配置用户名和邮箱,否则提交记录可能不规范

2.仓库操作

初始化本地仓库
bash 复制代码
git init

只在新建项目时使用,已有仓库不用再 init。

克隆远程仓库
bash 复制代码
git clone 仓库地址
# 例:git clone git@codeup.aliyun.com:d1/dxInside/MU86.git

克隆后会自动进入项目目录,注意切换到正确目录再操作

3.分支操作

查看分支
bash 复制代码
git branch           # 查看本地分支
git branch -r        # 查看远程分支
git branch -a        # 查看所有分支
新建分支
bash 复制代码
git branch 分支名

新建分支不会自动切换,需手动切换。

切换分支
bash 复制代码
git checkout 分支名
# 或
git switch 分支名

切换前请确保当前更改已提交或已暂存,否则可能导致冲突。

新建并切换分支
bash 复制代码
git checkout -b 分支名
# 或
git switch -c 分支名
删除分支
bash 复制代码
git branch -d 分支名         # 删除本地分支(已合并)
git branch -D 分支名         # 强制删除本地分支(未合并)
git push origin --delete 分支名  # 删除远程分支

删除分支前请确认分支内容已备份或合并。

4. 代码提交

查看状态
bash 复制代码
git status
添加文件到暂存区
bash 复制代码
git add 文件名
git add .           # 添加所有更改

git add . 会添加所有更改,包括删除和新建,操作前请确认。

提交更改
bash 复制代码
git commit -m "提交说明"

提交说明建议简明扼要,便于团队协作。

5. 远程操作

查看远程仓库
bash 复制代码
git remote -v
添加远程仓库
bash 复制代码
git remote add origin 仓库地址

一个仓库可以有多个远程(如 origin、upstream),注意区分。

拉取远程代码
bash 复制代码
git pull                # 拉取当前分支对应的远程分支
git pull origin 分支名  # 拉取指定远程分支到当前分支

拉取前建议先提交本地更改,避免冲突。

推送代码到远程
bash 复制代码
git push                # 推送当前分支到远程
git push origin 分支名  # 推送当前分支到远程指定分支
git push -u origin 分支名  # 首次推送并建立关联

推送前建议先拉取远程最新代码,避免覆盖他人提交。

6. 合并与变基

合并分支
bash 复制代码
git merge 其他分支名

合并前建议先拉取最新代码,合并后如有冲突需手动解决。

变基(rebase)
bash 复制代码
git rebase 其他分支名

rebase 会重写提交历史,协作开发时慎用,避免影响他人。

7. 撤销与回退

撤销未提交的更改
bash 复制代码
git checkout -- 文件名

会丢弃文件的本地更改,谨慎操作。

撤销已暂存的更改
bash 复制代码
git reset HEAD 文件名
回退到某次提交
bash 复制代码
git log                # 查看提交历史,找到commit id
git reset --hard commit_id

--hard 会丢弃所有未提交的更改,操作前请备份重要内容。

8. 查看日志

bash 复制代码
git log
git log --oneline
git log --graph --all --decorate

--graph 选项可以更直观地查看分支合并关系。

9. 标签(Tag)

创建标签
bash 复制代码
git tag v1.0
推送标签
bash 复制代码
git push origin v1.0
git push origin --tags   # 推送所有标签
删除标签
bash 复制代码
git tag -d v1.0
git push origin :refs/tags/v1.0

10. stash 临时保存

保存当前更改
bash 复制代码
git stash
查看 stash 列表
bash 复制代码
git stash list
恢复最近一次 stash
bash 复制代码
git stash pop

11. 常见问题与注意事项

  • 切换分支前请提交或保存当前更改,否则可能导致冲突或丢失。
  • 多人协作时,推送前务必先拉取远程最新代码,解决冲突后再推送。
  • 不要在公共分支(如 master/main)上直接开发,建议新建 feature 分支开发后合并。
  • rebase 只建议在自己的分支上用,合并到主分支前请用 merge。
  • reset、rebase、push -f 等会重写历史,操作前请三思。
  • 删除分支、回退历史等危险操作前请做好备份。

12. 其他实用命令

查看某个文件的历史
bash 复制代码
git log 文件名
查看某次提交的内容
bash 复制代码
git show commit_id
比较差异
bash 复制代码
git diff                # 工作区与暂存区差异
git diff --cached       # 暂存区与上次提交差异
git diff 分支A..分支B   # 两分支差异
修改最后一次提交说明
bash 复制代码
git commit --amend
相关推荐
字节跳动数据平台几秒前
5000 字技术向拆解 | 火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
武子康6 小时前
大数据-239 离线数仓 - 广告业务实战:Flume 导入日志到 HDFS,并完成 Hive ODS/DWD 分层加载
大数据·后端·apache hive
闲云一鹤1 天前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化
字节跳动数据平台1 天前
代码量减少 70%、GPU 利用率达 95%:火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
得物技术1 天前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
武子康1 天前
大数据-238 离线数仓 - 广告业务 Hive分析实战:ADS 点击率、购买率与 Top100 排名避坑
大数据·后端·apache hive
武子康2 天前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天2 天前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
vibecoding日记4 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具