官术网_书友最值得收藏!

Marshalling

(Un)Marshalling is what will (read/)write a Java object to a communication format. It is commonly the part converting an object to a XML or JSON payload but can really be any format, including binary formats.

This conversion is normally synchronous in the implementation and can be costly depending on the model you use and the serializer that is activated. Compared with the servlet API, where you yourself serialize the payload you want to read/return, here, the task is done by the framework and is, therefore, a bit hidden.

A crucial point at this stage is to make sure that the manipulated object has almost no logic and is fast to initialize/read. If you don't respect this point, you may end up holding the HTTP stream for too long which would badly impact your scalability and on a more general practice, you would risk to have some lazy loading of data with JPA which can fail or imply an unexpected connection usage depending the JPA provider and configuration. Another bad case would be to start writing and, then, compute some costly value before continuing to write and therefore force the marshalling process to pause and delay the write after having started it. This not only has a direct impact on the request thread pool but also on the HTTP I/O.

In the same spirit as the algorithm used to match a method to invoke (see the previous part), the JAX-RS runtime must resolve the provider to use (MessageBodyReader or MessageBodyWriter depending on whether you read or write) in order to make the link with the Java model. Here again, this resolution depends on the incoming request (or the response being built) and media type headers and is not as flat as expected even if it is cacheable and generally fast.

主站蜘蛛池模板: 靖江市| 南丰县| 太原市| 利辛县| 昆明市| 阳山县| 泌阳县| 二连浩特市| 奇台县| 阳信县| 遵义市| 巴林左旗| 台湾省| 万安县| 澄迈县| 邯郸县| 新巴尔虎右旗| 上林县| 铜鼓县| 离岛区| 林口县| 越西县| 瓮安县| 青神县| 犍为县| 常德市| 厦门市| 睢宁县| 隆安县| 滁州市| 突泉县| 秦安县| 长汀县| 浮山县| 西城区| 马尔康县| 鹤峰县| 托克逊县| 武宣县| 缙云县| 乌鲁木齐县|