团队Git使用教程
团队git使用教程(不要使用IDE自带版本控制功能)
角色分配:项目观察者、项目拥有者、项目开发人员

场景:项目拥有者创建项目
1. 在当前目录新建一个git代码库
git init "testgit_pm"

2. 切换bash路径到工作目录,否则无法使用git命令
cd testgit_pm

3. 添加目录或文件 切换目录 cd [xxx] 然后
git add .




4. 忽略文件
vi .gitignore



4. 提交到暂存区
git commit -m "描述内容"

5. 再次提交文件
git add ./
git commit --amend -m "修改内容"
6. 显示当前分支的最近几次提交
git reflog #简略显示当前分支的最近几次提交
git log #详细显示当前分支的版本历史


5. 配置当前项目用户信息(随便填就可以了,这里和远程Git系统分配的账号无关)
git config user.name "[name]"
git config user.email "[email]"

设置不自动转换换行符号(如果项目在linux系统和windows系统开发会有换行符号差别)
git config --gobal core.autocrlf false
6. 推送到远程仓库(这里会弹出输入用户名和密码的认证窗口)
git push "https://git.oschina.net/sutroon/testgit.git" --all

场景:项目拥有者创建分支
1. 新建分支
git branch [branch_name] # 新建分支,但依然停留在当前分支(以当前内容为分支内容)
git branch [branch_name] [commit] # 新建一个分支,指向指定commit
2. 切换到指定分支,并更新工作区
git checkout [branch_name]
git checkout - # 切换到上一个分支
3. 上传本地指定分支到远程仓库
git push "https://git.oschina.net/sutroon/testgit.git" "develop1"
git push "https://git.oschina.net/sutroon/testgit.git" "develop1":master # // 提交本地develop1分支作为远程的master分支
场景:项目开发人员修改文件
1. 克隆项目
git clone "https://git.oschina.net/sutroon/testgit.git" "testgit_deve1"

2. 显示有变更的文件
(粗略显示本次修改的文件,即使执行git add命令也会显示)
git status


3. 显示暂存区和工作区的差异
(详细显示修改后,未执行git add命令之前的文件详情)
git diff

4. 显示当前分支的最近几次提交
git reflog

5. 配置当前项目用户信息(随便填就可以了,这里和远程Git系统分配的账号无关)
git config user.name "[name]"
git config user.email "[email]"
设置不自动转换换行符号(如果项目在linux系统和windows系统开发会有换行符号差别)
git config --gobal core.autocrlf false
6. 推送到远程仓库(这里会弹出输入用户名和密码的认证窗口)
git push "https://git.oschina.net/sutroon/testgit.git" --all

项目观察者
统计操作:
1. 显示所有提交过的用户,按提交次数排序
git shortlog -sn
文件管理操作:
1. 显示指定的文件是什么人在什么时间修改过的
git blame [file]
每日工作
取回远程仓库的变化,并与本地分支合并(保存用户名和密码:git config credential.helper store)
git pull "https://git.oschina.net/sutroon/testgit.git" "master"

推送所有分支到远程仓库
git push "https://git.oschina.net/sutroon/testgit.git" --all
场景:文件冲突
pm编辑了file1.txt,执行git add .; git commit -m "pm编辑了file1"; git push ... --all;
dev编辑了file1.txt, 执行git add .; git commit -m "dev编辑了file1"; git push ... -all;


方法1:
冲突的时候,如果想直接用远程的
git checkout --theirs file1.txt
git add .
冲突的时候,如果想直接用本地的
git checkout --ours .
git add .
方法2:




撤销操作:
1. 显示commit历史以及每次commit发生变更的文件
git log --stat
2. 恢复某个commit的制定文件到暂存区和工作区
git checkout "[commit]" "[file]"
忽略文件:
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
更改操作
1. 恢复暂存区的指定文件到工作区
(比如工作区的文件被改乱了,想撤销,就可以从暂存区恢复最后一次提交的文件到工作区)
git checkout [file]

2. 恢复某个commit的指定文件到暂存区和工作区
git reflog #简略显示当前分支的最近几次提交,获取[commit]ID。
git checkout "[commit]" "[file]"

删除操作

