linux疑难问题排查实战专栏,分享了作为公司专家,在解决内存、性能、各类死机等疑难问题的排查经验,认真学习可以让你在日后工作中大放光彩。
在glibc的文档中明确表明,多线程程序中修改环境变量是不被允许的,多线程同时调用setenv、getenv会出现偶现死机,本文就给大家介绍一下,出现这种死机的一个现象,以及为什么是多线程不安全,为什么setenv、getenv多线程调用会导致死机。
部分读者可能不关注详细分析过程,这里直接说明一下结论:setenv接口在设置环境变量时,可能会调用realloc来扩充存储环境变量的内存,由于realloc实现机制,realloc返回的地址有可能和我们传入待扩容的地址是不一样的;因为没有多线程异步保护,getenv访问到realloc已经释放的内存,导致死机。一般死机出现在getenv中则大概率是该原因导致的。总之程序运行之后,禁止再去修改环境变量,可能导致死机。