前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Git从0到1

Git从0到1

作者头像
若与
发布2018-04-25 11:40:03
1.4K0
发布2018-04-25 11:40:03
举报

本文只是帮助你入门,从一个不会使用git的小白,到会解决开发中常见的使用。 废话不多说,直接进入正题。

最远处

git

git是用于Linux内核开发的版本控制工具。与CVS、Subversion一类的集中式版本控制工具不同,它采用了分布式版本库的作法,不需要服务器端软件,就可以运作版本控制,使得源代码的发布和交流极其方便。git的速度很快,这对于诸如Linux内核这样的大项目来说自然很重要。git最为出色的是它的合并追踪(merge tracing)能力

安装

安装,其实很简单,和普通软件安装无异。这里不介绍了。

创建新仓库

创建一个目录,打开,然后执行

代码语言:javascript
复制
git init

创建一个新的git仓库. 初始化git的方法有很多种

  • 在本地创建
  • 在gitlab或github上创建,git clone下来,
  • 图形界面上创建

远程

克隆仓库

执行如下命令可以创建一个本地克隆版本:

代码语言:javascript
复制
git clone /path/to/repository

如果实在远端服务器上的仓库,你的命令会是这样子:

代码语言:javascript
复制
git clone username@host:/path/tp/repository

克隆仓库也有很多内容,比如修改仓库名之类的等等。

工作流

你的本地仓库由git维护的三棵组成。第一棵树是你的工作目录,它持有实际文件;第二个是暂存区(index),它像是缓存区,临时保存你的改动;最后是HEAD,它指向你最后一次提交的结果。

git工作原理

添加和提交

你可以提交更改(吧它们添加到暂存区),使用如下命令:

代码语言:javascript
复制
git add <filename>
git add *
git add .

这是git基本工作流程第一步;使用如下命令以时间提交改动:

代码语言:javascript
复制
git commit -m '代码提交的信息'

现在,你的改动已经提交到HEAD,但是没有提交到你的远端仓库。

推送改动

你的改动现在已经在本地仓库的HEAD中了。执行如下命令以将这些改动提交到远端仓库:

代码语言:javascript
复制
git push origin master

可以把master换成你想要推送的任何分支。 如果你没有克隆现有的仓库,并欲将的仓库连接到某个远程服务器,你可以使用如下命令添加:

代码语言:javascript
复制
git remote add origin <server>

如此,你就可以将你的改动推送到所添加的服务器上去了。

分支

分支是用来将特性开发绝缘开来的,在你创建仓库的时候,master是"默认的"分支。在其他分支进行开发,完成后再将他们合并到主分支上。 创建一个叫"feature_test"的分支,并切换过去:

代码语言:javascript
复制
git checkout -b feature_test
# or
git branch feature_test
git checkout feature_test

切换回主分支

代码语言:javascript
复制
git checkout master

删除分支

代码语言:javascript
复制
git branch -d feature_test

除非你将分支推送到远程仓库,不然该分支就是其他人不可见的:

代码语言:javascript
复制
git push origin <branch>
更新与合并

要更新你本地仓库至最新改动,执行:

代码语言:javascript
复制
git pull origin <branch>

以在你工作目录中获取(fetch)合并(meger)远端的改动。 要合并其他分支到你当前分支(如master),执行:

代码语言:javascript
复制
git merge <branch>

在这两种情况下,git都会尝试去自动合并并改动。遗憾的是,这可能并非每次都成功,并可能出现(conficts).这个时候就需要你修改这些文件手动合并这些冲突(conflicts).改完后,你需要执行如下命令将他们标记为合并成功:

代码语言:javascript
复制
git add <filename>

在合并改动之前,你可以使用如下命令预览差异:

代码语言:javascript
复制
git diff <source_branch> <target_branch>
标签

为软件发布创建标签是推荐的。这个概念早已存在,svn中也有。你可以执行如下命令创建一个叫做1.0.0的标签:

代码语言:javascript
复制
git tag 1.0.0 abcdef1234

abcef1234是你想要标记的提交的ID的前10位字符,可以使用下列命令获取提交ID:

代码语言:javascript
复制
git log

你也可以使用少一点的提交ID前几位,只要它的指向具有唯一性。提交ID可以回滚。

log

如果想要了解蹦迪仓库的历史记录,最简单的命令:

代码语言:javascript
复制
git log

还可以添加一些参数来修改它的输出,得到自己想要的结果。只看某个人提交的记录:

