一、结构:
    |--工作区
    |--版本库
        |--stage——add,可以每个添加到暂存区
        |--master——commit        一次性提交到版本库

  具体的理论可以参考我的另一篇博客:Git版本控制系统VCS

二、本地github操作

1、安装git
    github官网下载桌面版,会有个git shell,安装就成功了。测试;git
    ubuntu是:sudo apt-get install git
    
    安装完成后,还需要最后一步设置,在命令行输入:
     git config --global user.name "Your Name"
     git config --global user.email "email@example.com"
    
2、创建版本库
    step1--其实就是创建一个文件夹
        mkdir sunseazhu
        cd sunseazhu
    step2--通过git init命令把这个目录变成Git可以管理的仓库
        git init
    step3--创建一个readme文件,内容如下,并拷贝到该仓库中
        Hello git,welcome!
    step4--用命令git add告诉Git,把文件添加到仓库:
        git add readme.txt
    step5--用命令git commit告诉Git,把文件提交到仓库:
        git commit -m "wrote a readme file"

3、查看当前的仓库状态
    仓库分支情况、提交情况等。
    1)git status
        显示:On branch master
                    nothing to commit, working directory clean
        修改一下readme内容,再执行git status显示
                    
    2)git diff
        告诉你修改后的内容和之前的差异
    3)git add readme
        git commit -m "edit it one"

4、版本回退相关操作
    1)git log:查看当前git操作的日志,就是git commit -m "anotation"
        git log --pretty=oneline:只显示一行,前面乱七八糟的id号
    2)git reset --hard HEAD^
        在Git中,用HEAD表示当前版本,也就是最新的提交d33a…aed95,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
    3)上面回到了以前的版本,如何回来
        (1)只要前面的commit id还能看到,就可以直接写前面几个数字就行了
            git reset --hard d33a
        (2)git reflog 可以查看之前的commit id
5、关于修改的问题
    1)第一次修改 -> git add -> 第二次修改 -> git commit
        git commit只提交添加到暂存区的文件,而与工作区的没关系,故会存在多次修改后只提交第一次修改的情况。
        git diff HEAD -- readme.txt:查看工作区的和版本仓库中的不同
    2)git checkout -- readme.txt
        修改过的文件,不想要了,可以撤销命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销
        若修改的文件没放到暂存区则撤销到版本库的状态,否则暂存区的状态
    3)git reset HEAD readme.txt
        此时想把暂存区的文件修改撤掉。
            
6、删除文件
    rm test.txt
    这时候工作区中的文件就和版本库中的不同了,git status可以查看。两种选择。
    1)确实从版本库中删除该文件,那就用命令git rm删掉,并且git commit
        git rm test.txt
        git commit -m "remove test.txt"
    2)另一种情况是删错了,可以很轻松地把误删的文件恢复到最新版本.
        git checkout -- test.txt
    注:此时知道git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
    
    至此,本地版本库基本操作完成,下面介绍远程仓库

三、远程github操作

1、在GitHub中创建一个仓库learngit
2、git remote add origin git@github.com:sunseazhu/learngit.git
    添加后,远程库的名字就是origin,相当于给learngit起了个别名,这是Git默认的叫法,也可以改成别的。
3、把本地库的所有内容推送到远程库上
    git push -u origin master
    由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
    从现在起,只要本地作了提交,就可以通过命令:
    git push origin master
4、从远程库中克隆
    git clone git@github.com:michaelliao/gitskills.git

参考博客: 1、廖雪峰的官方博客——使用GitHub

      2、易百Git教程

