git常用命令与一些问题

在这里插入图片描述
git branch 列出所有分支,*代表当前所在分支
git branch 分支名 新建分支
git commit:是将本地修改过的文件提交到本地库中
git push:是将本地库中的最新信息发送给远程库
git pull:是从远程获取最新版本到本地,并自动merge
git checkout 分支名:切换本地仓库的分支
使用此命令时一定要注意确认本地文件是否已经上传到远程仓库,如果进行了commit操作并没有进行push操作,切换分支后本地仓库的所有已跟踪文件将会丢失

git clone 指定分支和切换分支

git clone 指定分支:git clone -b 分支名称 项目地址

假设分支名称为test,则:
git clone -b test 项目地址

git命令查看当前分支:git branch

git命令切换分支:git checkout 分支名

合并分支:将test分支合并到master分支

先切换到master分支,然后执行命令:git merge test

将master分支合并到test分支

先切换到test分支,然后执行命令:git merge master,

最后:git push

删除单个文件

git clone 地址
cd 要删除的文件目录下
git rm -r --cached 文件名
git commit -m ‘注释’
git push

提交到库时报错:

提交到库时报错:fatal: unable to access ‘https://github.com/Jan-Thirteen/blog.git/’: OpenSSL SSL_read: Connection was reset, errno 10054

在这里插入图片描述
产生原因:一般是这是因为服务器的SSL证书没有经过第三方机构的签署,所以才报错

参考网上解决办法:解除ssl验证后,再次git即可

git config --global http.sslVerify "false"

在这里插入图片描述

git 上传文件到远程仓库

基本步骤:

初始化库
将远程仓库克隆到本地
本地进行增加或者修改文件;
add,commit,push三步曲;

命令:

git init

初始化后会在当前文件夹下生成一个隐藏文件夹 .git

在这里插入图片描述
在这里插入图片描述
将远程仓库克隆到本地

git pull 仓库地址

或者用

git clone 仓库地址

在这里插入图片描述
本地进行增加或者修改文件;
add,commit,push三步曲

git add .
git commit -m '注释内容'
git remote add origin 仓库地址
git push -u origin 分支名

-u这个参数是指,将master分支的所有内容都提交,第一次关联之后后边你再提交就可以不用这个参数了,之后你的每一次修改,你就可以只将你修改push就好了

git push origin master

在这里插入图片描述
刷新仓库,可以看到文件已经被添加进仓库

在这里插入图片描述

注意:注意在使用命令行时,查看自己当前所在的分支,需要和要上传的分支保持一致
在这里插入图片描述

warning: LF will be replaced by CRLF

在这里插入图片描述
问题描述:windows平台下使用git add,git deploy 文件时经常出现“warning: LF will be replaced by CRLF” 的提示

  1. 发现问题
    windows平台下使用git add,git deploy 文件时经常出现“warning: LF will be replaced by CRLF” 的提示。

网上很多解决办法提到: 设置core.autocrlf=false,windows也用LF换行。 除了记事本,其他编辑器都可以正常编辑。
而没有给出具体原因和分析,现在加以补充。

  1. 分析问题
    格式化与多余的空白字符,特别是在跨平台情况下,有时候是一个令人发指的问题。由于编辑器的不同或者文件行尾的换行符在 Windows 下被替换了,一些细微的空格变化会不经意地混入提交,造成麻烦。虽然这是小问题,但它会极大地扰乱跨平台协作。
    其实,这是因为在文本处理中,CR(CarriageReturn),LF(LineFeed),CR/LF是不同操作系统上使用的换行符,具体如下:

换行符‘\n’和回车符‘\r’
回车符就是回到一行的开头,用符号r表示,十进制ASCII代码是13,十六进制代码为0x0D,回车(return);
换行符就是另起一行,用n符号表示,ASCII代码是10,十六制为0x0A, 换行(newline)。
所以我们平时编写文件的回车符应该确切来说叫做回车换行符。

应用情况 Dos和Windows平台: 使用回车(CR)和换行(LF)两个字符来结束一行,回车+换行(CR+LF),即“\r\n”; Mac
和 Linux平台:只使用换行(LF)一个字符来结束一行,即“\n”; 最早Mac每行结尾是回车CR 即’\r’,后mac os x
也投奔了 unix。 许多 Windows 上的编辑器会悄悄把行尾的换行(LF)字符转换成回车(CR)和换行(LF),或在用户按下
Enter 键时,插入回车(CR)和换行(LF)两个字符。

影响
一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;
而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。
Linux保存的文件在windows上用记事本看的话会出现黑点。
这些问题都可以通过一定方式进行转换统一,例如,在linux下,命令unix2dos 是把linux文件格式转换成windows文件格式,命令dos2unix 是把windows格式转换成linux文件格式。

  1. 解决问题:
    情况一
    Git 可以在你提交时自动地把回车(CR)和换行(LF)转换成换行(LF),而在检出代码时把换行(LF)转换成回车(CR)和换行(LF)。 你可以用git config --global core.autocrlf true 来打开此项功能。 如果是在 Windows 系统上,把它设置成 true,这样在检出代码时,换行会被转换成回车和换行:

    #提交时转换为LF,检出时转换为CRLF
    $ git config --global core.autocrlf true

情况二
如果使用以换行(LF)作为行结束符的 Linux 或 Mac,你不需要 Git 在检出文件时进行自动的转换。然而当一个以回车(CR)和换行(LF)作为行结束符的文件不小心被引入时,你肯定想让 Git 修正。 所以,你可以把 core.autocrlf 设置成 input 来告诉 Git 在提交时把回车和换行转换成换行,检出时不转换:(这样在 Windows 上的检出文件中会保留回车和换行,而在 Mac 和 Linux 上,以及版本库中会保留换行。)

#提交时转换为LF,检出时不转换
$ git config --global core.autocrlf input

情况三
如果你是 Windows 程序员,且正在开发仅运行在 Windows 上的项目,可以设置 false 取消此功能,把回车保留在版本库中:

#提交检出均不转换
$ git config --global core.autocrlf false

你也可以在文件提交时进行safecrlf检查

#拒绝提交包含混合换行符的文件
git config --global core.safecrlf true   

#允许提交包含混合换行符的文件
git config --global core.safecrlf false   

#提交包含混合换行符的文件时给出警告
git config --global core.safecrlf warn

通俗解释

  • git 的 Windows 客户端基本都会默认设置 core.autocrlf=true,设置core.autocrlf=true, 只要保持工作区都是纯 CRLF 文件,编辑器用 CRLF 换行,就不会出现警告了;
  • Linux 最好不要设置 core.autocrlf,因为这个配置算是为 Windows 平台定制;
  • Windows 上设置 core.autocrlf=false,仓库里也没有配置 .gitattributes,很容易引入 CRLF 或者混合换行符(Mixed Line Endings,一个文件里既有 LF 又有CRLF)到版本库,这样就可能产生各种奇怪的问题。

本节参考来源:

git错误 error: failed to push some refs to 'https://github.com/…

问题描述:在git bash中键入 $ git push origin master 进行提交的时候出现 如下错误:

error: failed to push some refs to 'https://github.com/bluetata/

在这里插入图片描述
问题原因:远程库与本地库不一致造成的,在hint中也有提示把远程库同步到本地库就可以了。

解决办法:使用命令行:

git pull --rebase origin master

该命令的意思是把远程库中的更新合并到(pull=fetch+merge)本地库中,–-rebase的作用是取消掉本地库中刚刚的commit,并把他们接到更新后的版本库之中。出现如下图执行pull执行成功后,可以成功执行git push origin master操作。

在这里插入图片描述
本节参考来源:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值