git安装
打开浏览器输入Git官网网站回车即可打开Git官网;
点击里面的“Downloads for Windows”即调整到下载页面等待下载即可,现在最新版本为2.10.1
我下载的安装包名为Git-2.10.1-64-bit.exe。
双击既打开安装设置界面。然后点击“Next”;配置安装组件,默认即可,点击“Next”;默认已经都帮我们否选上了。包括创建桌面快捷方式、Git Bash、Git GUi、已经目录和后缀关联等;
在“Adjusting your PATH environment”选项中,默认即可。点击“Next”;
(这个步骤最好选择第二项“Use Git from the Windows Command Prompt”, 这样在Windows的命令行cmd中也可以运行git命令了。这样会对以后的一些操作带来方便);配置行结束标记,保持默认“Checkout Windows-style, commit Unix-style line endings”;
在终端模拟器选择页面,默认即可;
配置Git额外选择默认即可;
安装完成,默认点”Finish”即可。
安装完成后,还需要最后一步设置,在命令行输入:
git使用
初始化一个Git仓库,使用git init命令。
创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录: $ mkdir learngit $ cd learngit $ pwd C:/Users/lee/learngit pwd命令用于显示当前目录。在我的电脑上,这个仓库位于C:/Users/lee/learngit 第二步,通过git init命令把这个目录变成Git可以管理的仓库: $ git init 瞬间Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),细心的读者可以发现当前目录下多了一个.git的目录(隐藏文件): 这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。
添加文件到Git仓库,分两步:
第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;eg: git add readme.txt 第二步,使用命令git commit,完成。eg:git commit -m "任意起名"
git status
此命令可以让我们时刻掌握仓库当前的状态,上面的命令告诉我们,readme.txt被修改过了,但还没有准备提交的修改。
git diff
虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。比如你休假两周从国外回来,第一天上班时,已经记不清上次怎么修改的readme.txt,所以,需要用这个命令git diff看看:
$ git diff readme.txt
git diff顾名思义就是查看difference,显示的格式正是Unix通用的diff格式,可以从上面的命令输出看到,我们在第一行添加了一个“distributed”单词。
知道了对readme.txt作了什么修改后,再把它提交到仓库就放心多了,提交修改和提交新文件是一样的两步,第一步是git add: $ git add readme.txt 同样没有任何输出。在执行第二步git commit之前,我们再运行git status看看当前仓库的状态: git status告诉我们,将要被提交的修改包括readme.txt,下一步,就可以放心地提交了: $ git commit -m "任意起名"
git reset - -hard commit_id 时光机穿梭
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset - -hard commit_id。
在Git中,用HEAD表示当前版本,,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
添加远程仓库
现在的情景是,你已经在本地创建了一个Git仓库后,又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步; 这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作,真是一举多得。 首先,登陆GitHub,然后,在右上角找到“Create a new repo”按钮,创建一个新的仓库: 在Repository name填入learngit,其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库: 目前,在GitHub上的这个learngit仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联; 然后,把本地仓库的内容推送到GitHub仓库。 现在,我们根据GitHub的提示,在本地的learngit仓库下运行命令: $ git remote add origin https://github.com/starlee261/learngit.git 请千万注意,把上面的starlee261替换成你自己的GitHub账户名,否则,你在本地关联的就是我的远程库; 关联没有问题,但是你以后推送是推不上去的,因为你的SSH Key公钥不在我的账户列表中。 添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。 下一步,就可以把本地库的所有内容推送到远程库上: $ git push -u origin master 把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。 由于远程库是空的,我们第一次推送master分支时,加上了-u参数; Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来 在以后的推送或者拉取时就可以简化命令。 推送成功后,可以立刻在GitHub页面中看到远程库的内容已经和本地一模一样: 从现在起,只要本地作了提交,就可以通过命令: $ git push origin master 把本地master分支的最新修改推送至GitHub,现在,你就拥有了真正的分布式版本库! 当你第一次使用Git的clone或者push命令连接GitHub时,会得到一个警告: SSH警告 The authenticity of host 'github.com (xx.xx.xx.xx)' can't be established. RSA key fingerprint is xx.xx.xx.xx.xx. Are you sure you want to continue connecting (yes/no)? 这是因为Git使用SSH连接,而SSH连接在第一次验证GitHub服务器的Key时,需要你确认GitHub的Key的信息是否来自GitHub的服务器,输入yes回车即可。 Git会输出一个警告,告诉你已经把GitHub的Key添加到本机的一个信任列表里了: Warning: Permanently added 'github.com' (RSA) to the list of known hosts. 这个警告只会出现一次,后面的操作就不会有任何警告了。 如果你实在担心有人冒充GitHub服务器,输入yes前可以对照GitHub的RSA Key的信息是否与SSH连接给出的一致。

