首页 > 代码库 > Git版本管理荟萃
Git版本管理荟萃
用惯了svn,突然转到git难免有点不适,写个笔记好好备忘总结一番。
一、先看历史(imooc上的一个图):
二、git与svn
GIT跟SVN一样有自己的集中式版本库或服务器。但,GIT更倾向于被使用于分布式模式,也就是每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库。可以这样说,如果你被困在一个不能连接网络的地方时,就像在飞机上,地下室,电梯里等,你仍然能够提交文件,查看历史版本记录,创建项目分支,等。对一些人来说,这好像没多大用处,但当你突然遇到没有网络的环境时,这个将解决你的大麻烦。
三、那什么情况推荐使用svn
SVN具有的悲观锁的功能,能够实现一个用户在编辑时对文件进行锁定,阻止多人同时编辑 一个文件。这一悲观锁的功能是 Git 所不具备的。对于以二进制文件 (Word文档、PPT演示稿) 为主的版本库,为避免多人同时编辑造成合并上的困难, 建议使用SVN做版本控制。
四、git工作原理
这边文章介绍的不错 Git from the Bottom Up
五、git安装配置
mac下实际无需安装直接在命令窗口输入git即可弹出安装确认,这种方式安装默认是安装到/usr/bin目录下,且不需要配置环境变量
另一种方式就是手动安装dmg包,需要配置环境变量
官网下载:http://git-scm.com/download/mac
vi ~/.bash_profileexport PATH="/usr/local/git/bin:/usr/local/bin:/usr/bin:/usr/local/sbin:$PATH"source ~/.bash_profile重启一下终端,检查是否安装成功git version
用户信息配置:
$ git config --global user.name "jager"$ git config --global user.email jager@example.com
或 直接编辑配置文件:
vi ~/.gitconfig [user]name = jageremail = jager@example.com[color]ui = autobranch = autodiff = autostatus = auto[color "branch"]current = greenlocal = yellowremote = red[color "diff"]meta = yellow boldfrag = magenta boldold = red boldnew = green bold[color "status"]added = yellowchanged = greenuntracked = cyan[alias]st = statusdi = diffci = commitco = checkoutbr = branch
配置公私钥:
== 生成git密钥 ==ssh-keygen -t rsa -C "jager@example.com"秘钥名称填写:git_rsa其他默认即可== 配置git密钥 ==vim ~/.ssh/config//增加以下内容,IdentityFile路径为你生成的git私钥文件路径Host XXXUser gitIdentitiesOnly yesIdentityFile /Users/你的用户名/.ssh/git_rsa== 配置公钥 ==拷贝公钥 pbcopy < ~/.ssh/git_rsa.pub 添加到git管理平台== FAQ ==最后一步没配置可能出现错误:Permission denied (publickey).fatal: Could not read from remote repository.
六、git常用命令
- workspace: 本地工作目录
- index:缓存区域,临时保存本地改动
- local repository: 本地仓库
- remote repository:远程仓库
== git配置 ==git config --list //查看当前git的配置,Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)== 查看信息 ==git log //查看提交记录git status //查看修改状态git diff //查看详细修改内容git show //显示某次提交的内容git branch //列出所有本地分支git tag //列出所有taggit reflog //显示当前分支的最近几次提交== 新建代码库 ==git init //在当前目录新建一个Git代码库git init [project-name] //新建一个目录,将其初始化为Git代码库git clone [url] //下载一个项目和它的整个代码历史== 增加/删除 ==git add [file1] [file2] ... //添加指定文件到暂存区git add [dir] //添加指定目录到暂存区,包括子目录git add . //添加当前目录的所有文件到暂存区git rm [file1] [file2] ... //删除工作区文件,并且将这次删除放入暂存区git mv [file-original] [file-renamed] //改名文件,并且将这个改名放入暂存区== 代码提交 ==git commit -m [message] //代码提交到本地仓库git commit [file1] [file2] ... -m [message] //提交指定文件到本地仓库git commit -a //提交工作区自上次commit之后的变化,直接到仓库区git commit -v //提交时显示所有diff信息git commit --amend -m [message] //使用一次新的commit,替代上一次提交,如果代码没有任何新变化,则用来改写上一次commit的提交信息== 分支管理 ==git branch -r //列出所有远程分支git branch -a //列出所有本地分支和远程分支git branch [branch-name] //新建一个分支,但依然停留在当前分支git checkout -b [branch] //新建一个分支,并切换到该分支git checkout [branch-name] //切换到指定分支,并更新工作区git checkout - //切换到上一个分支git merge [branch] //合并指定分支到当前分支(如master)git branch -d [branch-name] //删除分支git push origin --delete [branch-name] //删除远程分支git branch -dr [remote/branch] //删除远程分支== 远程同步 ==git fetch [remote] //下载远程仓库的所有变动,到indexgit pull //更新本地仓库至最新改动,到workspacegit remote -v //显示所有远程仓库git remote show [remote] //显示某个远程仓库的信息git remote add [shortname] [url] //增加一个新的远程仓库,并命名git pull [remote] [branch] //取回远程仓库的变化,并与本地分支合并git push origin master //推送至master分支git push [remote] [branch] //上传本地指定分支到远程仓库git push [remote] --force //强行推送当前分支到远程仓库,即使有冲突git push [remote] --all //推送所有分支到远程仓库== 撤销 ==git reset [file] //重置暂存区的指定文件,与上一次commit保持一致,但工作区不变git reset --hard //重置暂存区与工作区,与上一次commit保持一致git checkout //从index恢复到workspacegit checkout . //恢复暂存区的所有文件到工作区git checkout -- files //文件从index恢复到workspacegit checkout HEAD -- files //文件从local repository复制到workspace== 冲突解决 ==git diff //对比workspace与indexgit diff HEAD //对于workspace与最后一次commitgit diff <source_branch> <target_branch> //对比差异git add <filename> //修改完冲突,需要add以标记合并成功
七、git使用流程规范【重要】
下面是ThoughtBot 的Git使用规范流程,推荐使用:
Create a local feature branch based off master.
Rebase frequently to incorporate upstream changes.
Resolve conflicts. When feature is complete and tests pass, stage the changes.
When you‘ve staged the changes, commit them.
Write a good commit message. Example format:
If you‘ve created more than one commit, use
Share your branch.
Submit a GitHub pull request. Ask for a code review in the project‘s chat room. |
总结大致如下:
- 新建分支
- 提交分支
- 撰写commit信息
- 与主干同步
- 合并commit
- 推送到远程仓库
- 发出pull request,请求别人进行代码review
参考文档:
中文官方文档:https://git-scm.com/book/zh/v2
猴子都能懂的GIT入门
Git教程 - 廖雪峰
常用 Git 命令清单
Git常用命令
Git 使用规范流程
Git简明指南(中文版)
Git版本管理荟萃