实用篇如何使用github(本地、远程)满足基本需求
2016-03-27 17:14
525 查看
一、结构:
|--工作区
|--版本库
|--stage——add,可以每个添加到暂存区
|--master——commit 一次性提交到版本库
具体的理论可以参考我的另一篇博客:Git版本控制系统VCS
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其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
至此,本地版本库基本操作完成,下面介绍远程仓库
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教程
|--工作区
|--版本库
|--stage——add,可以每个添加到暂存区
|--master——commit 一次性提交到版本库
具体的理论可以参考我的另一篇博客:Git版本控制系统VCS
二、本地github操作
1、安装gitgithub官网下载桌面版,会有个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中创建一个仓库learngit2、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教程
相关文章推荐
- 20145223《Java程序程序设计》第4周学习总结
- PHP-FPM子进程数量应该如何设置?
- 白话Spring(中级篇)---注解(3)
- 应用中Matlab语句学习笔记总结1
- Java循环语句之 for
- 泛型编程之“函数模板和类模板”
- 编程打印所有的3位质数,质数特点:只能被1和其本身整除
- Delphi XE Seattle update1 在iOS 9.3模拟器调试程序时出现dlopen(libmidas.dylib,1):image not found错误的解决
- SSM(maven) eclipse 搭建教程(合集)
- ThinkPHP 配置
- LeetCode OJ 之Merge TwoSorted Lists 解题报告
- 20145314郑凯杰 《Java程序设计》第4周学习总结
- LeetCode OJ 之 GenerateParenthesis解题报告
- 插入排序(JAVA语言描述)
- 【我的IT学习目标】目标是人前进的动力,只有有目标的人才可能成功!关于:C#
- Python图像处理之边缘检测
- <O'Reilly Java Swing> - Note01
- Java条件语句之 switch
- Java_chapter07_多维数组
- php关于<<<的用法