git在本地仓库直接使用rm彻底删除文件,服务端还是存在
2024-10-11 23:28:56
本地仓库:A和B
服务器:C
今天在本地仓库A希望删除一个文件test,于是执行以下命令:
1
2
3
4
|
$ sudo rm test $ git add . $ git commit -m "delete test" $ git push origin |
在本地仓库检查,的确没有文件test了。然后再次从服务器拉下来看看,执行
1
|
$ git pull |
test没有啦。我以为成功了。
但是在另一个客户端的本地仓库B拉下来,发现test又出来了。看来我以为的不是我以为的。
后来自己查资料,发现:
git add 表示 add to index only files created or modified and not those deleted
git add 只将新建的或者已更改的文件添加到索引区。(不会添加删除的文件)
但是我们现在是通过先rm的命令,那应该如何完成提交,并真正从服务端删除呢:
git add -u
git add -u 这个命令的意思是 add to index only files modified or deleted and not those created
只会处理已修改或者已删除的文件,但是不会处理新建的文件
好了,执行以下命令:
1
2
3
|
$ git add -u $ git commit -m "delete test" $ git push |
这时候我们在本地git status发现,已经没有了那些提交信息。再去本地仓库B看看,
test也没有了!
总结:如果我们要彻底通过git删除,分两种方式,如果先执行rm 命令去删除就可以使用本文的方法。
如果想通过git,可以使用git rm命令。
最新文章
- 运用css,对于下拉菜单的制作
- Java控制图片按比例缩放- (注意内存释放)
- svn 应该忽略的文件(visual studio)
- cellmap for iphone
- js 正则 以字母开头必须有 大小写字母数字组成 可以有“@";或 ”.“
- 并行程序设计模式--Master-Worker模式
- 【crunch bang】安装firefox,删除iceweasel
- ABAP 内表 详解
- yeoman的学习
- APP 如何适应 iPhone 5s/6/6Plus 三种屏幕的尺寸
- myEclipse异常解决:Errors occurred during the build. Errors running builder Mule 3 hot deployment
- SQL Server执行计划那些事儿(2)——查找和扫描
- VR全景智慧城市,开启“上帝视角”体验‘身临其境’
- oracle单字段拆分成多行
- 20165205 《网络对抗技术》 Exp0 Kali安装
- docker往阿里云推镜像和打包镜像
- 分布式锁之redisson
- [转]SpringMVC<;from:form>;表单标签和<;input>;表单标签简介
- Linux虚拟机下mysql 5.7安装配置方法图文教程
- ldap复制