You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@ignite.apache.org by "Dmitry Konstantinov (JIRA)" <ji...@apache.org> on 2017/12/16 11:32:00 UTC
[jira] [Created] (IGNITE-7219) Reduce memory allocation in
cassandra.persistence.PojoFieldAccessor
Dmitry Konstantinov created IGNITE-7219:
-------------------------------------------
Summary: Reduce memory allocation in cassandra.persistence.PojoFieldAccessor
Key: IGNITE-7219
URL: https://issues.apache.org/jira/browse/IGNITE-7219
Project: Ignite
Issue Type: Improvement
Components: cassandra
Affects Versions: 2.3, 2.2, 2.1
Reporter: Dmitry Konstantinov
As a part of store logic of CassandraCacheStore if strategy="POJO" is used to store a value entity - org.apache.ignite.cache.store.cassandra.persistence.PojoFieldAccessor is used to work with POJO properties. Within the methods getValue/setValue getReadMethod()/getWriteMethod() are invoked each time. As a part of the methods invocation sun.reflect.misc.ReflectUtil#isNonPublicProxyClass is triggered which works with class names as strings and allocates a memory. It is a small allocation by itself but it is triggered very frequently - for each field for each entity per each DB operation - so in summary it create a significant pressure. See attach:
Suggestion: we can cache and reuse getReadMethod()/getWriteMethod() results as a part of constructor logic of PojoFieldAccessor
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)