gianm opened a new pull request, #12468:
URL: https://github.com/apache/druid/pull/12468

   This patch attacks two sources of allocations during Jackson
   serialization:
   
   1) ObjectMapper.writeValue and JsonGenerator.writeObject create a new
      DefaultSerializerProvider instance for each call. It has lots of
      fields and creates pressure on the garbage collector. So, this patch
      adds helper functions in JacksonUtils that enable reuse of
      SerializerProvider objects and updates various call sites to make
      use of this.
   
   2) GroupByQueryToolChest copies the ObjectMapper for every query to
      install a special module that supports backwards compatibility with
      map-based rows. This isn't needed if resultAsArray is set and
      all servers are running Druid 0.16.0 or later. This release was a
      while ago. So, this patch disables backwards compatibility by default,
      which eliminates the need to copy the heavyweight ObjectMapper. The
      patch also introduces a configuration option that allows admins to
      explicitly enable backwards compatibility.


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to