1、任何文件在Git内都只有三种状态:
①已提交(committed):已提交表示该文件已经被安全地保存在本地数据库中了;
②已修改(modified):已修改表示修改了某个文件,但还没有提交保存;
③和已暂存(staged):已暂存表示把已修改的文件放在下次提交时要保存的清单中。
由此我们看到Git管理项目时,文件流转的三个工作区域:Git 的本地数据目录,工作目录以及暂存区域。
 
2、先决条件:
1)在GitHub上面注册一个账号并激活
2)安装windows下的git客户端如msysgit
 
*****************************华丽的分割线*****************************
一、使用SSH建立本地Git跟GitHub的连接
SSH是什么,我也不清楚,只知道很多连接相关的都叫SSH比如说XShell连接Linux主机的时候就是SSH,应该是一种连接协议吧,需要找一个谷歌。
 
1、查看本地是否存在SSH:
No such file or directory 说明不存在ssh,则需要去创建一个新的ssh keys,使用命令建立SSH连接(看第3点)。
 
2、运行命令:
$ ssh-keygen -t rsa -C your_email@youremail.com
执行完后在当前登录的用户下建立了文件夹:
 
3、将新生产的SSH密钥导入到Github账户中
其中key是id_rsa.pub里面的文件内容:
 
4、接下来测试一下我们的git跟github是否能连接上
①输入命令:ssh -T git@github.com
②输入yes,提示
③输入之前设置的密码:直接提示连接被关闭
④接着执行上面的命令,再一次输入密码,发现
以上设置为了让我们本地的Git跟Github连接上,接下来在本地配置git以便能够更好的进行签入和签出文件
 
*****************************华丽的分割线*****************************
 
二、配置Git并新建项目
1、使用命令 
git config --global user.name “Your Name”
git config --global user.email “you@example.com
如图:
操作之后windows下当前登陆用户会多一个.gitconfig文件,
文件内的内容为:
 
2、新建一个仓库
 
3、上传文件到GitHub中
 
①在的盘下新建一个目录名为jstest,跟前面建立的仓库名一样
 
②跳转到d:\jstest目录下
或者直接在cmd命令下进行,不过要将git的bin目录添加到环境变量下面
需要将git的bin路径添加到环境变量
 
③新建一个README文件
 
④签入到本地文件库中
first commit 是签入备注
 
整个步骤如下图:
 
官方给出的命令如下:
 
以上就是Git的一个简单使用
 
*****************************华丽的分割线*****************************
 
三、Git不能支持中文的解决方法

1、ls不能显示中文目录
解决办法:在git/etc/git-completion.bash中增加一行:
alias ls='ls --show-control-chars --color=auto'

2、git commit不能提交中文注释
解决办法:修改git/etc/inputrc中对应的行:
set output-meta on
set convert-meta off

3、git log无法显示中文注释
解决办法:在git/etc/profile中增加一行:
export LESSCHARSET=iso8859

来源于网络

*****************************华丽的分割线*****************************

四、Git一些命令详解(不断更新)

1、从GitHub上克隆一个项目
克隆地址在每一个项目的首页都有,有很种形式的方式
 
2、使用git diff查看差异(这个缺点太多了,请直接右键单击项目然后选择Git gui)
 
3、将一个已经存在的项目更新到GitHub上的步骤:
1)切换到工作目录:cd /d d:\github\jstest
1)新建一个文件夹,跟项目名称一模一样例如jstest
2)将项目文件复制到jstest文件夹下
 
4)进入项目根目录夹并初始化git:git init
5)添加所有文件:git add .
6)提交到本地:git commit -m "start project"
7)添加到远程服务器:git remote add origin git@github.com:liujiangbei/pytest.git
8)更新到GitHub上:git push -u origin master
参考文章:
 
4、创建一个仓库
Create a new repository on the command line
touch README.md
git init
git add README.md
git commit -m "first commit"
git remote add origin
git push -u origin master
 
Push an existing repository from the command line
git push -u origin master

 
5、命令条目
1)添加文件:git add file
2)移除文件:git rm file
3)从远程获取最新版本并merge到本地:git pull origin master (当然要进入项目的活动目录里)
4).更新项目(新加了文件):
$cd ~/jstest
$git add .                  //这样可以自动判断新加了哪些文件,或者手动加入文件名字
$git commit              //提交到本地仓库
$git push origin master    //不是新创建的,不用再add 到remote上了
5).更新项目(没新加文件,只有删除或者修改文件):
$cd ~/jstest
$git commit -a          //记录删除或修改了哪些文件
$git push origin master  //提交到github
6).忽略一些文件,比如*.o等:
$cd ~/jstest
$vim .gitignore     //把文件类型加入到.gitignore中,保存
然后就可以git add . 能自动过滤这种文件
7).clone代码到本地:
假如本地已经存在了代码,而仓库里有更新,把更改的合并到本地的项目:
$git fetch origin    //获取远程更新
$git merge origin/master //把更新的内容合并到本地分支
8).撤销
$git reset
 
*****************************华丽的分割线*****************************
有用的连接:
 
更新自己fork的项目
 
