团队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使用教程
本文链接:http://www.cnblogs.com/sochishun/p/7496350.html
本文作者:SoChishun (邮箱:14507247#qq.com | 博客:http://www.cnblogs.com/sochishun/)
发表日期:2017年9月8日

团队Git使用教程的更多相关文章

  1. Git基础教程(二)

    继续上篇Git基础教程(一),在开篇之前,先回顾一下上篇中的基本命令. 配置命令:git config --global * 版本库初始化:git init 向版本库添加文件:git add * 提交 ...

  2. git 入门教程

    git 入门教程之协同开发 前面我们已经介绍过远程仓库的相关概念,不过那时并没有深入探讨,只是讲解了如何创建远程仓库以及推送最新工作成果到远程仓库,实际上远程仓库对于团队协同开发很重要,不仅仅是团队协 ...

  3. Git简明教程一、基本概念

    文本是写给新手的Git入门教程.本文的目的是让新手能够快速了解并开始使用Git,因此只会介绍最基本.同时也是最核心的知识.其中包括使用Git的基本步骤和Git中最常用的命令,以及如何使用GitHub托 ...

  4. Git全面教程

    Git全面教程 简介 Git分布式版本管理系统. Linus在1991年创建了开源的Linux,但是一直没有一个合适的版本管理工具,在2002年以前,世界各地的志愿者都是通过把源代码文件通过diff的 ...

  5. [译]Atlassian Git系列教程

    国庆期间把Atlassian的Git系列教程看完了.边看边翻译了相关文章. 原教程: https://www.atlassian.com/git/tutorials/ 我翻译的: git init g ...

  6. Git使用教程【转】

    Git使用教程 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是 ...

  7. Git 使用教程

    Git 使用教程 更详细请参考:廖雪峰的官方网站 - Git教程 1. 安装Git客户端软件 Git for Windows http://msysgit.github.io/ 2. 创建版本库 两点 ...

  8. 记一次小团队Git实践(下)

    在上篇中,我们已经能基本使用git了,接下来继续更深入的挖掘一下git. 更多的配置自定义信息 除了前面讲的用户名和邮箱的配置,还可以自定义其他配置: # 自定义你喜欢的编辑器,可选 git conf ...

  9. 记一次小团队Git实践(中)

    对于初学者,从使用上先入手,往往学的最快,并从中汲取教训,再回头更深入的学习,效果尤佳. 安装git 安装git自不必说,mac已经内置了git,linux下一个命令就能搞定,windows下需要下载 ...

随机推荐

  1. Spark(Python) 从内存中建立 RDD 的例子

    Spark(Python) 从内存中建立 RDD 的例子: myData = ["Alice","Carlos","Frank"," ...

  2. flask, SQLAlchemy, sqlite3 实现 RESTful API 的 todo list, 同时支持form操作

    flask, SQLAlchemy, sqlite3 实现 RESTful API, 同时支持form操作. 前端与后台的交互都采用json数据格式,原生javascript实现的ajax.其技术要点 ...

  3. P2371 [国家集训队]墨墨的等式

    膜意义下最短路. 把最小的\(a\)抠出来,作为模数\(mod\),然后建点编号为\(0\)到\(mod-1\),对每个数\(a\)连边\((i,(a+i)\mod mod)\)点\(i\)的最短路就 ...

  4. Linux每天一个命令:cat

    Linux cat命令 命令:cat cat 命令用于连接文件并打印到标准输出设备上. 使用权限 所有使用者 语法格式 cat [-AbeEnstTuv] [--help] [--version] f ...

  5. koa2 入门(1)koa-generator 脚手架和 mongoose 使用

    项目地址:https://github.com/caochangkui/demo/tree/koa2-learn 1 构建项目 1.1 安装koa-generator $ npm install -g ...

  6. Redis简介、安装、配置、启用学习笔记

    前一篇文章有介绍关系型数据库和非关系型数据库的差异,现在就来学习一下用的较广的非关系型数据库:Redis数据库 Redis 简介 Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-v ...

  7. 数位DP模板详解

    // pos = 当前处理的位置(一般从高位到低位) // pre = 上一个位的数字(更高的那一位) // status = 要达到的状态,如果为1则可以认为找到了答案,到时候用来返回, // 给计 ...

  8. TensorFlow训练MNIST数据集(3) —— 卷积神经网络

    前面两篇随笔实现的单层神经网络 和多层神经网络, 在MNIST测试集上的正确率分别约为90%和96%.在换用多层神经网络后,正确率已有很大的提升.这次将采用卷积神经网络继续进行测试. 1.模型基本结构 ...

  9. 3Sum(or k_Sum)

    Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find ...

  10. Codeforces Round #550 (Div. 3) E. Median String (模拟)

    Median String time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...