GIt

[TOC]

1. git安装与配置

1.1 git安装

搜索git进官网下载,安装即可!

查看都有哪个版本的GIT
which -a git 

查看自己使用的git版本
git --version 

使用指定版本的git
vim .bash_profile(mac)
export PATH= 安装路径:$PATH
sourve .bash_parofile(加载)

1.2 git基本配置

  1. 增删改查
git config --global user.name "name"
git config --global user.email "email"

git help config
man git-config

增加用户
git config --global --add user.name "name"
git config user.name(查看当前用户)

删除用户
git congif --get user.name
git config --list --global(查看当前配置信息)
git config --global --unset.name "anme"(删除当前name用户)

修改用户
git config --golbal user.name "na"

查看所有用户
git config --get user.name
git config --list --global
  1. 子命令
git config --global alias.co checkout
git config --global alias.br branch
git config --global alias.st status
git config --global alias.ci commit
git config --global alias.lol "log --oneline"

2. git基本工作流程

git的四种 对象

  • blob
  • tree
  • commit
  • tag:固定的历史提交

git仓库

git仓库的创建
git init 目录 

git裸仓库
git init --bare 目录

将已有文件纳入git
直接进入这个目录下,然后执行
git init即可

或者
git clone 
git clone 裸仓库 新名字

  • 工作区
  • 暂存区
  • 历史提交

工作区---暂存区---历史记录--暂存区or工作区

  • git add
  • git commit
  • git status
  • git rm 删除
  • git mv移动重命名
  • gitignore 不添加某些东西
git add a b 将a和b加入暂存区
git status 查看提交
git commit -m "提交信息" #提交到历史仓库
git rm file 删除工作区和历史仓库的文件
git rm --cached file 仅仅删除暂存区的文件

git mv file newFile 重命名

将当前路径下的所有文件都添加都暂存区
git add .
git add -A 


忽略目录下这些文件,不跟踪这些文件
vim .gitigonore
通过通配符的样式忽略
.[oa] 忽略以.o和.a结尾的文件
!a.o 不要忽略这个文件
**/res 匹配零个或者多个目录


3. git暂存区

  • 工作区
    • git对象库

4.git本地分支与合并

  • git btanch 创建分支
  • git tag 做标记
  • git chechout 切换分支
  • git stash
  • git merge 合并分支

5. git---关注修改

5.1 撤销修改

  1. 这个文档在工作区被修改后还没git add .
第一步:撤销工作区的修改
git checkout -- file_name
  1. 这个文档在工作区被修改后git add .到了暂存区
第一步:撤销缓存区的修改
git reset HEAD file_name
第二步:撤销工作区的修改
git checkout -- file_name
  1. 这个文档被commit file_name -m "注释"
撤销本次提交,回退本节

5.2 管理修改

  1. 第一次vim a.txt
  2. 添加到暂存区git add a.txt后第二次vim a.txt
  3. 然后git commit -m "注释"
  4. git status止呕会发现第二次的vim a.txt更改没有修改成功
  • 第一次修改->git add->第二次修改->git commit

  • 你看,我们前面讲了,Git管理的是修改,当你用git add命令后,在工作区的第一次修改被放入暂存区,准备提交,但是,在工作区的第二次修改并没有放入暂存区,所以,git commit只负责把暂存区的修改提交了,也就是第一次的修改被提交了,第二次的修改不会被提交。

5.3 工作区和暂存区

  • 工作区
    • 电脑山能看到的目录
  • 版本库
    • 工作区有一个.git的文件
    • git add将文件添加到暂存区
    • git commita将暂存区内容提交到当前分区

5.4 版本回退

git reset -- hard HEAD^

git reglog

git reset -- hard 版本号

6. GitHub

  1. ssh连接GitHub

cd ~/.ssh

ls

如果有三个文件,那个id_ras.pub就是公钥

生成秘钥:ssh-keygen -t rsa
验证是否授权成功: ssh -T git@github.com

  1. GitHub基本使用

    star 收藏

    fork “复制”

    repository 仓库

    watch 观察

    Gist 代码片段

    Pull Request 请求合并

    Issue 提问题/bug

    clone 克隆

    git config 配置信息

    git push 将本地代码推送到github上去

    git pull 将远程的代码更新下来

    git branch 分支

    git merge 合并

关联仓库
git remote add origin git@github.com~~

将本地代码推送到GitHub上
git push origin master

请求合并
git pull origin master 

将其他分支推送到GitHub
git push origin 其它分支的名字

将其它分支合并在本分支
git merge 其它分支的名字


Pull Request 添加新功能给原作者(folk之后)


fatal: remote origin already exists

git remote rm origin

1. git config -global user.email "xxx@xx.com"
2. git config -global user.name "xxx"


1. git init 激活git管理
2. git add 加入缓存区
3. git commit -m "msg" 提交到版本库
4. git status 查看状态
5. git diff 查看文件修改了什么内容
6. git log 查看提交日志
7. git log --pretty=oneline 将日志显示在一行
8. git reset --hard HEAD^ 向前退一版本
9, git reset --hard xxxxx 回退到指定版本
10.  git reflog 显示每一次命令
11. git checkout -- fileName 撤销本地对文件的修改,回退到commit或者add后的状态
12. git reset HEAD 'filename' 将文件filename的暂存区修改放弃
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 安装Git Git的下载地址:Git官网下载地址 Git本地仓库和命令 配置用户 下载完Git后,右键会有一个Gi...
    TokyoZ阅读 4,485评论 1 7
  • Git 是目前最流行的分布式版本控制系统之一。 版本控制指的是,记录每次版本变更的内容和时间等细节,保留各版本之间...
    神齐阅读 1,396评论 0 7
  • (预警:因为详细,所以行文有些长,新手边看边操作效果出乎你的预料) 一:Git是什么? Git是目前世界上最先进的...
    axiaochao阅读 1,922评论 1 8
  • Git和Github学习 1.创建版本库 安装git,至于这个话题就不细说了,按照你电脑的操作系统下载一个合适的g...
    郭子web阅读 366评论 0 0
  • 教程网址:http://www.liaoxuefeng.com/wiki/0013739516305929606d...
    maybenai阅读 676评论 0 1