资讯专栏INFORMATION COLUMN

Webservice On Netty

weknow619 / 2664人阅读

摘要:最近遇到了一个项目需求,技术选型选择了,需要对外提供接口。考虑到我们的对外接口需要进行分类,需要在原来的路径映射加上前缀。这个开源组件原来的示例表示路径,表示的具体实现。

Java的世界属于开源的世界,所谓开源的世界,只要你能想到的点子就一定有人实现了,没有你就自己造一个啊。

最近遇到了一个项目需求,技术选型选择了webservice,需要对外提供webservice接口。实现webserice功能可以有多种做法的,比如servlet + tomcat的方式,Java Main方法+嵌入jetty server的方式,本质上是XML/HTTP的原理(误?)。

项目组对外提供接口的功能已经选择了HTTP/Netty的方式,既然已经有HTTP的支持了,那么XML/HTTP On Netty或许是个不错的点子,这样我们不用再引入tomcat等服务应用了。

经过一番搜索,终于发现了netty-jax-ws这款组件,非常符合我们的需求,于是就采用了它完成了开发工作。

考虑到我们的对外接口需要进行分类,需要在原来的URL路径映射加上前缀。
这个开源组件原来的示例

mappings.put("/echoService", echoWebService);

key表示URL路径,value表示webservice的具体实现。
此时我们给它加上前缀

mappings.put("/honey/echoService", echoWebService);

比如之前的访问方式http://localhost:4040/echoService?wsdl,这回我们的访问路径应该是http://localhost:4040/honey/echoService?wsdl
只不过这回意外的是服务给我们返回的是404的结果,看来我们的路径是不正确的,或者这个访问路径找不到实现的webservice(类似MVC框架中的Controller)。

这个问题的原因很快就排查出来的,我觉得可能自己就能解决,于是乎就fork了项目试着改动起来,参见这个提交commit1,至此暂告一段落了。

这部分功能代码就加入到了原来的项目中,只不过已经打包部署就发现,只要访问webservice功能http://localhost:4040/honey/echoService?wsdl
就会报错:NoSuchMethodError, 然后是xx.jboss.netty.xx.ChannelFactory诸如此类的错误,我第一个感觉就是netty-jax-ws和原来的项目使用的Netty版本冲突了。

此时我请教我们组经验丰富的同事,遇到这种情况要不要迎难而上呢,还是另辟蹊径呢?(当然,当时肯定是口语化的表达)。

既然我前面已经改造过一回,不在乎再一次了,所以就有了这次commit2。

以上算是我真正意义地上参与了一次开源贡献,我只是做了一点工作而已了。

-- EDIT --
这次修改是为了支持通过代理的方式访问webservice,支持了HTTP Host请求头,修改参见commit3

文章属个人观点,与本人工作雇主无关!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/110352.html

相关文章

  • 分布式下的远程通信技术(RPC)的一些理解

    摘要:都是分开部署,单独上线的。序列化毕竟是远程通信,需要将对象转化成二进制流进行传输。服务化架构的演进架构当业务规模很小时,将所有功能都不熟在同一个进程中,通过双机或者负载均衡器实现负债分流此时,分离前后台逻辑的架构是关键。 showImg(https://segmentfault.com/img/bVbiI2F?w=2250&h=1500); 前言 为什么需要RPC,而不是简单的HTTP...

    EastWoodYang 评论0 收藏0
  • 实现一个spring webservice服务端三:实现一个有复杂返回值的spring-ws服务

    摘要:,将类或枚举类型映射到模式类型,控制字段或属性的序列化。表示将自动绑定类中的每个非静态的非瞬态的由标注字段到。,对于数组或集合即包含多个元素的成员变量,生成一个包装该数组或集合的元素称为包装器。 在经过前面两篇文章的学习,我已经能够熟练创建一个正常运行的spring-ws的webservice服务,大多数接口,都是要有返回数据,所以这篇文章就是学习spring-ws怎么实现返回数据 实...

    xinhaip 评论0 收藏0
  • 基于Docker的Scrapy+Scrapyd+Scrapydweb部署

    摘要:如需远程访问,则需在配置文件中设置,然后重启。详见如果是同个容器,直接使用即可,这里是演示了不同容器或主机下的情况访问即可 文章开始,先摘录一下文中各软件的官方定义Scrapy An open source and collaborative framework for extracting the data youneed from websites.In a fast, simpl...

    defcon 评论0 收藏0
  • 基于Docker的Scrapy+Scrapyd+Scrapydweb部署

    摘要:如需远程访问,则需在配置文件中设置,然后重启。详见如果是同个容器,直接使用即可,这里是演示了不同容器或主机下的情况访问即可 文章开始,先摘录一下文中各软件的官方定义Scrapy An open source and collaborative framework for extracting the data youneed from websites.In a fast, simpl...

    陈伟 评论0 收藏0
  • 后端好书阅读与推荐(续三)

    摘要:后端好书阅读与推荐系列文章后端好书阅读与推荐后端好书阅读与推荐续后端好书阅读与推荐续二后端好书阅读与推荐续三这里依然记录一下每本书的亮点与自己读书心得和体会,分享并求拍砖。然后又请求封锁,当释放了上的封锁之后,系统又批准了的请求一直等待。 后端好书阅读与推荐系列文章:后端好书阅读与推荐后端好书阅读与推荐(续)后端好书阅读与推荐(续二)后端好书阅读与推荐(续三) 这里依然记录一下每本书的...

    lauren_liuling 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<