背景:需要使用arthas的火焰图查看程序的运行情况,arthas其他功能可正常使用,但是输入profiler start
后报错。
环境:程序是由alpine镜像构建的,基于jdk8。docker采用swarm模式搭建的集群。
问题:
libstdc++.so.6: cannot open shared object file
No access to perf events. Try --fdtransfer or --all-user option or \'sysctl kernel.perf_event_paranoid=1\'
解决:
- 构建镜像时 Dockerfile中加入
RUN apk add libstdc++
即可解决 - 分步解决
2.1 docker容器一般使用宿主机的kernel参数,将宿主机的perf_event_paranoid
设置为1后,在容器中查看对应参数已经变为1了,但还是无法启动。
2.2 经过一系列搜索看到在docker run
时可以添加--cap-add SYS_ADMIN
,尝试后可正常使用。
2.3 查看docker文档,修改部署yaml后,再次部署发现不支持cap_add
参数。使用相同的配置用docker-compose就可以启动,并可以使用profiler
。
2.4 再次一系列查询,发现在swarm环境下cap-add
有bug,在20.10
版本之前去除了,将本机docker升级一下就可以正常使用。
总结:现在应该没有使用docker swarm
的地方了,仅前面两步解决还是很简单的,在k8s
环境下也很好设置。主要是后面的解决步骤,在此记录。