日前Linux官方内置Bash中新发现一个非常严重安全漏洞(漏洞参考https://access.redhat.com/security/cve/CVE-2014-6271  ),黑客可以利用该Bash漏洞完全控制目标系统并发起攻击,为了避免您Linux服务器受影响,建议您尽快完成漏洞修补,修复方法如下:

 

【已确认被成功利用的软件及系统  

所有安装GNU bash 版本小于或者等于4.3的Linux操作系统。  

 

【漏洞描述】  

该漏洞源于你调用的bash shell之前创建的特殊的环境变量,这些变量可以包含代码,同时会被bash执行。  

 

【漏洞检测方法】  

可以使用如下命令来检查系统存在此漏洞:  

env x='() { :;}; echo vulnerable' bash -c "echo this is a test"   

 

修复前 

输出:    

vulnerable   

this is a test    

 

使用修补方案修复后 

bash: warning: x: ignoring function definition attempt 

bash: error importing function definition for `x' 

this is a test 

特别提示:该修复不会有任何影响,如果您的脚本使用以上方式定义环境变量,修复后您的脚本执行会报错。 

 

【建议修补方案 】  

请您根据Linux版本选择您需要修复的命令, 为了防止意外情况发生,建议您执行命令前先对Linux服务器系统盘打个快照,如果万一出现升级影响您服务器使用情况,可以通过回滚系统盘快照解决。  

 

CentOS: 

yum -y update bash 

 

Ubuntu管理员权限安装更新: 

14.04 64bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.3-7ubuntu1.1_amd64.deb && sudo  dpkg -i bash_4.3-7ubuntu1.1_amd64.deb 

 

14.04 32bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.3-7ubuntu1.1_i386.deb && sudo dpkg -i  bash_4.3-7ubuntu1.1_i386.deb 

 

12.04 64bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.2-2ubuntu2.2_amd64.deb && dpkg -i  bash_4.2-2ubuntu2.2_amd64.deb 

 

12.04 32bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.2-2ubuntu2.2_i386.deb && dpkg -i  bash_4.2-2ubuntu2.2_i386.deb 

 

10.10 64bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.1-2ubuntu3.1_amd64.deb && dpkg -i bash_4.1-2ubuntu3.1_amd64.deb 

 

10.10 32bit 

wget http://mirrors.aliyun.com/fix_stuff/bash_4.1-2ubuntu3.1_i386.deb && dpkg -i bash_4.1-2ubuntu3.1_i386.deb 

 

Debian: 

7.5 64bit && 32bit 

apt-get -y install --only-upgrade bash 

 

6.0.x 64bit 

wget http://mirrors.aliyun.com/debian/pool/main/b/bash/bash_4.1-3%2bdeb6u1_amd64.deb &&  dpkg -i bash_4.1-3+deb6u1_amd64.deb 

 

6.0.x 32bit 

wget http://mirrors.aliyun.com/debian/pool/main/b/bash/bash_4.1-3%2bdeb6u1_i386.deb &&  dpkg -i bash_4.1-3+deb6u1_i386.deb 

 

OpenSuse: 

13.1 64bit 

wget http://mirrors.aliyun.com/fix_stuff/bash-4.2-68.4.1.x86_64.rpm && rpm -Uvh bash-4.2-68.4.1.x86_64.rpm 

 

13.1 32bit 

wget http://mirrors.aliyun.com/fix_stuff/bash-4.2-68.4.1.i586.rpm && rpm -Uvh bash-4.2-68.4.1.i586.rpm 

 

Aliyun Linux: 

5.x 64bit 

wget http://mirrors.aliyun.com/centos/5/updates/x86_64/RPMS/bash-3.2-33.el5.1.x86_64.rpm && rpm -Uvh bash-3.2-33.el5.1.x86_64.rpm 

 

5.x 32bit 

wget http://mirrors.aliyun.com/centos/5/updates/i386/RPMS/bash-3.2-33.el5.1.i386.rpm && rpm -Uvh bash-3.2-33.el5.1.i386.rpm 

 

RedHat 红帽系可通过更新 bash 并重启系统来解决这个问题:  

# yum update bash   

或者:  

# yum update bash-4.1.2-15.el6_5.1   

此举只是更新了 bash 包,还需要重启系统才能生效。

 

Ubuntu 用户可以通过如下命令打补丁,无需重启:  

apt-get update   

apt-get install bash

 

RedHat/CentOS 修复后查看版本:

[root@localhost]# which bash
/bin/bash
[root@localhost]# /bin/bash --version
GNU bash, version 4.1.2(1)-release (x86_64-redhat-linux-gnu)
Copyright (C) 2009 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>

This is free software; you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.

[root@localhost ]# rpm -q bash
bash-4.1.2-15.el6_5.1.x86_64