【已确认被成功利用的软件及系统】
所有安装GNU bash 版本小于或者等于4.3的Linux操作系统。
【漏洞描述】
该漏洞源于你调用的bash shell之前创建的特殊的环境变量,这些变量可以包含代码,同时会被bash执行。
【漏洞检测方法】
执行shell脚本: env x='() { :;}; echo vulnerable' bash -c "echo this is a test"
如果输出:
vulnerable this is a test
说明你的系统存在漏洞
特别提示:该修复不会有任何影响,如果您的脚本使用以上方式定义环境变量,修复后您的脚本执行会报错。
【建议修补方案 】
请您根据Linux版本选择您需要修复的命令, 为了防止意外情况发生,建议您执行命令前先对Linux服务器系统盘打个快照,如果万一出现升级影响您服务器使用情况,可以通过回滚系统盘快照解决。
centos:
yum clean all yum -y update bash
ubuntu:
apt-get update apt-get install bash
使用修补方案修复后 ,输出内容如下:
bash: warning: x: ignoring function definition attempt bash: error importing function definition for `x' this is a test
原文链接:http://outofmemory.cn/shell/fix-linux-bash-leak