GitHub入门与实践

作者: 皮皮大 | 来源:发表于2020-06-13 00:56 被阅读0次

    本文是对《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)"
    

    相关文章

      网友评论

        本文标题:GitHub入门与实践

        本文链接:https://www.haomeiwen.com/subject/fnwotktx.html