Mac通过Terminal来使用Github

本文中使用的一些图片和说明引用参考了一些其它文章的内容,这些文章链接详见本文末尾的参考网址说明.

1. GitHub的注册

这一步具体就不再详细描述了,建议根据GitHub的新手引导一步一步的做一遍,初步了解相关流程.


2. 安装或更新Git

使用Github的前提之一就是必须已经在Mac上安装了Git.
通常,Mac已经安装了Git . 打开Terminal,在提示符后面输入git命令,如下图,如果git命令可以被识别,说明已经安装了Git .


通过 git --version 可以查看当前安装的版本,如果没有安装,到 Git网站 下载并安装最新版本,如下图:


注意上图中红框的部分,即使你已经安装了Git,建议使用红框中的命令更新到最新版本.
安装更新完毕之后,进行git config配置:

//显示当前的Git的配置
git config --list
//第一次提交需要添加邮箱账号与用户名
git config [--global] user.name "你的名字"
git config [--global] user.email "你的邮箱"

3. SSH配置

Terminal与GitHub之间使用SSH通信协议进行数据传输,想要将数据传输到github的时候,需要对方信任电脑. 配置流程如下:

  1. 检查本机的ssh是否存在,在Terminal中输入命令 cd ~/.ssh,如果存在会检索出有哪些,可以将这些ssh备份,或者将新建的ssh生成到另外的目录下.
  2. 通过默认参数生成ssh ssh-keygen -t rsa -C xxxx@gmail.com(注册GitHub时的email)
  1. 在GitHub中选择Settings->SSH and GPG Keys 输入Title和Key,Key中存放生成的id_rsa.pub文件中的内容.

4.打开Terminal,输入命令 ssh -T git@github.com ,测试账号跟GitHub的连接

Hi ynchai! You've successfully authenticated, but GitHub does not provide shell access

4. Git的初步使用

  • 1.在GitHub中创建新的Repositor,这一步不具体描述了
  • 2.创建本地仓库,并和远程仓库进行连接,主要步骤如下:
      cd ...  //到仓库文件夹下
      git init  //初始化本地仓库
      git add <File>  //添加某一个文件
      git add *  //添加文件夹下面的所有文件
      git status  //检查状态 如果都是绿的 证明成功
      git commit -m "commit的相关描述"  //提交到本地仓库,并写一些注释
      git remote add origin SSH Key  //连接远程仓库(SSH Key在GitHub中创建的respositor中clone with SSH中复制),origin远程的别名
      git pull origin master --allow-unrelated-histories //合并一些远程仓库的内容
      git push -u origin master  //将本地仓库的东西提交到origin的master分支下面
  • 3. .gitignore的创建和使用
    • .gitignore文件比较重要,一般在进行项目第一次push之前进行创建和使用
    • 在本地仓库的文件夹下面 touch .gitignore 创建.gitignore文件,然后open .gitignore,写入忽略目录.
    • 具体忽略目录配置请参考 github/gitignore ,也可以在 gitignore.io 输入你需要配置的语言,生成配置.
    • 如果设置 .gitignore之前已经进行了push,可以通过以下命令,在提交:
      git rm -r --cached .
      git add .
      git commit -m 'update .gitignore'
    
    • ignore相关语法
      # 此为注释 – 将被 Git 忽略
      *.a       # 忽略所有 .a 结尾的文件
      !lib.a    # 但 lib.a 除外
      /TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
      build/    # 忽略 build/ 目录下的所有文件
      doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
    

5. Git branch 相关操作

# 本地分支的相关操作
# 建立一个本地自己的分支
git branch mybranch  //mybranch自己分支的名字
# 查看本地有多少分支
git branch
# 切换到新建的分支
git checkout mybranch  //此时进行修改只是在mybranch上,不会影响master,此时可以进行修改、add、commit操作
# 切换回原来的分支
git checkout master
# 将之前在mybranch上的修改合并到master
git merge mybranch
# 删除无用的mybranch分支
git branch -d mybranch
# 将本地master的修改push到远程
git push 
## 新建和切换branch一次完成
git checkout -b branchname
# 远程分支的相关操作
# 查看远程分支
git branch -r
# 现在本地创建一个远程没有的分支
git checkout -b branchname
# 将本地分支链接到远程分支
git push origin branchname//将本地分支链接到远程,同时在远程上也创建同一分支,origin远程仓库名字, branchname本地创建的分支名字
# 将修改后的branchname push到远程分支branchname
git push --set-upstream origin branchname
# branchname代码没有问题,合并到主分支
git checkout master
git merge branchname
git push
# 删除远程分支
git push origin :branchname
## 1.7版本之后,也可以使用以下语句
git push origin --delete branchname
# 删除本地分支
git branch -d branchname

