背景
因为分布式微服务的诸多优点,应用的开发不再局限在一个代码repository,多个应用同时并行开发的情况还是很常见。再者调用其他系统/应用时遇到问题,总不能每次都去问人家。自己去拉代码,看代码,甚至是调试代码,所以搭建多个应用调试环境是很必要的。故而,总不能把这个应用停止之后,再去看另外一个应用,白白把时间浪费在应用的停止和启动上面。并且两个应用间的调试,还是需要启动多个应用。
准备工具
idea,tomcat。
PS:如果想要实现热部署的需求,还需要一个 jrebel。
方案
方案一
修改IDEA的deployment标签页信息,如下:
注意选择war exploded。然后修改应用context。多个应用的context不能同名即可。
注:war和war exploded有什么区别?
war:发布时脱离本地项目目录,发布到Tomcat目录\webapps\ROOT下;
explored:将web root指向你的本地项目。
因此war形式会产生冲突,而explored方式不会,且explored方式可以热加载。
方案二
修改IDEA的端口配置信息,具体来说修改Tomcat server settings下面的HTTP port以及JMX port。
注意同时需要修改JMX port端口信息。注意两个应用的HTTP port以及JMX port不能冲突。
热部署
在调试应用程序或者接口方法的时候,难免需要修改程序,总不能每次修改一点点代码就重新启动应用吧。此时可以考虑使用热部署功能。IDEA自带热部署功能。具体配置方法:
都修改为 update classes and resources即可。
热部署进阶之JRebel
在实际使用中会发现,简单的文件class修改,IDEA自带的热部署功能可以应付过去,如果是大面积的代码修改,则无能为力。此时可以考虑使用JRebel。首先需要安装插件JRebel,很简单;
但是激活可能比较麻烦一些:
方案一:需要能翻墙的情况下,借助于 Facebook 或者 Twitter 账户去 JRebel 产品的公司 zeroturnaround 注册,然后获得一个license,添加license就可以使用。
方案二:网上找破解的插件,具体百度即可。
如果看到这个,则表示热部署插件安装成功。
或者
然后每次启动项目的时候就可以选择后面两个JRebel的Run & Debug按钮功能啦。
但是
但是如果本文仅仅只是上述内容,那么又将是充斥互联网垃圾的另一篇垃圾。
为什么?在按照上面的解决方案配置IDEA之后,有时候并不可行。
比如我有一次启动两个项目就出现下面这个问题:
首先检查自己的配置肯定没有问题,但是为什么会出现这样的问题呢?报错是不能打开debugger port:55982,于是按照这个思路去Google,找到这篇 按照这里面的思路去配置:
你猜,问题解决的话,我也不会写这个但是。
根本就不能解决我的问题。难道这个随机端口被占用?使用命令netstat或者其他命令查看,并没有占用啊?why?想了想,认为debugger port基于JMX port,所以去更改JMX port就行(的确是这样,解决我的问题)。另外,貌似在哪里看到JMX port最好是偶数(待验证,实际上我配置一个奇数也没有问题)。
问题是得到解决,但是为什么呢?网络协议这一块,还有很多坑要填啊。