git -GitHub-git常用命令(git安装及命令使用)

git命令自动补全(MAC)

1.安装Homebrew
一 、安装bash-completion

  1. $ brew install bash-completion

  2. '' if [ -f $(brew --prefix)/etc/bash_completion ]; then
    '' . $(brew --prefix)/etc/bash_completion
    '' fi
    添加到~/.bash_profile(如果没有该文件,新建一个)

二、拷贝文件、设置路径
访问下面网站
{https://github.com/git/git.git}
找到”contrib/completion/”目录下的git-completion.bash ,然后点击编辑,拷贝其内容,复制到文本文件,保存为 git-completion.bash 文件 然后将文件用命令拷贝到 ~/ 目录下
三、配置~/.bash_profile
~/.bash_profile文件(该目录下如果没有,新建一个)中添加下边的内容:
source ~/.git-completion.bash
执行命令:source ~/.bash_profile

1. 安装git

Ubuntu: sudo apt-get install git
Mac: brew install git

2. git 基本使用

? {版本的创建和回退}
? {工作区和暂存区}
? {管理修改}
? {撤销修改}
? {对比文件不同}
? {删除文件}

2.1 版本的创建和回退

  1. 初始化仓库
    git
  2. 创建一个git版本库
    git
  3. 创建版本
    git add 文件或目录
    git commit -m '版本信息说明' (img)
  4. 查看版本记录
    git log
    git log --pretty=oneline # 一行显示
    **git reflog # 查看所有操作记录
  5. 版本回退
    git reset --hard HEAD^ # ^表示回退到上一个版本
    等价git reset --hard HEAD~数字 # 数字对应回退到第几个版本
    或者git reset --hard 版本序列号 # 回退到指定版本

2.2 工作区和暂存区(img)

? 第一步:
git add把工作区文件的修改添加到暂存区;
? 第二步:
git commit提交更改,把{暂存区}的所有内容提交到{当前分支}。

查看当前工作树的状态:
git status

2.3 管理修改

::git管理的文件的修改,它只会提交暂存区的修改来创建版本。::

2.4 撤销修改

git checkout -- <文件> # 丢弃工作区的改动

git reset HEAD <文件>
可以把暂存区的修改撤销掉,重新放回工作区。
{小结}
? 场景1:::当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。::
? 场景2:::当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。::
? 场景3:::已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节。::

2.5 对比文件不同

  • 对比工作区和版本中文件的不同
    git diff HEAD -- 文件名
    git checkout -- <文件> # 丢弃工作区的改动
  • 对比两个版本之间某个文件的不同
    1)对比HEAD 和 HEAD^ 中code.txt的不同:
    git diff HEAD HEAD^ code.txt

2.6 删除文件

(1) 我们把目录中的code2.txt删除,git status查看工作树的状态。
git status命令会立刻提示哪些文件被删除了。(img)
(2) 现在你有两个选择,一是确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit(img)
误删恢复: git checkout -- code2.txt,这样文件code2.txt又回来了
{小结}
::命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。::

3 分支管理

作用:
? 分支之间的互不影响这种特性可以增加团队合作的效率。GIT分支的另外一个重要特性就是可以合并不同软件仓库(fork)的分支

3.1 创建与合并分支

(1) 一开始的时候,master分支是一条线,git用master指向最新的提交,再用HEAD指向master,就能确定当前分支,以及当前分支的提交点。
(img)
每次提交,master分支都会向前移动一步,这样,随着你不断提交,master分支的线也越来越长。
(2) 当我们创建新的分支,例如dev时,git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上。
(img)
git创建一个分支很快,因为除了增加一个dev指针,改变HEAD的指向,工作区的文件都没有任何变化。
(3) 不过,从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变。
(img)
(4) 假如我们在dev上的工作完成了,就可以把dev合并到master上。git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并。
(img)
git合并分支也很快,就改改指针,工作区内容也不变。
(5) 合并完分支后,甚至可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支。
(img)

命令:
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建并切换分支:git branch -b <name>
合并某个分支到当前分支:git merge <name>
删除分支:git branch -d <name>