6. Git撤销git add 文件 、撤销 commit 文件

  • 撤销 git add 文件
# 将修改提交至stage区
git add xx.file
# 重置HEAD指针,xx.file 变为 unstaged,git diff和git status又可以查看
git reset HEAD xx.file
# 修改错误后撤销修改
git checkout --xx.file
  • 撤销 git commit 文件
# 将修改或者添加从stage提交到本地仓库
git commit -m "xxxxx"
# 把commit文件的状态更改为staging
git reset --soft HEAD^ //之后再用git status,提示有修改的内容可以commit
# 重新修改commit
git commit --amend -m "new message" //git log可以看到这条commit记录,之前的那条没有了,如果只是想修改commit的message,不用中间更改状态的直接用这一句就可以,但是如果有别的修改,就需要有中间那一句
# 撤销上一次的commit和all changes
git reset --hard HEAD^
# 撤销上二次的commit和all changes
git reset --hard HEAD^^

7. Git tag标签相关操作

tag是对历史一个提交id的引用,如果理解这句话就明白了. 使用git checkout tag即可切换到指定tag,例如:git checkout v0.1.0切换到tag历史记录会处在分离头指针状态,这个是的修改是很危险的,在切换回主线时如果没有合并,之前的修改提交基本都会丢失,如果需要修改可以尝试git checkout -b branch tag创建一个基于指定tag的分支,例如:git checkout -b tset v0.1.0 这个时候就会在分支上进行开发,之后可以切换到主线合并

# 打标签
git tag -a v1.0.1 -m "Release version 1.0.1"  //git tag 是打标签命令, -a是添加标签,其后跟上新标签号, -m后面是相关描述
# 提交标签到远程仓库, git push不会将标签传送到远端服务器上
## 提交单个标签
git push origin [tagname]
## 提交所有标签
git push [origin] --tags
### 如果以上命令不起作用,请在Git控制台上确认你的账号是否有权限推送Tag
# 删除标签
git tag -d v1.0.1 //-d表示删除,后面跟上要删除标签的名字
# 删除远程标签
git push origin  :refs/tags/v1.0.1
# 查看标签
git tag / git tag -l
# 获取tag对应的代码,先clone整个仓库,然后
git checkout tagname
# 获取tag对应的代码,并在这个基础上进行修改
git checkout -b branch_name tag_name  //从tag创建一个分支,后续操作和普通的git操作一样

8. Git常用命令

      git init  //git 初始化(进入本地目录以后)
      git remote add origin url  //连接远程仓库origin(url)
      git diff  //看看有什么修改的,检测unstaged文件的差异
      git diff --staged  //查看staged文件的差异
      git status  //检查状态
      git add .  //本目录下所有修改和新的文件添加至Stage(暂存区)
      git add *  //同上面的注释
      git commit -m "message"  //将更新和修改从Stage提交到本地仓库
      git pull origin master  //远程仓库相对本地的更新
      git push origin master  //将本地仓库的修改提交至远程仓库
      git rm "文件"  //删除文件
      git clone url  //下载工程 url 是远程的url
      git log  //获取版本记录状态

附上一张 w3c 的git常用命令速查表:


参考网址

  1. 在Mac(OS X)中使用GitHub的超详细攻略(20170706)
  2. Mac下使用GitHub
  3. Mac下使用github
  4. MAC下GitHub命令操作
  5. 关于使用终端terminal对GitHub项目进行管理
  6. mac下使用git向GitHub提交项目代码
  7. Git的一些常用命令,及.gitignore的配置
  8. Git分支与多人协作-Git使用总结!
  9. Git查看、删除、重命名远程分支和tag
  10. git reset soft,hard,mixed之区别深解
  11. Git中tag的用法
  12. Git教程-分支和tag管理
  13. git学习--GitHub上如何进行PR(Pull Request)操作
  14. Pull Request的正确打开方式(如何在GitHub上贡献开源项目)
  15. Which remote URL should I use?
  16. 真正理解 git fetch, git pull 以及 FETCH_HEAD
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容