git中pull和fetch的区别
 
*****************************华丽的分割线*****************************
常见错误
1.$ git remote add origin git@github.com:WadeLeng/hello-world.git
错误提示:fatal: remote origin already exists.
解决办法:$ git remote rm origin
然后在执行:$ git remote add origin git@github.com:WadeLeng/hello-world.git 就不会报错误了
2. $ git push origin master
错误提示:error:failed to push som refs to
解决办法:$ git pull origin master //先把远程服务器github上面的文件拉先来,再push 上去。
 

附件列表

20130907.Git学习记录的更多相关文章

  1. Git学习记录 力做全网最强入门教程

    目录 Git学习记录 力做全网最强入门教程 什么是GitHub? 什么是Git? Git的配置 Git的安装(只介绍windos操作系统下) Git的配置 至此我们的入门教程到此结束,更新中级教程要等 ...

  2. Git学习记录--git仓库

    Git是一款强大的版本控制工具,与svn相比git的分布式提交,本地仓库等在使用时确实比较方便.当然两者之间各有优劣,我在这里不多做比较.由于之前少有接触git,只是零星大致地了解一点,所以找时间系统 ...

  3. git 学习记录—— git 中的仓库、文件状态、修改和提交操作等

    最近开始学习使用版本控制工具  git .学习方式主要通过阅读 git 网站上的 Pro git 和动手实践,使用的系统为 Ubuntu16.04LTS,以及 Windows 8.1. 本文主要关注 ...

  4. GIT学习记录4(标签管理与自定义git)

    学习参考地址:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 本编随笔只是自己对 ...

  5. GIT学习记录3(分支管理)

    学习参考地址:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 本编随笔只是自己对 ...

  6. git学习记录2(远程库管理)

    学习参考地址:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 本编随笔只是自己对 ...

  7. git学习记录1(本地库管理)

    学习参考地址:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 本编随笔只是自己对 ...

  8. Git学习记录-基本命令篇

    目录 网页在线练习地址 https://learngitbranching.js.org/ 1.git commit Git 仓库中的提交记录保存的是你的目录下所有文件的快照,就像是把整个目录复制,然 ...

  9. Git学习记录(一)

    本篇文章介绍Git的本地使用 Git是什么? Git是世界上最先进的分布式版本控制系统. 那么什么是版本控制系统? 我们来举个例子,假设我创建了一个项目Project.1,里面写了一个README.t ...

随机推荐

  1. 【UOJ#50】【UR #3】链式反应(分治FFT,动态规划)

    [UOJ#50][UR #3]链式反应(分治FFT,动态规划) 题面 UOJ 题解 首先把题目意思捋一捋,大概就是有\(n\)个节点的一棵树,父亲的编号大于儿子. 满足一个点的儿子有\(2+c\)个, ...

  2. POJ 2157 How many ways??

    How many ways?? Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Origina ...

  3. BZOJ 3674 可持久化并查集加强版(按秩合并版本)

    /* bzoj 3674: 可持久化并查集加强版 http://www.lydsy.com/JudgeOnline/problem.php?id=3674 用可持久化线段树维护可持久化数组从而实现可持 ...

  4. 0111mysql如何选择Join的顺序

    本文通过一个案例来看看MySQL优化器如何选择索引和JOIN顺序.表结构和数据准备参考本文最后部分"测试环境".这里主要介绍MySQL优化器的主要执行流程,而不是介绍一个优化器的各 ...

  5. 【剑指Offer学习】【面试题63:二叉搜索树的第k个结点】

    题目:给定一棵二叉搜索树,请找出当中的第k大的结点. 解题思路 假设依照中序遍历的顺序遍历一棵二叉搜索树,遍历序列的数值是递增排序的. 仅仅须要用中序遍历算法遍历一棵二叉搜索树.就非常easy找出它的 ...

  6. getColor()方法过时的替代方法

    Android SDK 升級到 23 之後,getResource.getColor(R.color.color_name) 過時 使用新加入的方法 ContextCompat.getColor(co ...

  7. Hive权限之改进

    不足 即使开启hive权限认证的情况下,不论什么用户仍然是超级用户.能够通过grant给不论什么人赋予不论什么权限,这样权限认证基本没有意义.因此必须在开启权限认证的同一时候.对运行grant/rev ...

  8. linux虚拟机网络设置好ping百度没有用

    场景:公司内网,本机使用的是本地连接,不是wiff,虚拟机设置了桥接模式 问题:使用桥接模式 启动好网络服务,查看ifconfig也获取到了设置的ip,可是ping了www.baidu.com还是没有 ...

  9. 2016.03.27,英语,《Vocabulary Builder》Unit 06

    equ: from Latin aequus, meaning 'equal', equalize:使相等; equivalent:[ɪ'kwɪvələnt], A is equivalent to ...

  10. 2016.02.25,英语,《Vocabulary Builder》Unit 02

    ag:来自拉丁语do.go.lead.drive,an agenda是要做事情的清单,an agent是代表他们做事的人,同时也是为他人做事的机构.拉丁语litigare包括词根lit,即lawsui ...