---- by 程序亦非猿 2016.03.07
这是在公司分享的稿子,演示为主,稿子内容不太详细,有兴趣的可以看看,推荐看看文末的资料~
控制版本系统(VCS)
版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统
集中化控制系统都有一个单一的集中管理的服务器,保存所有文件的修订版本,客户端通过这台服务器获取文件或提交更新.
很明显,中央服务器是个中心,一旦它出了问题就会影响整个系统.
中央服务器单点故障,如果服务器一挂,那么整个系统就挂了,无法工作
甚至,中央服务器磁盘故障,很可能导致数据丢失,丢失所有历史更改记录等重要信息.
客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来。这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份
Git--控制版本之神作者,大神 Linus Torvalds
优点:
<!-- more -->
Git常用命令git config #--global 全局配置
git config --global user.name "alan"
git config --global user.email alancheen06@gmail.com
git config --list
查看配置列表
git init
用来初始化项目
它会创建一个.git
目录,它包含所有初始化git的所有文件
git clone url
git clone url name #重命名成name
文件的状态
接下去的命令跟文件状态有关
untracked===>staged
git add file
git add .
staged===>untracked
git reset HEAD file
git commit -m "init"
git commit -a -m "init"
git commit -am "init"
git commit --amend #想要撤消刚才的提交操作,可以使用 --amend 选项重新提交
// 演示
git branch branchname
PS:当init一个仓库时,master需要先commit一遍才能新建其他分支,否则会得到一个错误
fatal: Not a valid object name:'master'.
git checkout branchname
git checkout -b branchname
git branch -r -a -l
git branch -d branchname #删除本地分支
git push origin --delete branchname #删除远程分支
// 演示
git remote add [shortname] url
如:
git remote add origin url #
git remote -v
可以查看所有远程仓库
git fetch remote-name
fetch 只是从远程仓库 获取数据,并不会合并到工作区
git pull origin master
pull = fetch +merge
git push [remote-name] [branch-name]
git push origin master
git log
查看提交历史
git reflog
git reset --hard commitId
git stash/pop
git tag
git help cmdname
....
git config --global alias.co checkout
git config --global alias.br branch
git config --global alias.ci commit
git config --global alias.st status
git config --global alias.unstage 'reset HEAD --'
git config --global alias.last 'log -1 HEAD'
忽略不想提交的文件
基于git的工作流
工具推荐git GUI 软件
不管装不装逼,都要必备
学习资料推荐内容很多,很详细,堪称权威,而且还有中文版,还有pdf等下载,一定要看看.
非常棒的指南,极力推荐
一个git的游戏,现在一共有54个关卡,从init开始,让你在玩的过程中学习git,挺有意思
又是一个学习git的游戏,不过这个是针对分支的游戏,非常棒~非常推荐
2025 - 快车库 - 我的知识库 重庆启连科技有限公司 渝ICP备16002641号-10
企客连连 表单助手 企服开发 榜单123