[omcr@lnlte2dmr-tdl legacy]$ cat -A ums_del_mr_files_cfg.ini
MrFileDiskMountPoint=/home^M$
MrFileDiskSpaceQuotaThresholdRatio=70^M$
MrFileReserveDayMin=7^M$
MrFileReserveDayMax=31^M$
MRF_Path=/home/mrftp/mrfile/dtmrfile^M$
MRE_Path=/home/mrftp/mrfile/MRE^M$
MRO_Path=/home/mrftp/mrfile/MRO^M$
MRS_Path=/home/mrftp/mrfile/MRS^M$
^M$
TDMRSWITCH=OFF^M$
TDMRORIGINALFILE=/home/mrftp/tdmrfile/backup^M$
TDMRFILE=/home/mrftp/tdmr/download^M$
TDMRNORTHFILE=/home/mrftp/tdmr/mrfile^M$

  在Linux下可以是用“cat –A filename” 来查看某个文件中的隐含字符,UNIX格式的话,每行结尾是 “$”符号,而DOS格式则是 “^M”符号。

这个 “^M”是怎么来的,为啥.sh脚本文件就没有?

solaris修改后的*.ini文件,换行符变成了dos模式。

为啥嘞?

是从solaris传输到windows时,ftp采用自动模式传输,实际上ftp采用ascii模式传输,结果传输的ini文件被改写了,

这个现象是使用flashfxp从solaris下载到windows才发生的,从windows上传到solaris没有这种情况,linux与windows互传也没有这种情况。

得好好研究一下ftp的ascii模式和binary模式。

ASCII模式
复制时候会进行调整,主要体现为对不同操作系统的回车/换行/结束符等进行转译。
比如,回车符号在Unix下是\n(0A),Windows下是\r\n(0D0A),Mac下是\r(0D)。当在一个Windows操作系统上用 ASCII方式从Unix服务器上下载文件时——无论是文本文件还是二进制文件——都会进行检测和转换:每检测到一个0A,则认为是回车符号,自动插入 0D形成Windows下的回车符。显然,如果下载的是文本文件,这种转换是很有用的——我们能在Windows下看到分行后的文本,否则我们看到的是中间夹杂着小黑方块的不换行的一堆文字;然而如果下载的是二进制文件(比如exe或rar),这种转换无异于画蛇添足,破坏了整个文件。(PS:我的FlashFXP设置的是默认,估计就是按文件的特征信息来判断是文本还是二进制,但它向linux传却用了windows的newLine符,可能是个bug吧)

-------------------------------------------------------------以下是我总结的一点儿经验------------------------------------------------------------------------------------------

从linux下载ini文本文件到windows,或从windows上传到ini文本文件linux,尽管我设置为ascii模式,但最终传输还是使用binary模式。

但windows与solaris之间传输ini文本文件时ascii模式是起作用的,不论是从windows上传到solaris,还是从solairs下载到windows:

我把一个unix格式的ini文件也通过ascii模式从windows上传到solaris,flashfxp的消息窗口还有warning警告,提示发现13出换行符有误。

如果把.ini后缀名换为.sh,则自动模式下,flashfxp采用binary模式从solaris下载到windows。看来如果让flashfxp自动判断,flashfxp不把.sh当成文件文件。

如果把传输模式设定为ascii,则从solaris下载到windows的.sh文件也会被修改换行符。

最终结论,从windows上传到solaris用自动传输模式应该是没有问题的,前提是上传的文件原来的格式是正确的。比如.sh文件上传前就应该使用UNIX换行符。

当然用ascii传输模式上传script脚本,如.sql文件,也可以二次检验一下是否使用UNIX换行符,传输过程中把发现的windows换行符都改成UNIX换行符。

但是,如果传输.jar包之类的程序文件,千万不能用ascii模式。用自动模式也行,binary模式也行,因为flashfxp的自动模式会判断传输文件的后缀是不是文本文件类型,jar包不算文本类型,所以实际传输时还是binary模式。

要是不想麻烦,就用自动模式,让程序去判断哪些是文本文件,哪些不是文本文件。

如果你明白了这个道理,就可以选定传输模式。

-------------------------------------------------------------以上是我总结的一点儿经验-----------------------------------------------------------------------------------

因此,如果服务器和客户端的OS不相同,对于ASCII文件(文本文件)采用ASCII模式下载,对于非文本文件采用BINARY模式下载;如果两端OS相同,两种方式具有同样效果。

如何解决:
有些经常游走在两个OS之间的人员采取的习惯做法是:将在Windows下编辑的文件转换成Unix模式,而FTP默认用BINARY模式传输。(PS:最终我也选择这种模式,好处两点,1newLine符我控制,清晰;2不用ascii方式的转换,速度也快)。

FTP的两种传输模式:BINARY和ASCII

http://blog.chinaunix.net/uid-20546486-id-4256823.html

Linux上如何进行换行符转换

https://wdp107.iteye.com/blog/892133

