直接使用 Arthas 的命令行交互方式,不能满足金融级运维要求,在落地使用上存在哪些实际的问题?

直接使用 Arthas 的命令行交互方式,不能满足金融级运维要求,在落地使用上存在哪些实际的问题?

展开
收起
vncamyi27xznk 2021-12-15 10:36:32 356 分享 版权
1 条回答
写回答
取消 提交回答
  • 1.信息安全问题:Arthas 可以通过命令行方式,直接观测方法的入参、返回值,这就涉及到一些客户敏感信息,直接在生产环境使用命令行操作显然是不合适的。 2.学习成本问题:工具的安装使用存在一定的学习成本,尤其是对于新员工来说。 3.多人协作问题:当多个开发者对同一个目标进程进行诊断时,可能存在冲突,例如,一个同学正在watch 某个方法,另一个同学把这个方法redefine 了,那么第一个同学 watch 到的其实是别人替换后的代码的运行情况,这就像一个多线程访问共享资源的线程安全问题。再比如两个同学都在 at tach 同一个进程,一个同学用完了,直接把 Arthas 进程 shutdown(关闭),而另一个还在使用的同学就突然不能用了。 4.资源占用问题:如果开发者忘记关闭 Arthas,Arthas 进程会占用一定的系统资源(如内存、CPU)。当然,Arthas 本身对资源开销是有很多考虑的,比如 Arthas 使用自定义的类加载器加载自身的类,在关闭时将引用置空,这样在下一次垃圾回收的时候,自定义类加载器加载的类就会被回收,从而避免对原有工程的影响。因此,我们认为 Arthas 应该在排查问题时使用,而不应该当作常规监控工具一直运行。 5.环境不统一问题:在不同的 Java 虚拟机实现安装和使用 Arthas,可能会碰到一些奇怪的问题,比 如用 Hotspot 虚拟机运行 Arthas 进程,而目标虚拟机是 J9 实现,attach 的时候可能会出错。 另一方面,生产环境云上、云下节点规模庞大,网络访问权限是严格控制的,开发人员想远程连接目标进程,涉及到权限开通、版本管理、安装程序下发等问题。

    答复内容摘自《云原生技术与架构实践年货小红书》,这本电子书收录开发者藏经阁 下载连接:https://developer.aliyun.com/topic/download?id=1127

    2021-12-15 16:07:15
    赞同 展开评论

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

收录在圈子:
+ 订阅
阿里云 云原生应用平台 肩负阿里巴巴集团基础设施云化以及核心技术互联网化的重要职责,致力于打造稳定、标准、先进的云原生产品,成为云原生时代的引领者,推动行业全面想云原生的技术升级,成为阿里云新增长引擎。商业化产品包括容器、云原生中间件、函数计算等。
还有其他疑问?
咨询AI助理