首页 > 技术文章 > 关于报错“syntax error near unexpected token `”和回车换行

youngt 2014-05-07 12:39 原文

本来是很简单一个事情,转过来是因为打字机这事比较有趣……

http://blog.csdn.net/xyp84/archive/2009/08/11/4435899.aspx

 

摘要一下:

 

 

回车

换行

0D

0A

<CR>

<LF>

Carriage Return

Line Feed

 

 

 

 

“/r”

“/n”

win32

0D

0D 0A

unix

0D

0A

 

 

============淡定的分割线===============

 

今天写了个shell脚本,在自己机器上运行正常,给同事,运行报错syntax error near unexpected token `,左看右看shell脚本没有问题,没有办法google搜索,发现一位仁兄讲的挺好,内容如下:

      用命令vi -b 打开你的SHELL脚本文件,你会。发现每行脚本最后多了个^M。

  那么接下来就要搞清楚这个^M是什么东东?

  long long ago.....  老式的电传打字机使用两个字符来另起新行。一个字符把滑动架移回首位 (称为回车,<CR>,ASCII码为0D),另一个字符把纸上移一行 (称为换行, <LF>,ASCII码为0A)。当计算机问世以后,存储器曾经非常昂贵。有些人就认定没必要用两个字符来表示行尾。UNIX 开发者决定他们可以用 一个字符来表示行尾,Linux沿袭Unix,也是<LF>。Apple 开发者规定了用<CR>。开发 MS-DOS以及Windows 的那些家伙则决定沿用老式的<CR><LF>。

  因为MS-DOS及Windows是回车+换行来表示换行,因此在Linux下用Vim查看在Windows下用VC写的代码,行尾后的“^M”符号,表示的是符。

  在Vim中解决这个问题,很简单,在Vim中利用替换功能就可以将“^M”都干掉,键入如下替换命令行:

  1)vi -b setup.sh

  2)在命令编辑行<就是: 按ESC键 然后shift+:冒号>输入:%s/^M//g

  注意:上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的。

  这样替换掉以后,保存就可以执行了。当然还有其他的替换方式比如:

  a.一些linux版本有 dos2unix 程序,可以用来祛除^M。

  b.cat filename1 | tr -d "/r" > newfile 去掉^M生成一个新文件,还有sed命令等,凡是可以替换的命令都是可以用来新生成一个文件的。

      按照上面所说的,删除^Mshell脚本就运行正常,后来问同事,原来他windows记事本中修改了程序路径,导致每一行多出了^M。

 

http://blog.csdn.net/windless0530/article/details/6077654

 

 先说点常识问题:

因为MS-DOS及Windows是回车+换行来表示换行,因此在Linux下用Vim查看在Windows下用VC写的代码,行尾后的“^M”符号,表示的是符。
现在,你使用vim -b 打开你的文件。就会发现每一行都有^M ,那么我们可以是用全局替换替换掉

................解决方法

        在命令编辑行<就是: 按ESC键 然后shift+:冒号>输入:%s/^M//g

     注意:上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的。 

MyISAM中确实很容易就会发生Lock一大片的情况,主要是某些情况下某个表的耗时Select语句,阻塞了Insert语句,然后Insert语句就锁住了这个表,让其他的Select语句无法执行。

简单的说就是耗时的Select语句,参杂了一些Insert语句,导致大面积Select被Lock,演变成了串行执行。

参数如下:

concurrent_insert  通过查看 show variables like '%concurrent%'

0: 表示不能并发,Select, insert之间只能串行执行

1:表中有空洞(删除记录留下的)情况下,阻塞insert; 表中无空洞的情况下,Insert并发插入表尾

2:无论是否有空洞都并发插入表尾

默认情况下, 这个值是1, 所以在既有Select又有insert的情况下,很容易就出现了近似串行的执行场景。


解决方法:

1.  concurrent_insert=2  坏处就是delete的空洞永远都不去补回来了,浪费空间,浪费了cpu扫描

2.  --low-priority-updates启用mysqld,让select有更高优先级

3.  在语句中加上HIGH_PRIORITY, LOW_PRIORITY以定义优先级,让select赶在insert锁定之前执行

 

http://hi.baidu.com/dmkj2008/item/0b58d20c228a9f8e03ce1b46

推荐阅读