实用篇如何使用github(本地、远程)满足基本需求的更多相关文章

  1. Docker实用篇

    Docker实用篇 0.学习目标 1.初识Docker 1.1.什么是Docker 微服务虽然具备各种各样的优势,但服务的拆分通用给部署带来了很大的麻烦. 分布式系统中,依赖的组件非常多,不同组件之间 ...

  2. 【Git】简单地使用github当做远程共享仓库

    简单地使用github当做远程共享仓库 1.进入各自的github,选取一个人的github作为总的远程共享仓库,其余成员每次修改完项目后pull request请求合并自己的修改内容. 2.其余开发 ...

  3. windows下使用git和github建立远程仓库

    转自(http://www.bubuko.com/infodetail-430228.html) 从昨天开始就在看git的使用,因为在Windows下很多命令行操作都比较坑爹,但是今天再走了无数弯路之 ...

  4. MyBatis 实用篇(二)配置文件

    MyBatis 实用篇(二)配置文件 一.全局配置 全局配置:http://www.mybatis.org/mybatis-3/zh/configuration.html <?xml versi ...

  5. MyBatis 实用篇(一)入门

    MyBatis 实用篇(一)入门 MyBatis(http://www.mybatis.org/mybatis-3/zh/index.html) 是一款优秀的持久层框架,它支持定制化 SQL.存储过程 ...

  6. 乐鑫esp8266基于freeRtos实现私有服务器本地远程OTA升级

    目录 一.前言: 二.回顾下OTA的流程: 三.lwip网络框架的知识的使用: 四.如何处理服务器返回的数据? 五.扇区的擦除和烧写? 六.如何调用? 七.好好享用吧! 八.下载: 九.工程截图: 代 ...

  7. Android基础新手教程——1.5.2 Git之使用GitHub搭建远程仓库

    Android基础新手教程--1.5.2 Git之使用GitHub搭建远程仓库 标签(空格分隔): Android基础新手教程 本节引言: 在上一节中.我们学习了怎样使用Git.构建我们的本地仓库.轻 ...

  8. git设置github的远程仓库的相关操作

        git能够把github作为远程仓库,本地可以进行推送有关变更,从而多人可以进行协作开发工作.    1  ssh-keygen -t rsa -C "your-email@163. ...

  9. iOS开发——实用篇&提高iOS开发效率的方法和工具

    提高iOS开发效率的方法和工具 介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先要说的肯定是IDE了,说到IDE,Xcode不能跑,当然你也可能同时 ...

随机推荐

  1. Swoole系列(三):建立TCP服务器并发送数据测试

    <?php // 建立tcp服务器下 $host = '0.0.0.0'; $port = 9501; $serv = new swoole_server($host,$port); $serv ...

  2. ps -aux --sort -rss |head 列出进程拿物理内存占用排序 使用ps aux 查看系统进程时,第六列即 RSS列显示的就是进程使用的物理内存。

    ps -a     Select all processes -u userlist               Select by effective user ID (EUID) or name. ...

  3. CentOS7安装mysql提示“No package mysql-server available

    在CentOS7上安装mysql时,出现了以下的提示: 原因是: CentOS7带有MariaDB而不是MySQL,MariaDB和MySQL一样也是开元的数据库,您可以使用yum -y instal ...

  4. Java 学习笔记之读取jdbc.propertyes配置参数

    package test; import java.io.IOException; import java.io.InputStream; import java.util.Properties; p ...

  5. Tesseract–OCR 库原理探索

    一,简介: Tesseract is probably the most accurate open source OCR engine available. Combined with the Le ...

  6. Python:Django【基础篇】

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  7. Andriod - 创建自定义控件

    控件和布局的继承结构: 可以看到,我们所用的所有控件都是直接或间接继承自 View的,所用的所有布局都是直接或间接继承自 ViewGroup 的.View 是 Android 中一种最基本的 UI 组 ...

  8. [Noip2016]天天爱跑步 LCA+DFS

    [Noip2016]天天爱跑步 Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.?天天爱跑步?是一个养成类游戏,需要玩家每天按时上线,完成打卡任 ...

  9. 九度OJ 1360:乐透之猜数游戏 (递归)

    时间限制:2 秒 内存限制:32 兆 特殊判题:否 提交:955 解决:261 题目描述: 六一儿童节到了,YZ买了很多丰厚的礼品,准备奖励给JOBDU里辛劳的员工.为了增添一点趣味性,他还准备了一些 ...

  10. 如何使用模板生成 sqlite3 sql 创建语句?

    template<typename T,typename... Args> std::string createTable(T tableName,Args&&... ar ...