创建git仓库
1、本地新建
git init #初始化
2、远程克隆
git clone git@github.com:user/project.git
常用命令
git add test.txt #将文件加入仓库缓存区
git commit -m 'some comment' # 将缓存区文件提交到仓库
git status # 查看仓库当前状态
git diff #查看修改内容
git log #查看提交日志
git log --pretty=oneline #日志美化
git reset --hard HEAD^ #退回到上一版本,HEAD^^上上个版本,HEAD~n 上n个版本
git reflog #记录每一次命令
git diff HEAD -- readme.txt # 查看工作区和仓库最新版的区别
git checkout -- readme.txt #撤销未被存入暂存区的修改
git reset HEAD readme.txt # 撤出暂存区的修改回到工作区
git branch dev # 创建dev分支
git checkout dev # 切换至dev分支
git checkout -b dev #创建名为dev的分支并切换至dev
git branch # 查看所有分支,当前分支前会有*号
git checkout master #切换回master分支
git merge dev #将分支上改动合并至master分支,默认使用fastforward模式,删除分支后分支信息丢失
git branch -d dev #删除dev分支
git branch -D dev # 当dev分支还没与master合并时,无法用-d删除,用-D强行删除
git log --graph --pretty=oneline --abbrev-commit # 查看分支合并情况
git merge --no-ff dev # 合并式将分支信息加入log
git stach #暂存目前工作区
git stash list #列出所有暂存工作区
git stash apple # 恢复工作区
git stash drop # 删除暂存工作区
git stash pop #恢复工作区并删除stash内容
git stash apply stash@{0} # 有多个stash时如何恢复
git remote #查看远程库信息
git remote -v #查看远程库详细信息
fetch 抓去权限,push 推送权限
git push origin master# 推送master分支
git put origin dev # 推送dev分支
git tag *** # 给最新提交的commit打标签
git tag *** commit-id # 给对应commit-id的commit打标签
git tag 查看所有标签
git tag -a sometag -m somecomment commit-id # 给对应commit-id的commit打标签(sometag),并附说明文字(somecomment)
git tag -d tagname # 删除标签
git push origin tagname #推送标签
git push origin --tags #推送所有标签
# 删除远程标签
git tag -d tagname #先删除本地标签
git push origin :refs/tags/tagname # 删除远程标签
自定义git
git仓库中有某些文件不能提交时,可以建 .gitignore 文件,将文件名放入此文件中
git add test.txt # 当test.txt在igitignore中时,会添加失败
git add -f test.txt #强制添加
git check-ignore -v test.txt #查看添加失败原因
配置别名
git config --global alias.st status #将status改成别名 st,--global 后配置针对当前用于有效,没有--global的配置只针对当前仓库有效
git st #等于 git status
将本地仓库上传到github
1,登陆github创建新的repository
2,
git remote add origin git@github.com:user/project.git
3,
git push -u origin master #第一次加u 以后不用加