背景
今天用公司自动化编译流水线git拉取代码时,发现脚本执行都失败了,但是手动拉取的代码是正常的,对比两份脚本发现内容虽然一致,但是十六进制对比下,流水线拉取的脚本换行符为"0x0A",手动拉取的换行符为"0x0A,0x0D"导致windows在执行bat脚本的时候忽略了换行。
解决
网上查询资料发现git配置core.autocrlf会有相关的影响,果然在流水线配置上有这个设置,把这个设置成true,拉取下来的脚本就能正常执行了,由于本机已有默认的core.autocrlf配置,所以手动拉取的脚本是正常的。
原理
假如你正在 Windows 上写程序,而你的同伴用的是其他系统(或相反),你可能会遇到 CRLF 问题。 这是因为 Windows 使用回车(CR)和换行(LF)两个字符来结束一行,而 macOS 和 Linux 只使用换行(LF)一个字符。 虽然这是小问题,但它会极大地扰乱跨平台协作。许多 Windows 上的编辑器会悄悄把行尾的换行字符转换成回车和换行, 或在用户按下 Enter 键时,插入回车和换行两个字符。
// 提交时转换为LF,拉取时转换为CRLF
git config --global core.autocrlf true
// 提交时转换为LF,拉取时不转换
git config --global core.autocrlf input
// 不转换
git config --global core.autocrlf false
|