marathon小知识点分享之如何远程调试marathon

简介:

目的,在centos服务器上启动marathon服务后,可以在window上使用intellij idea进行远程调试;

主要环境:

1、本人是参考https://mesosphere.github.io/marathon/docs/提供的方式,部署的marathon服务;

2、https://github.com/mesosphere/marathondown下的marathon源码

  1. 如果不想修改源码的话,将marathon的源码down下来后,直接导入到intellijidea里,就可以

  2. 如果想修改源码后,再进行远程调试的话,那么需要对marathon源码进行重新编译,打包成jar包后,替换服务器上的/marathon根目录/target/scala-2.11下的源码包;这样的话,保证本地调试的源码与服务器上运行的源码是一致。

 

  • marathon的远程调试与spark的远程调试有什么区别?

    个人感觉,主要一方面的区别:

    在去年年底研究过spark的远程调试,需要在spark-class脚本里添加jvm参数,如:

声明JAVA_OPTS

wKioL1mVlTryjuqpAAH93VV4wwY154.png-wh_50

Marathon这一点做的比较好,不需要添加,

无论你是从git上直接down的源码,还是通过https://mesosphere.github.io/marathon/下载部署包

在启动脚本bin/start里都提供了调试参数,如下图所示:

wKioL1mVk9iwHjxtAABou7WmmIM708.png-wh_50

不过,如果要实现远程调试的话,需要将上面参数suspend=n的值,由n改成y, 不然的话,远程调试不起作用。

具体步骤:

1、修改启动脚本start

wKioL1mVlGWRQ-jAAADHsrgHmEQ698.png-wh_50

2、更新启动marathon服务的命令,改成调试模式

启动脚本start

wKioL1mVklyg7t9gAAChADXVOLQ286.png-wh_50

因此,将marathon的启动服务的命令,改成下面的形式

/usr/local/marathon/bin/start --jvm-debug 9999 --master zk://master001:2181,master002:2181,master003:2181/mesos--zk zk://master001:2181,master002:2181,master003:2181/marathon--framework_name marathon --mesos_user root --mesos_role marathon_role--mesos_authentication_principal marathon_user

 

3、intellij idea 中,将启动marathon的方式,改成远程调试模式

wKiom1mVkl-zo4A-AAIiBX5GTV8808.png-wh_50

 

4、在服务器上,启动marathon服务,

wKioL1mVkmCTgLgAAAJ3zGoN_tU999.png-wh_50

5、window上,打断点,并启动debug

wKiom1mVkmaxWvV3AACdJq-Kn6M807.png-wh_50

 wKiom1mVkmmztuC3AAOdu2oaId0539.png-wh_50

6、开始debug远程调试

wKioL1mVkmmi1fWcAAHov9bTa8I157.png-wh_50


查看服务器上,是否打印出了日志

 wKioL1mVkmyzbf05AAJv0iEvRnk504.png-wh_50


 OK!

 












本文转自故新51CTO博客,原文链接:http://blog.51cto.com/xingej/1957177 ,如需转载请自行联系原作者

相关文章
|
存储 运维 Kubernetes
服务搭建篇(十二) Kubernetes集群的安装及部署
在所有k8s node机器执行上图第三个红框里的命令 将node节点加入进master节点的集群里,复制上图第三个红框里的命令执行(执行自己的命令)
323 0
|
NoSQL 调度 数据中心
|
4月前
|
负载均衡 监控 调度
手把手告诉您Swarm 集群管理
【8月更文挑战第17天】Swarm是Docker原生的容器编排工具,简化多主机环境下的容器调度与管理,支持高效分布式部署。Swarm自Docker Engine v1.12起内置,无需额外安装。集群由管理节点和工作节点构成,前者负责调度与管理,后者执行任务。通过服务定义实现容器自动化部署与扩展,支持任务重调度以维持预期状态。Swarm采用去中心化设计,提供TLS加密确保安全通信,并具备负载均衡与滚动更新特性,简化服务发现与管理流程。
89 10
|
5月前
|
Kubernetes 负载均衡 Java
Kubernetes在Java应用部署中的最佳实践
Kubernetes在Java应用部署中的最佳实践
|
存储 Kubernetes Docker
kubenetes学习 1
kubenetes学习
|
Kubernetes 容器
kubenetes学习 2
kubenetes学习
|
Kubernetes 容器 Perl
kubenetes学习 4
kubenetes学习
111 0
|
存储 Kubernetes Docker
Docker 与 K8S学习笔记(十九)—— Pod的配置管理
我们在部署应用时常常会考虑将应用程序与配置文件相分离,这样可以使应用程序更好的复用,并且通过不同配置也能实现更灵活的功能。将应用制作成镜像后,我们可以在启动容器时通过环境变量或挂载文件的方式注入,但是在面临大规模容器集群的场景下就显得力不从心了,因此我们可以使用ConfigMap进行统一配置。 一、
372 0
|
JSON Prometheus 监控
Docker下Prometheus和Grafana三部曲之二:细说Docker编排
上一篇文章中快速搭建环境是否给您留下了印象,今天就来揭秘如何实现简单快捷的构建一个监控系统
288 0
Docker下Prometheus和Grafana三部曲之二:细说Docker编排
|
Kubernetes Linux 网络安全
『Kubernetes』Linux安装K8S集群过程笔记
📣读完这篇文章里你能收获到 - K8S安装全过程 - 博主自己实操笔记带你跳过所有坑
708 0