git之从过时的header还原到master的最新header
git stash //先备份已经改变的文件
git checkout master //从过时的header还原到master的最新header,(即当前header是老的,过时的)
git stash pop //恢复备份的文件
git add //添加改变的文件
git commit //提交到本地库
git checkout回之前版本后,如何把旧版本写的代码push上去?
保存你的修改
git commit ...
git tag tmp
更新主分支到remote最新
git checkout master
git pull origin master
合并你的修改并提交到remote
git merge tmp
git push origin master
clean
git tag -d tmp
参考文章:
Git忽略规则及.gitignore规则不生效的解决办法 [http://www.pfeng.org/archives/840]
git之从过时的header还原到master的最新header [http://blog.csdn.net/conjimmy/article/details/51512378]
git checkout回之前版本后,如何把旧版本写的代码push上去? [https://segmentfault.com/q/1010000004056628/a-1020000004056703]
|
版权声明:本文采用署名-非商业性使用-相同方式共享(CC BY-NC-SA 3.0 CN)国际许可协议进行许可,转载请注明作者及出处。 |
团队Git使用教程的更多相关文章
- Git基础教程(二)
继续上篇Git基础教程(一),在开篇之前,先回顾一下上篇中的基本命令. 配置命令:git config --global * 版本库初始化:git init 向版本库添加文件:git add * 提交 ...
- git 入门教程
git 入门教程之协同开发 前面我们已经介绍过远程仓库的相关概念,不过那时并没有深入探讨,只是讲解了如何创建远程仓库以及推送最新工作成果到远程仓库,实际上远程仓库对于团队协同开发很重要,不仅仅是团队协 ...
- Git简明教程一、基本概念
文本是写给新手的Git入门教程.本文的目的是让新手能够快速了解并开始使用Git,因此只会介绍最基本.同时也是最核心的知识.其中包括使用Git的基本步骤和Git中最常用的命令,以及如何使用GitHub托 ...
- Git全面教程
Git全面教程 简介 Git分布式版本管理系统. Linus在1991年创建了开源的Linux,但是一直没有一个合适的版本管理工具,在2002年以前,世界各地的志愿者都是通过把源代码文件通过diff的 ...
- [译]Atlassian Git系列教程
国庆期间把Atlassian的Git系列教程看完了.边看边翻译了相关文章. 原教程: https://www.atlassian.com/git/tutorials/ 我翻译的: git init g ...
- Git使用教程【转】
Git使用教程 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是 ...
- Git 使用教程
Git 使用教程 更详细请参考:廖雪峰的官方网站 - Git教程 1. 安装Git客户端软件 Git for Windows http://msysgit.github.io/ 2. 创建版本库 两点 ...
- 记一次小团队Git实践(下)
在上篇中,我们已经能基本使用git了,接下来继续更深入的挖掘一下git. 更多的配置自定义信息 除了前面讲的用户名和邮箱的配置,还可以自定义其他配置: # 自定义你喜欢的编辑器,可选 git conf ...
- 记一次小团队Git实践(中)
对于初学者,从使用上先入手,往往学的最快,并从中汲取教训,再回头更深入的学习,效果尤佳. 安装git 安装git自不必说,mac已经内置了git,linux下一个命令就能搞定,windows下需要下载 ...
随机推荐
- Exp6 20155218 信息搜集与漏洞扫描
Exp6 信息搜集与漏洞扫描 1.DNS IP注册信息的查询 1.进行whois查询时,要去掉www,ftp等前缀,否则可能在whois服务器中查询不到: 2.使用whois查询ip的地理位置: 2. ...
- app.use( )做一个静态资源服务
var express = require("express"); var app = express(); //静态服务 app.use("/jingtai" ...
- Asp.net中汉字转换成为拼音
1.应用场景 将汉字转换为拼音(eg:"我爱你"--->"WOAINI") 取各个汉字的首字母(eg:"我是中国人"--->&q ...
- 【Android UI设计与开发】第04期:引导界面(四)仿人人网V5.9.2最新版引导界面
这一篇我将会以人人网的引导界面为实例来展开详细的讲解,人人网的引导界面比较的新颖,不同于其他应用程序千篇一律的靠滑动来引导用户,而是以一个一个比较生动形象的动画效果展示在用户们的面前,有一种给人眼前一 ...
- JMeter:生成漂亮的接口/压力测试的HTML报告
JMeter生成HTML网页报告(非gui模式操作) 我们做性能测试的时候会经常使用一些性能测试工具,比如loardrunner和jmeter,我个人比较喜欢Jmeter这个工具,jmeter之前版本 ...
- HyperLedger/Fabric SDK使用Docker容器镜像快速部署上线
HyperLedger/Fabric SDK Docker Image 该项目在github上的地址是:https://github.com/aberic/fabric-sdk-container ( ...
- BugPhobia开发篇章:Beta阶段第V次Scrum Meeting
0x01 :Scrum Meeting基本摘要 Beta阶段第五次Scrum Meeting 敏捷开发起始时间 2015/12/17 00:00 A.M. 敏捷开发终止时间 2015/12/17 23 ...
- request.getParameter中文乱码问题解决办法
new String(request.getParameter("pageNo").getBytes("ISO-8859-1"),"UTF-8&quo ...
- idea 使用 mybaits generator
Intellij IDEA 14 作为JavaIDE 神器,接触后发现,非常好用,对它爱不释手,打算离开eclipse和myeclipse,投入Intellij IDEA的怀抱. 然而在使用的过程中会 ...
- 第二个Sprint ------第四、五、六、七天
27号.28号.29号有事回家,没能及时更新博客. 罗伟业:加减算术----乘除算式 返回一个完整正确(加减.乘除)的算式<考虑到低年级还没有完全掌握四则混合运算> 康取:四则混合运算 ...