1.git status
查看当前目录下文件变化状态,红色代表有修改的文件,但是没有加入index里面
2.git add .
添加修改文件到index下,或者添加新的文件到index
3.git commit -m "....."
添加提交信息,'..." 为提交的comment
4. git push
将本地commit的内容,push到远程分支
5.git pull
将远程分支上面的代码同步到本地
6.git branch -a
查看当前工程的所有分支的列表
7.git branch xxx
new一个新的分支
8.git checkout xxx
切换当前分支到xxx 分支
9.git reset --hard head
reset当前分支的改动,此行为需要谨慎使用
10.git 回退之前的提交的版本
a.git reset --hard <commitId> // 回退某个提交版本 b.git push -f origin <branch name> //push 当前分支名称到远程分支
11.git 删除本地分支
git branch -D <branch name>
12.git 删除本地有,但是远程已经不存在的分支
git remote prune origin
13.git reflog
如果log已经被reset --hard 之后,看不到之前的log的时候,可以用reflog 查看之前的所有日志
14.git 重新设定远程仓库地址
//a.删除远程url git remote rm origin //b.重新指定远程分支地址 git remote add origin <url path> //c.push 本地分支到远程仓库 git push --set-upstream origin master
15.解决国内访问github 慢或者无响应
a.使用 http://tool.chinaz.com/dns?type=1&host=github.com&ip= 网站,输入github.com
b.选择TTL值最小的对应的ip
c.针对window用户,打开C:WindowsSystem32driversetc 路径,选择hosts文件,用记事本或者notepad++等编辑工具,在页面最低端添加 b 步骤中获取的ip 和网站名称,例如:
192.30.253.112 github.com
192.30.253.113 github.com
d.window用户,crtl+R ,输入cmd,进入控制台,输入ipconfig /flushdns ,刚才的修改就生效了。
16.git统计代码量
git ls-files | grep ".ts$" | xargs wc -l
16.git checkout remote branch
a.git fetch
b.git checkout <branch name>
17.Another git process seems to be running in this repository
rm -f ./.git/index.lock
18.git stash
git stash 可用来暂存当前正在进行的工作, 比如想pull 最新代码, 又不想加新commit, 或者另外一种情况,为了fix 一个紧急的bug, 先stash, 使返回到自己上一个commit, 改完bug之后再stash pop, 继续原来的工作。
基础命令:
//暂存当前改动内容,回到当前head,没有修改状态 git stash //do some work,此时你可以做一些自动需要的工作,例如pull最新的code,或者fix bug等 //将刚才暂存的改动还原回来 git stash pop
19.查看远程分支地址
git remote -v
20.fork的代码同步远程
a.指定上游仓库 git remote add upstream <your upstream url> //查看是否指定成功 git remote -v b.fetch 上游仓库 c.merge你需要的分支 git merge upstream/<your branch>
21.清理无用的分支
git remote prune origin