团队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下需要下载 ...
随机推荐
- POJ1807&&1276
DP专题下的背包专题 其实就是PJ的那些东西了 主流的背包有三种:01背包,完全背包和多重背包 其中01背包和完全背包的转移就比较经典了,而多重背包也是在前两者基础上演变一下即可 1837 题意:有一 ...
- EZ 2018 04 01 ZJOI2018模拟赛04.01
现在开始填以前的坑 这次老叶强制我们打一下这次省选题,然后我已经做好了掉Rating到死的准备 然后考完--莫名涨了 Orz 题目链接 由于很多东西我都不会,所以详细请看:dalao的题解 T1 我T ...
- Linux 学习日记 1
这是我第一次系统地学习Linux,希望通过这个学习日记收获一些东西把-- @_@ Grub - 启动管理器 在启动时让用户选择要启动的系统.(但是windows比较霸道--重装windows后会将 ...
- Django的跨域请求
一 同源策略 同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响.可以说Web是构建在同源策略基础之 ...
- 我用Python爬虫挣钱的那些事
在下写了10年Python,期间写了各种奇葩爬虫,挣各种奇葩的钱,写这篇文章总结下几种爬虫挣钱的方式. 1.最典型的就是找爬虫外包活儿. 这个真是体力活,最早是在国外各个freelancer网站上找适 ...
- muduo网络库学习笔记(三)TimerQueue定时器队列
目录 muduo网络库学习笔记(三)TimerQueue定时器队列 Linux中的时间函数 timerfd简单使用介绍 timerfd示例 muduo中对timerfd的封装 TimerQueue的结 ...
- PAT-1003 Emergency(Dijkstra)
1003 Emergency (25 分) As an emergency rescue team leader of a city, you are given a special map of y ...
- 微软职位内部推荐-SW Engineer II for Azure Network
微软近期Open的职位: Software Engineer II The world is moving to cloud computing. Microsoft is betting Windo ...
- PAT甲题题解-1096. Consecutive Factors(20)-(枚举)
题意:一个正整数n可以分解成一系列因子的乘积,其中会存在连续的因子相乘,如630=3*5*6*7,5*6*7即为连续的因子.给定n,让你求最大的连续因子个数,并且输出其中最小的连续序列. 比如一个数可 ...
- vue.js指令总结
1.v-html 用于输出真正html,而不是纯文本. 2.v-text 输出纯文本. <!DOCTYPE html> <html lang="en"> & ...