Git常用命令

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qingfeng812/article/details/72876453

Git常用命令

标签(空格分隔): 版本控制


配置

查看配置的方法:

git config –list

日志与版本管理

查看日志[找到指定提交版本的commit_id]:

 git log 

回滚指定版本

git reset --hard  commit_id
git reset --hard  0b9f0c8fc2bb8c04376a950a5bb90835ad9aad84

放弃本地仓库,远程仓库强制覆盖本地仓库

git fetch --all
git reset --hard origin/master

//git feth 是下载远程仓库代码,不与本地仓库代码合并
//git reset 把HEAD指向刚刚下载的最新版本

.gitnore文件重新生效

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

基础命令

本地仓库初始化

 git init

克隆到本地

git clone https://github.com/spring-guides/gs-gradle.git

强制推送[谨慎]:

 git push -f  

查看状态:

 git status

添加本地:

 git add  .

提交本地:

 git commit -m "commit at 2015-09-17"

推送到远程(远程仓库存在)

 git push [remote-name] [branch-name]
 git push origin master [默认的提交方式]
 git push github master

新建远程仓库 (远程仓库不存在)

 git remote add [remote-name] [url]
 git remote add origin url  

删除远程仓库:

 git remote rm [remote-name]     

远程仓库下拉代码:

git pull origin master

状态

恢复为unstaged状态:

   git rm --cache test.c  【变为unstaged状态】

取消本地仓库暂时保存:

   git reset test.c  【状态变为modified状态】

分支

查看本地分支:

  git branch    

查看所有远程仓库:

  git remote -v

查看单个远程仓库:

  git remote show [remote-name]

提交本地test分支作为远程的master分支:

 git push origin test:master   

提交本地test分支作为远程的test分支:

 git push origin test:test    

.gitignore

在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:

说明
# 此为注释 将被 Git 忽略
*.a 忽略所有 .a 结尾的文件
!lib.a 但 lib.a 除外
/TODO 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ 忽略 build/ 目录下的所有文件
doc/*.txt 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

Git忽略规则及.gitignore规则不生效的解决办法
.gitignore无效,不能过滤某些文件
利用.gitignore过滤文件,如编译过程中的中间文件,等等,这些文件不需要被追踪管理。
现象:a
在.gitignore添加file1文件,以过滤该文件,但是通过git status查看仍显示file1文件的状态。a
原因
在git库中已存在了这个文件,之前push提交过该文件。
.gitignore文件只对还没有加入版本管理的文件起作用,如果之前已经用git把这些文件纳入了版本库,就不起作用了
解决
需要在git库中删除该文件,并更新。
然后再次git status查看状态,file1文件不再显示状态。

规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

使用 git rm 命令即可,有两种选择,
一种是 git rm –cached “文件路径”,不删除物理文件,仅将该文件从缓存中删除;
一种是 git rm –f “文件路径”,不仅将该文件从缓存中删除,还会将物理文件删除(不会回收到垃圾桶)。

总结

  • .gitignore 文件的作用,在文件没有纳入版本库管理(没有add)之前有效;

参考文献:

http://www.cnblogs.com/wang_yb/p/3867221.html git命令(大全)
http://blog.csdn.net/chun799/article/details/9095635 git基础
http://blog.csdn.net/hudashi/article/details/7664374 git add详解
http://blog.csdn.net/zxncvb/article/details/22153019 git config命令使用
http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013758404317281e54b6f5375640abbb11e67be4cd49e0000 学习博客

相关文章
|
13天前
|
缓存 数据可视化 网络安全
Git命令大全
Git命令大全
45 1
|
17天前
|
开发工具 git
Git教程:深入了解删除分支的命令
【4月更文挑战第3天】
37 0
Git教程:深入了解删除分支的命令
|
1月前
|
存储 Shell Linux
【Shell 命令集合 文件管理】Linux git命令使用教程
【Shell 命令集合 文件管理】Linux git命令使用教程
34 0
|
1月前
|
开发工具 git
git常用命令整理
git常用命令整理
13 0
|
23天前
|
开发工具 git 开发者
Git常用命令大全:让你轻松驾驭版本控制
Git命令速查:`git init`新建仓库,`git clone`克隆,`git add`入暂存区,`git commit -m`提交,`git status`查看状态,`git log`查看历史,`git branch`创建分支,`git checkout`切换,`git merge`合并,`git pull`拉取更新,`git push`推送,`git remote -v`查看远程,`git checkout --`撤销本地修改,`git reset HEAD`取消暂存,`git reset --hard`回退版本。掌握这些,提升代码管理效率!
18 0
|
2天前
|
存储 Linux 开发工具
Git 分布式版本控制系统基本概念和操作命令
Git 分布式版本控制系统基本概念和操作命令
21 0
|
4天前
|
算法 Java BI
云效产品使用报错问题之平台上导出的统计数据和 git 中使用命令导出的数据统计都对不上,如何解决
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
30天前
|
算法 开发工具 git
【git 实用指南】git 增加 本地代码 git add 相关命令和复杂情况需求
【git 实用指南】git 增加 本地代码 git add 相关命令和复杂情况需求
92 0
|
1月前
|
Shell Linux 开发工具
【Shell 命令集合 系统管理 】Linux 查看当前Git仓库的提交历史 gitps命令 使用指南
【Shell 命令集合 系统管理 】Linux 查看当前Git仓库的提交历史 gitps命令 使用指南
18 0
|
1月前
|
开发工具 git
git命令使用大全
git命令使用大全
20 1