代码语言:javascript
复制
git log --auth=youdi

一个压缩后每一条提交记录只占位一行

代码语言:javascript
复制
git log --pretty=oneline

或者你想要通过ASCII艺术的树形结构来显示所有的分支,每个分支都标示了它的名字和标签:

代码语言:javascript
复制
git log --graph --oneline --decorate --all

看看哪些文件改变了:

代码语言:javascript
复制
git log --name-status

这些只是你可以使用的参数一部分,更多可以查看:

代码语言:javascript
复制
git log --help
替换本地改动

假如你操作失误(当然,这最好永远不要发生),你可以使用如下命令替换掉本地改动:

代码语言:javascript
复制
git checkout -- <filename>

此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。 假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它

代码语言:javascript
复制
git fetch origin
git reset --hard origin/master
使用小贴士

彩色的git输出

代码语言:javascript
复制
git config color.ui true

显示历史记录时,每一个提交信息只显示一行

代码语言:javascript
复制
git config format.pretty oneline

交互式添加文件到暂存区

代码语言:javascript
复制
git add -i

下面介绍一些工作中常用的小技巧:

撤销刚刚git add(暂存区的文件)
代码语言:javascript
复制
git reset --hard <filename>
撤销暂存区中指定的commit之前的提交
代码语言:javascript
复制
git reset --hard <commit的hash值>

注:--hard丢弃working directory中内容的修改 --soft保留working directory中内容的修改

修改commit最新一次的注释信息
代码语言:javascript
复制
git commit -amend

会打开编辑器,可能是nano,或vim 修改以后,重新push到远端仓库

代码语言:javascript
复制
git push master origin  -f

另外:

代码语言:javascript
复制
git commit -amend -m 'msg'
修改commit的历史注释信息
代码语言:javascript
复制
git rebase -i head~2

修改前2条提交记录

版本回退

版本回退,需要使用git commit提交ID,查看如下命令:

代码语言:javascript
复制
git log

回到指定版本

代码语言:javascript
复制
git reset --hard  <commit hash value>

远端仓库也回退

代码语言:javascript
复制
git push origin <branch> -f
忽略文件

如果忽略文件,在仓库中创建 .gitignore

代码语言:javascript
复制
vim .gitignore
*.pyc
/tmp
database.config
.gitignore
.tmp

进行匹配,匹配成功文就不会添加到work directory.

储藏(Stashing)

经常有这样的事情发生,当你正在进行项目中某一部分的工作,里面的东西处于一个比较杂乱的状态,而你想转到其他分支上进行一些工作。问题是,你不想提交进行了一半的工作,否则以后你无法回到这个工作点。解决这个问题的办法就是git stash命令。

“‘储藏”“可以获取你工作目录的中间状态——也就是你修改过的被追踪的文件和暂存的变更——并将它保存到一个未完结变更的堆栈中,随时可以重新应用。

代码语言:javascript
复制
git stash

查看储藏的信息

代码语言:javascript
复制
git stash list

放出储藏

代码语言:javascript
复制
git stash pop <stash index>
多个仓库,开发

在公司开发,一般都是将项目clone到自己名下的仓库中,进行开发,如何在本地拉去项目中最新的项目。 修改git配置文件 .git/config

代码语言:javascript
复制
[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
[remote "origin"]
        url = git@github.com:jacksonyoudi/python-note.git
        fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
        remote = origin
        merge = refs/heads/master
[remote "google"]
        url = git@github.com:google/python-note.git
        fetch = +refs/heads/*:refs/remotes/origin/*

按上面配置好以后 拉取项目最新代码,合并到本地

代码语言:javascript
复制
git pull google master

推送到项目上,而非自己仓库

代码语言:javascript
复制
git push google feature

望见

git的内容就介绍到这里,以上都是皮毛,你只当做入门的初级文章即可,不必深究。如果有精力,希望你配置好github. 如想深入,建议官方文档。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.04.08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • git
  • 安装
    • 创建新仓库
      • 克隆仓库
      • 工作流
      • 添加和提交
      • 推送改动
      • 分支
      • 更新与合并
      • 标签
      • log
      • 替换本地改动
      • 使用小贴士
      • 撤销刚刚git add(暂存区的文件)
        • 撤销暂存区中指定的commit之前的提交
        • 修改commit最新一次的注释信息
        • 修改commit的历史注释信息
        • 版本回退
        • 忽略文件
        • 储藏(Stashing)
        • 多个仓库,开发
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档