3.2 合并冲突解决

  • 当两个分支对同一个文件做了修改之后, 合并分支会冲突.
  • git status告诉我们冲突的文件。
  • git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容修改之后才能解决冲突, 解决之后再git commit 文件名提交
  • git log --graph --pretty=oneline 查看分支合并情况
  • 合并完成, 删除分支

3.3 合并分支策略

{快速合并模式}: fast forward
分支上新建一个文件并提交到版本控制, 再合并分支则不能快速合并,git会提示输入合并信息说明. 输入之后, git 会合并内容并自动创建一次新的提交.

禁用fast forward合并

git merge --no-ff -m '版本说明' 分支名
--no-ff参数,表示禁用Fast forward合并

3.4 bug分支

  1. 保存当前工作现场,等修复bug之后继续工作
    git stash
  2. 创建bug-001分支修复bug
  3. 确定要在哪个分支上修复bug, 假定要在master分支上修复, 就从master创建临时分支
  4. 现在修复bug代码, 然后提交
  5. 修复完成之后, 切换master分支, 并完成合并, 最后删除bug-001分支.
  6. git stash list 查看保存的工作现场, git stash pop 恢复工作现场
    {小结}
    ::修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除; 当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,恢复工作现场。::

4 使用GitHub

4.1 创建仓库

(1) 注册github账户,登录后,点击"New respository"。(img)
(2) 在新页面中,输入项目的名称,勾选'readme.md',点击'create repository'。(img)(img)

4.2 添加ssh账户

::如果某台机器需要与github上的仓库交互,那么就要把这台机器的ssh公钥添加到这个github账户上。::
(1) 在ubuntu的命令行中,回到用户的主目录下,编辑文件.gitconfig,修改某台机器的git配置。(img)
(2) 使用如下命令生成ssh密钥。(img)
ssh-keygen -t rsa -C '邮箱地址'
(3)进入主目录下的.ssh文件件,下面有两个文件。
公钥为id_rsa.pub
私钥为id_rsa
查看公钥内容,复制此内容。(img)
(4) 点击账户头像后的下拉三角,选择'settings'。(img)
(5) 点击'SSH and GPG keys',然后点击'New SSH Key'添加ssh公钥。(img)
(6) 到浏览器中粘贴ssh公钥,点击'Add SSH Key'。
(img)

4.3 克隆项目

(1) 在浏览器中点击进入github首页,再进入项目仓库的页面。(img)
(2) 复制git地址。
(img)
(3) 回到自己的电脑上,使用如下命令克隆项目。(img)
git clone 克隆地址
(4) 克隆出错,执行如下命令解决。(img)
eval "$(ssh-agent -s)"
ssh-add
(5) 在命令行中继续执行上面的克隆仓库命令。(img)

4.4 远程交互

  • 上传分支
    (1) 项目克隆到本地之后,执行git checkout -b smart创建分支smart.
    (2)创建一个code.py并提交一个版本
    (3)推送分支

    • git push <远程主机名> <本地分支名>:<远程分支名>
      例子: git push origin smart
  • 跟踪远程分支

    • git branch --set-upstream-to=origin/远程分支名 本地分支名
      例子:(1) 执行如下命令让本地smart分支跟踪远程smart分支。
      git branch --set-upstream-to=origin/smart smart
  • 从远程分支上拉取代码

    • git pull <远程主机名> <远程分支名>:<本地分支名>
      例子: #(1) 把远程分支smart上的代码下载并合并到本地所在分支
      git pull origin smart

5 项目中的Git

开发时的分支

一般在开发时,远程库上会有两个主要分支master分支和dev分支。
{master}:用户保存发布的项目代码。V1.0,V2.0
{dev}:保存开发过程中的代码。

项目经理

? 1) 项目经理搭建项目的框架。
? 2) 搭建完项目框架之后,把项目框架代码放到服务器。

普通员工

? 1) 在自己的电脑上,生成ssh公钥,然后把公钥给项目经理,项目经理把它添加的服务器上面。
? 2) 项目经理会给每个组员的项目代码的地址,组员把代码下载到自己的电脑上。
? 3) 切换到dev分支,并创建新的分支。
? 4) 每天在自己的分支上开发代码。
? 5) 每一个员工开发完自己的代码之后,都需要将自己的代码合并到本地的dev分支,然后将代码发布远程的dev分支上。

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容