server2008之后的系统默认开启了ecn的功能,导致内网客户端连接外网的服务器建立连接的过程要10几秒,无法忍受。
cmd控制台输入netsh命令即可禁用该功能:netsh interface tcp set global ecn=disabled
不可能让用户自己去输入该命令,因此很正常的逻辑,把这个命令写在安装包中,软件安装时调用该命令禁用该功能。
做法:软件安装包用的nsis,将该命令(netsh interface tcp set global ecn=disabled)写到一个批处理文件“DisableECN.bat”中,nsis的脚本中调用:nsExec::exec '"DisableECN.bat">DisableECN.log'。
问题来了:log文件中一直输出的是Set global command failed on IPv4 The parameter is incorrect。
中文是:在IPv4上设置global命令失败参数错误
明显参数没有错误,cmd控制台执行的好好的,到安装包里就不行。头疼。
偶然间发现在安装包执行时,任务管理器中netsh执行的是32位的netsh.exe(映像路径名称为:C:\Windows\SysWOW64\netsh.exe)。我去,终于发现问题所在。nsis生成的是32位的安装包,默认执行的是32位的netsh.exe
尝试解决1:netsh.exe加上路径名称。nsExec::exec '"C:\Windows\System32\netsh" interface tcp set global ecn=disabled' 仍然设置不成功,发现加上了路径在执行的时候仍然重定向到32位的netsh。
啊郁闷了,网上找资料。终于找到一个有用的信息,禁止nsis重定向
最终解决:
System::Call "Kernel32::Wow64EnableWow64FsRedirection(i 0)"
nsExec::exec '"C:\Windows\System32\netsh" interface tcp set global ecn=disabled'
System::Call "Kernel32::Wow64EnableWow64FsRedirection(i 1)"
安装包运行后,ecn被关闭。解决完成