[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. 如何手写实现简易的Dubbo[z]

    [z]https://juejin.im/post/5ccf8dec6fb9a0321c45ebb5 前言 结束了集群容错和服务发布原理这两个小专题之后,有朋友问我服务引用什么时候开始,本篇为服务引用 ...

  2. Ubuntu:Unable to locate package ***

    在Ubuntu 上使用apt-get 安装包时遇到  Unable to locate package 的信息 解决方案: 更细apt-get然后重新安装 #sudo apt-get update   ...

  3. [ubuntu]如何实现双屏显示

    一.首先直接运行xrandr命令,查看设备的相关信息: 运行之后会显示当前连接设备的屏幕信息,如下图 PS:我已经用HDMI线连接了外接显示器和主机 wangju@wangju-HP--G4:~$ x ...

  4. python接口测试之mock(三)

    前面介绍了moco的详细的使用,它主要是基于moco-runner-0.11.0-standalone.jar,通过编写json的文件来实现,mock翻译过来就是模拟的意思,也就是说,它是将测试对象所 ...

  5. robotframework 配置过程中遇到的问题

    现有环境配置:操作系统: Win7 32bitPython 2.7.8Python 3.5.2Pycharm Community Edition 2016.3.2robotframework: 3.0 ...

  6. 进程管理工具之supervisor[安装并使用]

    在Linux服务器中,有时候我们需要一个进程需要可靠的在后台运行,并且能够监控进程状态,在意外结束时能够自动重启等.此时就可以使用supervisor. supervisor 是使用Python开发的 ...

  7. MySQL MGR 5.7.22 on centos 6.3 单主/多主搭建测试

    搭建Mysql Group Replication本次搭建采用3个实例,三个服务器,同一个网段,MGR的参数配置在配置文件中添加.注意通讯端口号的配置,它用于组成员之间的通讯使用请确定当前MySQL版 ...

  8. 应用安全 - Java - 插件 - IO - excel-streaming-reader - 漏洞汇总

    xlsx-streamer.jar的XXE漏洞 Date 类型XXE 影响范围 xlsx-streamer.jar-2.0.0及以下版本 复现

  9. 【神经网络与深度学习】卷积神经网络-进化史:从LeNet到AlexNet

    [卷积神经网络-进化史]从LeNet到AlexNet 本博客是[卷积神经网络-进化史]的第一部分<从LeNet到AlexNet> 如需转载,请附上本文链接:http://blog.csdn ...

  10. 快速生成500W测试数据库

    快速生成500W测试数据库: 创建测试表: DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` int(10) NOT NULL AUTO_ ...