背景
能源产品线的单元测试需要root权限,在统一开发服务器中,只能使用docker进行部分高权限单元测试的运行和调试开发。
问题
docker里运行gdb,打了断点,却无法进入断点。
原因
docker为了保证主机安全,docker开了很多安全设置,其中包括ASLR(Address space layout randomization),即docker里的内存地址和主机内存地址是不一样的。
ASLR会导致GDB这种依赖地址的程序无法正常运作。
解决方法
使用docker的超级权限,加入–privileged
如:
docker run –privileged ……
GDB即可正常运作。
超级权限会关闭很多安全设置,可以更充分的使用docker能力。
例如,docker里再开docker都可以了。