GitHub入门与实践

本文是对《GitHub入门与实践》一本书的总结和归纳,方便日后查看Git各种命令的使用

image

目录

image

git初始设置

git config --global user.name  # 姓名

git config --global user.email  # 邮箱

让输出命令具有更好的可读性:

$ git config --global color.ui auto

设置SSH Key

GitHub上连接已有仓库是通过SSH Key来进行的,创建SSH Key:

$ ssh-keygen -t rsa -C

两个重要的文件:

  • id_rsa:私有密钥
  • Is_rsa.pub:公开密钥

在GitHub中添加公开密钥,就可以用私有密钥来访问的

$ cat ~/.ssh/id_rsa.pub

完成设置之后,用手中的私有密钥与GitHub进行通信:

$ ssh -T git@github.com

下面是实际操作部分:

创建仓库

新建一个git上的\color{red}{远程仓库},见下图,不要勾选初始化的read.me文件

image
image

上面的私有和公开写反了。。。哈哈哈哈哈

初始化

在本地新建一个和远程仓库同名字的本地仓库,进行初始化

git init   # 生成.git目录
image

查看状态git status

  • 未加入到缓存区:红色

  • 加入到缓存区:绿色

git status
image

缓存区git add

向缓存区添加文件。上面的栗子中有使用git add命令。缓存区是提交前的一个临时区域。

提交commit

提交指的是激励工作树中所有文件的当前状态。通过参数m可以加上本次的提交信息。还可以修改提交信息。

git commit -m "first commit"
git commit --amend "重新提交"
image

添加和提交

将上面的两个动作同时进行的语句

git commit -am "添加和提交同时进行"

查看日志

  1. 输入q即可退出
git log
image
  1. 只看一行信息
image
  1. 查看指定文件、目录的信息

在后面直接跟上文件名称即可

image

如果想看到提交带来的改动,加上参数-p

$ git log -p README.md

git reflog

查看当前仓库执行过的操作日志

只要不进行Git的GC(Garbage Collection,垃圾回收),就可以通过日志随意调取近期的历史状态。

前面表示的是哈希值。哈希值只要输入4位以上就可以执行的

image

差别git diff

git diff查看更改前后的差别

git diff head  # 查看和最新提交的差别

养成好的习惯:在执行git commit命令之前,先执行git diff命令,查看本次提交和上次提交的差别,确认完毕再提交

分支操作

master分支是git的主分支,其他分支都是以这个分支为中心进行的。

image

显示分支列表

git branch   # 分支名列表显示,同时显示现在所处的分支
git branch -a  # 同时显示远程仓库和本地仓库的分支信息
image

当前只有master分支,星号表示当前所处的分支

新建分支并切换

git checkout -b feature-A   # 创建的同时切换到分支feature-A

上面👆的语句等同于:

git branch feature-A   # 创建分支
git checkout feature-A   # 切换分支

git checkout -  # 短横线表示切换到上一个分支
  • 分支feature-A 的操作不会影响到主分支master
  • 分支之间的操作互不影响,能够同时进行

特性分支Topic

  1. 特性分支是集中实现单一特性(主题),除此之外不进行任何作业的分支。

  2. 在实际的开发中,往往会创建多个特性分支,保留一个随时可以发布软件的稳定分支。稳定分支通常由master分支担当。

  3. 基于特定主题的作业在特定分支中进行,主题完成后再和master分支合并

image

分支合并git merge

git checkout master   # 先切换到主分支
git merge --no-ff feature-A   # 合并分支:创建合并并提交,记录本次合并

图表形式git log —graph

用图表的形式输出提交日志,非常直观

git log --graph
image

回溯历史版本

Git的另一个特征是可以灵活地操作历史版本。

要让仓库的HEAD、暂存区、当前工作树回溯到指定状态,需要使用git reset --hard命令。

需要目标时间点的哈希值。什么是哈希值???

image
git reset --hard 9154998......  # 恢复到该时间点的状态

压缩历史git rebase -i

使用场景:如果发现已经提交的内容中有错误(拼音、内容等小错误),可以提交一个修改,将这个修改包含到前一个提交之中,压缩成一个历史记录

git rebase -i HEAD~2   # 压缩最近的两个历史记录

git log --graph  # 树形查看提交日志

推动到远程仓库

添加远程仓库-add

Git是分散性版本管理系统。为了防止和其他仓库混淆,远程的仓库名尽量保持和本地仓库相同

创建远程仓库的时候不要勾选添加初始化文件

现在假设有个test的本地仓库,现在创建了一个同名的远程仓库,将通过如下的语句将该其设置成本地仓库的远程仓库

git remote add origin git@github.com:username/test.git

推送到远程仓库-push

将当前分支下本地仓库中的内容推送到远程仓库中,使用如下语句:

git push -u origin master   # -u参数是指在推送的同时,将origin仓库的master分支设置成本地仓库当前分支的上游

-u参数是指在推送的同时,将origin仓库的master分支设置成本地仓库当前分支的上游。好处:将来能够直接从远程仓库拉取:

git pull

如果不是推送到master分支,比如是feature-D

git checkout -b feature-D   # 先切换到该分支
git push -u origin feature-D   # 推送该分支

获取远程仓库

默认处在maste分支下面

git clone "仓库地址"
image

假设远程有个分支feature-A,我们想获取该分支下的内容:

  • 在本地创建同名的分支
git checkout -b feature-A origin/feature-A  # -b后面的feature-A 是本地的分支,和远程同名

# 修改内容之后进行推送
git push

获取最新的远程

假设本地中有个分支feature-A,想把它更新到最新远程仓库的状态

git pull origin feature-A

hub

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