本来是很简单一个事情,转过来是因为打字机这事比较有趣……
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锁定之前执行