Strace跟踪解决expect乱码问题

--Strace跟踪解决expect乱码问题

----------------------------------2014/07/27

情景:需要在本机抓去另外一台远程数据库中的数据。

执行语句:./ersh.exp "export LANG=en_US.UTF-8;mysql -uroot  -S /tmp/mysql_3306.sock -ss  cdb2 -e \"set names utf8; select '外部-SNG-上海松江',pair_id,concat(tvs_vip,':',tvs_vport),instance_name,app_name from tb_mysql_pair where sync_status=1 and tvs_vport<>0 and status=3;\""  10.237.152.19

输出结果:

复制代码
spawn ssh -p36000 10.237.152.19 -lroot -q
root's password: 
Last login: Sun Jul 27 19:31:18 2014 from 10.181.225.39
Welcome to tlinux 1.2 64bit
Version 1.2 20130715 
[root@TENCENT64 ~]# export LANG=en_US.UTF-8;mysql -uroot -S /tmp/mysql_3306.sock -ss cdb2 -e "set names utf8; select '??-SNG-????',pair_id,concat(tvs_vip,':',tvs_vport),instance_name,app_name from tb_mysql_pair where sync_status=1 and tvs_vport<>0 and status=3;" 
??-SNG-???? 26061 10.236.158.100:3951 宅计划 1251002789
[root@TENCENT64 ~]# sleep 1 
exit
[root@TENCENT64 ~]# exit
logout
复制代码

 

可见这句话在传过去的时候就是乱码了,不是返回时的乱码。

使用strace跟踪脚本的执行,发现如下编码相关语句:

open("/usr/lib/locale/en_US/LC_CTYPE", O_RDONLY) = 3

查看本机locale:

复制代码
# locale
LANG=en_US.UTF-8
LC_CTYPE=en_US
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=
复制代码

 

猜测是LC_CTYPE的设定问题引起此语句传输到其他机器时发生乱码,将LC_CTYPE设置成en_US.UTF-8,问题解决。

复制代码
./ersh.exp "export LANG=en_US.UTF-8;mysql -uroot -S /tmp/mysql_3306.sock -ss cdb2 -e \"set names utf8; select '外部-SNG-上海松江',pair_id,concat(tvs_vip,':',tvs_vport),instance_name,app_name from tb_mysql_pair where sync_status=1 and tvs_vport<>0 and status=3;\"" 10.237.152.19
spawn ssh -p36000 10.237.152.19 -lroot -q
root's password: 
Last login: Sun Jul 27 19:26:49 2014 from 10.181.225.39
Welcome to tlinux 1.2 64bit
Version 1.2 20130715 
at(tvs_vip,':',tvs_vport),instance_name,app_name from tb_mysql_pair where sync_status=1 and tvs_vport<>0 and status=3;" 外部-SNG-上海松江',pair_id,conc 
外部-SNG-上海松江 26061 10.236.158.100:3951 宅计划 1251002789
[root@TENCENT64 ~]# sleep 1 
exit
[root@TENCENT64 ~]# exit
logout
复制代码

 

posted @   胡.杰  阅读(1415)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
历史上的今天:
2013-07-27 DB2的日志理解难点
点击右上角即可分享
微信分享提示