文件

ini文件多了个dos的^M结尾符号,导致linux下脚本程序不能运行的更多相关文章

  1. 【java】 linux下利用nohup后台运行jar文件包程序

    Linux 运行jar包命令如下: 方式一: java -jar XXX.jar 特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 方式二 ...

  2. 位图文件(BMP)格式以及Linux下C程序实现(转)

    源:位图文件(BMP)格式以及Linux下C程序实现 说到图片,位图(Bitmap)当然是最简单的,它是Windows显示图片的基本格式,其文件扩展名为*.BMP.由于没有经过任何的压缩,故BMP图 ...

  3. Linux下脚本文件第一行的作用

    Linux下脚本文件第一行的作用 在Linux/Unix系统中,你可以在脚本hello.py顶部添加以下命令让Python脚本可以像SHELL脚本一样可直接执行: #! /usr/bin/env py ...

  4. windows下建立文件的换行符^M导致linux下的shell脚本执行错误的解决方式

    常常在windows下编辑的文件远程传送到linux下的时候每行末尾都会出现^M.这将导致shell脚本执行错误,主要是由于dos下的编辑器和linux下的编辑器对文件末行的回车符处理不一致导致. 主 ...

  5. Linux下修改默认字符集--->解决Linux下Java程序种中文文件夹file.isDirectory()判断失败的问题

    一.问题描述: 一个项目中为了生成树状目录,调用了file.listFiles()方法,然后利用file.isDirectory()方法判断是否为目录,该程序在windows下运行无问题,在Linux ...

  6. linux 下启动程序的时候会显示坏的解释器,或者没有那个文件

    又一次开发的时候在windowns上编写完的程序放到linux下运行的时候,比如:./start.sh的时候显示:"坏的解释器,没有那个文件"错误, 原因是windowns下写的s ...

  7. linux下利用nohup后台运行jar文件包程序

    Linux 运行jar包命令如下: 方式一: java -jar XXX.jar 特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 方式二 ...

  8. Linux下中断程序导致写文件失败的分析

    案例: 一个普通linux C程序,执行期间会进行多次printf操作,利用bash脚本重定向功能,将stdout重定向到一个另一个文件中去.在运行途中用ctrl+C终止程序,发现定向文件始终为空,即 ...

  9. openwrt 下python程序后台运行,并将打印信息保存文件

    python -u gw20191223.py  > test.log 1 2 & "python" 表示执行python代码 "-u" 表示不启 ...

随机推荐

  1. 折腾ELK+kafka+zk

    回顾前大半年: 1.kubespray搭建K8S集群 2.openVPN 搭建 3.helm使用 4.aws EKS 搭建维护 5.Jenkins pipline 编写ci/cd流程 6.蓝鲸,jum ...

  2. Android IdleHandler 原理浅析

    IdleHandler:空闲监听器(就像我没事做了,在群里发了个表情,这时候其他人就知道我很闲了) 在每次next获取消息进行处理时,发现没有可以处理的消息(队列空,只有延时消息并且没到时间,同步阻塞 ...

  3. 浏览器访问ipv6站点(未绑定主机的ipv6站点)

    我们在浏览器直接输入ipv6地址敲回车,一般情况下浏览器会跳转到搜索引擎进行搜索. 我们需要在浏览器器中输入: http://[::1]  或者 [::1]

  4. P1141 01迷宫(连通块模板)

    题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任务是:对于给定的迷宫, ...

  5. 《React+Redux前端开发实战》笔记3:基于Webpack构建的Hello World案例(下)

    2.使用React编码 下面正式开始使用React来编写前端代码. (1)npm安装react和react-dom: npm install react react-dom -S (2)用下面代码替换 ...

  6. CentOS安装Netdata进行系统监控

    偶然间在知乎看到了Netdata这个东西 看到它华丽的界面 顿时心动 gkd gkd #准备 yum install autoconf automake curl gcc git libmnl-dev ...

  7. CM金丝雀Canary报错

    参考: https://www.cnblogs.com/barneywill/p/10400788.html CM金丝雀Canary报错 1 HDFS 金丝雀Canary 测试无法为 /tmp/.cl ...

  8. TCP listener

    调试时未关闭之前开启的TCP SERVER: 应该关闭: TcpListener TcpClient 1.开启TCP listener (1)Start()方法失败 异常位置:该异常的产生位置为 tc ...

  9. 【6.12校内test】T2 子集

    这道题大概是这三道题里最简单的啦 但这阻止不了我废的脚步 [问题描述] 对于 n=4 时,对应的集合 s={4,3,2,1},他的非空子集有 15 个依次如下: {1} {2} {1,2} {3} { ...

  10. Magento开发基础知识之RequireJs

    一.RequireJS概述 RequireJS是一个工具库,主要用于客户端的模块管理.实现异步或动态加载,从而提高代码的性能和可维护性. RequireJS的基本思想是,通过define方法,将代码定 ...