git-学习笔记
1. git set proxy
git设置代理教程 git-proxy.html
2. git设置信息: git config
- 所有的配置都在~/.gitconfig内
完善自己的用户名和信息
$ git config --global user.name "pengshao" $ git config --global user.email "pengshao@gmail.com"
–global参数是整个机器上面的全局参数
git设置颜色
$ git config --global color.ui true $ git config --global color.ui 1
自动更正
$ git config --global help.autocorrect 1
Git 命令自定义别名
别名用来帮助你定义自己的 git 命令 比如你可以定义 git a 来运行 git add –all。
要添加一个别名, 一种方法是打开 ~/.gitconfig 文件并添加如下内容:
[alias] co = checkout cm = commit p = push # Show verbose output about tags, branches or remotes tags = tag -l branches = branch -a remotes = remote -v
或者在命令行里键入:
$ git config --global alias.new_alias git_function
例如:
$ git config --global alias.cm commit #指向多个命令的别名可以用引号来定义: $ git config --global alias.ac 'add -A . && commit'
下面列出了一些有用的别名:
Alias Command git cm git commit git co git checkout git ac git add . -A git commit git st git status -sb git tags git tag -l git branches git branch -a git cleanup git branch –merged \ grep -v '*' xargs git branch -d git remotes git remote -v
3. 建立repository: git init
git init—添加当前目录为git仓库
git init
Initialized empty Git repository in /home/pengshao/tmp/gitlearn/.git/
4. git添加文件: git add *.***/git commit
git add *.***
pengshao@ps-debian:~/tmp/gitlearn$ pengshao@ps-debian:~/tmp/gitlearn$ git add readme.org pengshao@ps-debian:~/tmp/gitlearn$
这样就添加了一个git文件到自己的git仓库了.
git commit -m 'add readme.txt to my Git repository'
pengshao@ps-debian:~/tmp/gitlearn$ git commit -m 'add 2.org file' [master 528d873] add 2.org file your configuration file: git config --global --edit After doing this, you may fix the identity used for this commit with: git commit --amend --reset-author 1 file changed, 1 insertion(+) create mode 100644 2.org pengshao@ps-debian:~/tmp/gitlearn$
git会告诉你,1 file changed, 1 insertion(+)
git add 和 git commit 介绍
- git add 一次只能添加一个文件
- git commit一次可以添加很多文件
$ git add file1.txt $ git add file2.txt file3.txt $ git commit -m "add 3 files."
5. repository status: git status
- 修改2.org这个文件
git status–命令 查看git repository 近况
pengshao@ps-debian:~/tmp/gitlearn$ git status On branch master Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git checkout -- <file>..." to discard changes in working directory) modified: 2.org no changes added to commit (use "git add" and/or "git commit -a") pengshao@ps-debian:~/tmp/gitlearn$
- 上面的代码告诉我们,有一个文件修改了 但是没有commit到git repository
6. 查看文件不同: git diff *.***/git
git diff—查看文件的不同之处
可以用git diff *.***查看两个文件之间的不同之处.
pengshao@ps-debian:~/tmp/gitlearn$ git diff WARNING: terminal is not fully functional - (press RETURN) diff --git a/2.org b/2.org index 77a872f..dc92c40 100644 --- a/2.org +++ b/2.org @@ -1 +1,2 @@ -my git test +this is my git test file +我要继续学习git pengshao@ps-debian:~/tmp/gitlearn$
通过上面的代码就能看到两个文件之间的不同了
- 知道了文件之间的不同之处之后就能够放心的commit了
git add *.***
pengshao@ps-debian:~/tmp/gitlearn$ git add 2.org pengshao@ps-debian:~/tmp/gitlearn$
linux哲学,没有任何的输出
- git status 查看一下当前的 repository 这时候会提示modefied文件会有一个2.org 这时候就能进行commit了
git commit -m '我要继续学习git'
pengshao@ps-debian:~/tmp/gitlearn$ git commit -m '2.org->我要继续学习git字行' [master 197daf9] 2.org->我要继续学习git字行 your configuration file: git config --global --edit After doing this, you may fix the identity used for this commit with: git commit --amend --reset-author 1 file changed, 2 insertions(+), 1 deletion(-) pengshao@ps-debian:~/tmp/gitlearn$
告诉我们一个文件改动了,添加了新的两行(+),删除了一行(-)
git status 在查看一下啊
pengshao@ps-debian:~/tmp/gitlearn$ git status On branch master nothing to commit, working tree clean pengshao@ps-debian:~/tmp/gitlearn$
更改已经完成
7. 版本的回退: git reset –hard HEAD^
7.1. 在Git中,用HEAD表示当前版本
HEAD^: 上一个版本就是 HEAD^^: 上上一个版本就是 当然往上100个版本写100个比较容易数不过来 HEAD~100: 回到第一百个版本
$git reset --hard HEAD^
HEAD is now at b0c58a0 这是我的第一个git文件
7.2. 也可以红SHA1计算出来的那个大的数字–版本号来代替HEAD^
$ git reset --hard b0c58a0
这样和那样的效果是一样的 只要没有关电脑能找到版本号就能这样回退版本
7.3. 如果关掉电脑找不到版本号了可以通过: git reflog来找到全部的版本号码
pengshao@ps-debian:~/tmp/gitlearn$ git reflog b0c58a0 (HEAD -> master) HEAD@{0}: reset: moving to HEAD^ bcc625b HEAD@{1}: commit: 添加了记笔记的选项 b0c58a0 (HEAD -> master) HEAD@{2}: commit (initial): 这是我的第一个git文件 pengshao@ps-debian:~/tmp/gitlearn$
8. 操作日志: git log/git reflog
9. working dirctory + Repository+stage概念
当前目录就是工作区 工作区里面的.git文件就是版本库 最重要的就是称为stage(或者叫index)的暂存区 还有Git为我们自动创建的第一个分支master 以及指向master的一个指针叫HEAD
- git add *.*** 实际上是把文件或者修改提交到stage
- git commit 实际上是把缓存区的更新提交到master分支
10. 撤销修改: git checkout – ./my-first-git.org
git checkout 可以撤销没有提交到stage的修改 git reset HEAD 可以撤销掉提交到stage的修改
11. 删除文件: git rm *.***
11.1. 用rm或者git rm删掉的文件也是一个针对版本库的修改项目
git rm *.*** 从而在版本库中同步删除 git commit -m '**' 来提交到版本库中
11.2. 删错了恢复: git checkout – ./***.***
12. 远程仓库: github 使用教程
12.1. 本地上传远程库
- 在github上面 create a new repository
本地关联远程仓库
$git remote add origin https://github.com/boxmaking/learngit-note.git
这一步是关联远程仓库的命令 并且在本地仓库新建一个origin的远程分支
第一次推送master和所有内容
$git push -u origin master
实际上就是把本地的master分支推送到远程 由于远程库是空的,我们第一次推送master分支时,加上了-u参数 Git不但会把本地的master分支内容推送的远程新的master分支 还会把本地的master分支和远程的master分支关联起来 在以后的推送或者拉取时就可以简化命令
推送最新的内容
$git push origin master
把本地master分支的最新修改推送至GitHub
远程仓库比本地仓库提前一个版本
$git pull origin master
12.2. 远程仓库的clone
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆
13. 快速添加许可证文件
创建一个仓库时,Github会为你提供一个预置的软件许可列表:
对于已有的仓库,可以通过 web 界面创建文件来添加软件许可
输入LICENSE作为文件名后,同样可以从预置的列表中选择一个作为模板。
这个技巧也适用于 .gitignore 文件。
14. 工作区去除大量已删除文件
当用 /bin/rm 命令删除了大量文件之后 你可以用下面一条命令从工作区和索引中去除这些文件
$ git rm $(git ls-files -d)
例如:
$ git status On branch master Changes not staged for commit: deleted: a deleted: c $ git rm $(git ls-files -d) rm 'a' rm 'c' $ git status On branch master Changes to be committed: deleted: a deleted: c
15. 没有任何改动的提交
可以使用–allow-empty选项强制创建一个没有任何改动的提交:
$ git commit -m "Big-ass commit" --allow-empty
这样做在如下几种情况下是有意义的:
- 标记新的工作或一个新功能的开始。
- 记录对项目的跟代码无关的改动。
- 跟使用你仓库的其他人交流。
- 作为仓库的第一次提交,因为第一次提交后不能被
16. 美化相关
美化git status git status加上-sb选项:
$ git status -sb
美化 Git Log 输入如下命令:
$ git log --all --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit --date=relative