zoukankan      html  css  js  c++  java
  • k8s-nginx二进制报Illegal instruction (core dumped)

    1.环境

    系统:CentOS 7.3

    内核:x86

    环境:虚拟机

    2.问题

    收到一个现场问题,k8s环境中nginx的pod都启动异常。

    #kubectl get pod |grep nginx
    nginx-7945cf468c-z7z9r            0/1     Running     0          10m17m
    

    看pod日志无任何有效信息,于是进入nginx的pod,执行nginx二进制,报错Illegal instruction (core dumped)

    ~# kubectl exec -ti nginx-7945cf468c-z7z9r bash
    bash-4.4# /usr/local/openresty/nginx/sbin/nginx -h
    Illegal instruction (core dumped)
    

     3.猜想及答案

    针对上述问题于是产生如下猜想:

    1.镜像损坏
    
    2.系统安装了安全软件
    
    3.系统做过内核或参数升级

    判断问题1:镜像损坏,于是找到nginx pod编译前的nginx base镜像,直接docker run启动后执行nginx二进制,问题相同;
    判断问题2:根据一番了解,现场环境之前装过三合一,和瑞星杀毒,但都已经关闭,没有相关进程;
    判断问题3:了解到现场环境未做内核升级及修改系统参数。

     在一番思考和查到后得到下面这句话:

     

     于是用如下命令查了一下cpu指令集

    #grep -q sse4_2 /proc/cpuinfo && echo “SSE 4.2 supported” || echo “SSE 4.2 not supported”
    SSE 4.2 not supportedj

    竟然CPU不支持SSE 4.2指令集。查看正常运行的环境是支持的

    # grep -q sse4_2 /proc/cpuinfo && echo “SSE 4.2 supported” || echo “SSE 4.2 not supported”
    “SSE 4.2 supported”

    于是咨询现场是否迁移过虚拟机,果然迁移过。

    于是再找到支持SSE 4.2指令集的物理机进行迁移后,环境恢复,nginx正常启动,问题得到解决。

    参考文档:https://github.com/openresty/docker-openresty/issues/49

  • 相关阅读:
    IT名词备忘录——汇编
    逆转链表的实现
    编写安全的代码的一些技巧
    extern c 谈
    回调函数
    职场必备八个黄金句型
    CString类的用法介绍和自己动手写的CString类
    61条面向对象设计的经验原则(转贴)
    sprintf的用法
    VisualStudioVS2010统计代码行数
  • 原文地址:https://www.cnblogs.com/yaohong/p/14920425.html
Copyright © 2011-2022 走看看