• Git 学习01


    一、下载并安装git bash

    双击打开出现命令窗口

    创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录:

    cd F:

    mkdir learngit

    clip_image002

    clip_image004

    pwd F/learngit 显示当前目录

    clip_image006

    二、通过git init命令把这个目录变成Git可以管理的仓库

    clip_image002[4]

    Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),可以发现当前目录下多了一个.git的目录

    接下来把文件添加到版本库

    编写一个readme.txt文件,内容如下:

    特别注意千万不要使用Windows自带的记事本编辑任何文本文件。原因是Microsoft开发记事本的团队使用了一个非常弱智的行为来保存UTF-8编码的文件

    Git is a version control system.
    Git is free software.

    clip_image004[4]

    git add readme.txt
    git commit -m "wrote a readme file"

    简单解释一下git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。

    我们修改readme.txt文件

    git status

    clip_image006[4]

    虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用git diff这个命令看看:

    clip_image008

    知道了对readme.txt作了什么修改后,再把它提交到仓库就放心多了,提交修改和提交新文件是一样的两步,第一步是git add

    git add readme.txt

    同样没有任何输出。在执行第二步git commit之前,我们再运行git status看看当前仓库的状态:

    git status

    clip_image010

    git commit -m "add distributed"

    clip_image012

    提交后,我们再用git status命令看看仓库的当前状态:

    clip_image014

    三、查看历史记录

    git log

    clip_image016

    把readme.txt回退到上一个版本

    在Git中,用HEAD表示当前版本

    上一个版本就是HEAD^

    上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100

    如果一直 git reset --hard HEAD^

    就会不停的返回上一版本知道最后一个版本版本为止,这时候你再git status 查看版本就会发现看不到后面的版本了,想再回去已经回不去了,肿么办?

    办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个thir dversion commit idd380.,于是就可以指定回到未来的某个版本:

    clip_image018

    上一个版本内容

    clip_image020

    返回版本之后的内容

    clip_image022

    版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。

    关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办

    再想恢复到append GPL,就必须找到append GPL的commit id。Git提供了一个命令git reflog用来记录你的每一次命令:

    git reflog 查看命令历史

    clip_image024

    Git工作区和暂存区概念

    第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

    第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

    因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。

    你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

    clip_image026

    所以,git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。

    git commit只负责把暂存区的修改提交

    那怎么提交第二次修改呢?你可以继续git addgit commit,也可以别着急提交第一次修改,先git add第二次修改,再git commit,就相当于把两次修改合并后一块提交了:

    第一次修改 -> git add -> 第二次修改 -> git add -> git commit

    添加一个style.css文件 add 并提交之后 手动删除

    git reset --hard commit_id 也可以还原回来 (根据说明备注写好找到命令ID

    创建远程仓库

    下面以我自己的账号为例:

    clip_image028

    gitHub账号 195684842@qq.com

    clip_image030

    https://help.github.com/articles/generating-ssh-keys/s

    clip_image032

    在哪里添加密匙

    https://help.github.com/articles/keeping-your-ssh-keys-and-application-access-tokens-safe/#reviewing-your-ssh-keys

    clip_image034

    clip_image036

    clip_image038

    clip_image040

    clip_image042

    添加远程库

    登陆GitHub

    然后找到“Create a new repo”按钮,创建一个新的仓库:

    在Repository name填入learngit,其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库:

    把一个已有的本地仓库与之关联,然后把本地仓库的内容推送到GitHub仓库

    clip_image044

    在本地的learngit仓库下运行命令:本地关联到远程库

    git remote add origin git@github.com:ruoqiang/learngit.git

    下一步,就可以把本地库的所有内容推送到远程库上:(第一次推送)

    git push -u origin master

    在以后的推送或者拉取时就可以简化命令。

    git push origin master

    总结:

    1. 安装好了git 进入当前项目目录(cd F:/learngit) git 直接git init

    2.添加文件:git add 文件名 提交文件:git commit –m “提交说明

    3.查看文件变更状态 git status 比较文件版本之间的不同 git diff

    4.使用命令git reset --hard commit_id。版本的历史之间切换

    切换前,用git log可以查看提交历史,以便确定要回退到哪个版本。

    命令窗口关闭之后要返回版本,用git reflog查看命令历史,以便确定要回到哪个版本。

    5.每次修改,如果不add到暂存区,那就不会加入到commit中。

    创建远程仓库

    1.创建SSH Key

    ssh-keygen -t rsa -C "youremail@example.com"

    设置密码是可以为空一直回车知道不提醒了为止

    msysgit 下 确认ssh-agent 的可用性

    然后eval $(ssh-agent -s)

    添加 SSH key 到ssh-agent

    ssh-add ~/.ssh/id_rsa

    可以在用户主目录里找到.ssh目录,里面有id_rsaid_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥

    2:登陆GitHub,打开“Account settings”,“SSH Keys”页面:

    在Key文本框里粘贴id_rsa.pub文件的内容(打开文件复制里面的内容贴进去

    6. 关联远程

    要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git

    关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

    此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

    参考链接

    http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256916071d599b3aed534aaab22a0db6c4e07fd0000

  • 相关阅读:
    oppo手机永久打开USB调试模式
    一个简单的php分页类代码(转载)
    php分页类的二种调用方法(转载)
    直流电与交流电的几点区别
    变压器的分类_变压器的作用
    静态无功补偿与动态无功补偿的区别(转载)
    无功补偿装置三种投切方式(转载)
    西门子plc串口通讯方式
    电动葫芦起吊重物时摇晃怎么办?
    电灯节电小知识的方法大全(转载)
  • 原文地址:https://www.cnblogs.com/ruoqiang/p/4991008.html
Copyright © 2020-2023  润新知