Sergey,

Sure, I'll add you as a reviewer.
And a thorough review will be the best contribution. The feature is rather
complex and in the works for quite some time.


On Fri, Feb 21, 2020 at 4:03 PM Ilya Kasnacheev <ilya.kasnach...@gmail.com>
wrote:

> Hello!
>
> Can you please describe what is the overhead on server nodes from starting
> .Net near cache, as compared to starting "regular" near cache?
>
> Also, why do we start near cache on all server nodes - is it required by
> our architecture?
>
> Otherwise, if you add a new feature, which you have to explicitly invoke
> from application .Net code, I assume it's OK to consume some resources upon
> such invocation. We can't expect new features to consume zero resources.
>
> Regards,
> --
> Ilya Kasnacheev
>
>
> вт, 18 февр. 2020 г. в 20:46, Pavel Tupitsyn <ptupit...@apache.org>:
>
> > Ilya, looks like there is a misunderstanding.
> >
> > We don't start near cache on a subset of server nodes. Let me explain
> > again.
> > Consider the following code, executed on any node (client or server -
> does
> > not matter):
> >
> > ignite.createCache(new CacheConfiguration("c").setNearConfiguration(new
> > NearCacheConfiguration()));
> >
> > As a result, cache "c" is started on all server nodes, and corresponding
> > near cache is started on all server nodes,
> > with the same config, eviction policy, and so on.
> >
> > Now, what do we do with .NET near cache in this situation?
> > 1. Start .NET near cache as well on server nodes, always.
> > 2. Introduce a config flag, and start .NET near cache only when the flag
> is
> > set
> >
> > The problem with option (1) is that it changes the behavior of existing
> > applications,
> > increasing overhead for cache operations and increasing memory usage.
> >
> > As a user, I don't want some new features to be force-enabled on me
> > silently in a new product version.
> > That is why an opt-in config flag is required.
> >
> > Does this make sense?
> >
> > On Tue, Feb 18, 2020 at 6:42 PM Ilya Kasnacheev <
> ilya.kasnach...@gmail.com
> > >
> > wrote:
> >
> > > Hello!
> > >
> > > I'm not sure that we can/want to create near cache on a subset of
> server
> > > nodes.
> > >
> > > If this is indeed possible, I would decouple that from .Net and
> introduce
> > > as a separate feature.
> > >
> > > Ideally we should be able to start or stop near cache on any node,
> server
> > > or client, and this should be the same cache for all platforms
> (including
> > > Java). WDYT?
> > >
> > > Regards,
> > > --
> > > Ilya Kasnacheev
> > >
> > >
> > > вт, 18 февр. 2020 г. в 17:31, Pavel Tupitsyn <ptupit...@apache.org>:
> > >
> > > > Ilya, as noted above:
> > > >
> > > > > There are 2 kinds of Near Caches:
> > > > > - On client nodes: created per-node by calling
> ignite.CreateNearCache
> > > > > - On server nodes: created on all server nodes if
> > > > CacheConfiguration.NearCacheConfiguration is not null
> > > > >
> > > > > When user says ignite.CreateCache(new CacheConfiguration
> > > > {NearCacheConfiguration = ...}),
> > > > > the whole config is sent to all server nodes, and .NET-specific
> flag
> > > has
> > > > to be included somehow.
> > > >
> > > >
> > > >
> > > > On Tue, Feb 18, 2020 at 5:10 PM Ilya Kasnacheev <
> > > ilya.kasnach...@gmail.com
> > > > >
> > > > wrote:
> > > >
> > > > > Hello!
> > > > >
> > > > > Why would it waste additional memory? All nodes are also Java nodes
> > so
> > > > they
> > > > > will start near caches all right.
> > > > >
> > > > > Don't we have near cache start-up on per-node basis for clients,
> > > anyway?
> > > > >
> > > > > I'm not convinced why we need this flag. I have to admit my
> > > understanding
> > > > > of near caches is limited.
> > > > >
> > > > > Regards,
> > > > > --
> > > > > Ilya Kasnacheev
> > > > >
> > > > >
> > > > > вт, 18 февр. 2020 г. в 16:56, Pavel Tupitsyn <ptupit...@apache.org
> >:
> > > > >
> > > > > > Ilya, Aleksandr,
> > > > > >
> > > > > > The flag is called platformNearCacheEnabled, my idea is to have
> > just
> > > > one
> > > > > > flag for all platforms.
> > > > > >
> > > > > > If some platform is present on the given node (.NET, C++) and it
> > > > supports
> > > > > > native near caching,
> > > > > > then the flag is honored, otherwise it is ignored. We should not
> > > throw
> > > > > > exceptions,
> > > > > > because mixed clusters are possible (.NET nodes along with Java
> > > nodes).
> > > > > >
> > > > > > > Why would enabling it affect mixed`clusters?
> > > > > > Initially the idea was to enable .NET near cache whenever
> > > > > > NearCacheConfiguration is present.
> > > > > > If we assume .NET-only clusters, it makes sense: existing code
> will
> > > > work
> > > > > > faster automatically.
> > > > > >
> > > > > > Mixed cluster is just one of the possible use cases when this may
> > be
> > > a
> > > > > bad
> > > > > > idea,
> > > > > > e.g. users have enabled near caching to speed up their Java-based
> > > > > > computations,
> > > > > > and .NET nodes are used for something else, wasting memory on
> near
> > > > > caching
> > > > > > unnecessarily.
> > > > > >
> > > > > > On  ue, Feb 18, 2020 at 4:30 PM Aleksandr Shapkin <
> > lexw...@gmail.com
> > > >
> > > > > > wrote:
> > > > > >
> > > > > > > Pavel,
> > > > > > >
> > > > > > >
> > > > > > >
> > > > > > > I think it’s ok to add a new flag.
> > > > > > >
> > > > > > > Though we may change a name to something like
> > > > > > #usePlatformCacheIfAvailable
> > > > > > >
> > > > > > >
> > > > > > >
> > > > > > > But it may vary depending on the implementation, i.e.
> > > > > > >
> > > > > > > should we throw an error if there is no native cache
> > > > > > >
> > > > > > > available for a platform or just ignore the configuration.
> > > > > > >
> > > > > > > вт, 18 февр. 2020 г. в 15:05, Pavel Tupitsyn <
> > ptupit...@apache.org
> > > >:
> > > > > > >
> > > > > > > > Igor,
> > > > > > > >
> > > > > > > > The problem is - we need to pass this flag around the
> > cluster`for
> > > > > > Server
> > > > > > > > Near Caches,
> > > > > > > > so that .NET near caches are started accordingly.
> > > > > > > >
> > > > > > > > There are 2 kinds of Near Caches:
> > > > > > > > - On client nodes: created on every client node separately by
> > > > calling
> > > > > > > > ignite.CreateNearCache
> > > > > > > > - On server nodes: created on all server nodes if
> > > > > > > > CacheConfiguration.NearCacheConfiguration is set
> > > > > > > >
> > > > > > > > When user says ignite.CreateCache(new CacheConfiguration
> > > > > > > > {NearCacheConfiguration = ...}),
> > > > > > > > the whole config is sent 4o all server nodes, and
> .NET-specific
> > > > flag
> > > > > > has
> > > > > > > to
> > > > > > > > be included somehow.
> > > > > > > >
> > > > > > > > On Tue, Feb 18, 2020 at 2:59 PM Igor Sapego <
> > isap...@apache.org>
> > > > > > wrote:
> > > > > > > >
> > > > > > > > > Do you suggest to introduce it in general configuration?
> Why
> > > not
> > > > > > > > introduce
> > > > > > > > > it only on platform side? Is there any .NET-specific
> > > > configuration?
> > > > > > > > >
> > > > > > > > > Best Regards,
> > > > > > > > > Igo2
> > > > > > > > >
> > > > > > > > >
> > > > > > > > > On Tue, Feb 18, 2020 at 1:10 AM Pavel Tupitsyn <
> > > > > ptupit...@apache.org
> > > > > > >
> > > > > > > > > wrote:
> > > > > > > > >
> > > > > > > > > > Igniters,
> > > > > > > > > >
> > > > > > > > > > I'm working on .NET Near Cache feature [1]
> > > > > > > > > > (storing deserialized cache entries in CLR memory to
> > improve
> > > > > > > > > performance).
> > > > > > > > > >
> > > > > > > > > > Implementation is based on Java near cache, with some
> > > callbacks
> > > > > to
> > > > > > > .NET
> > > > > > > > > > side
> > > > > > > > > > for updating and invalidating cached entries.
> > > ~ > > > > > >
> > > > > > > > > > However, I'd like to make this feature optional: enabling
> > > Java
> > > > > near
> > > > > > > > cache
> > > > > > > > > > should not
> > > > > > > > > > always enable .NET near cache - some users may have mixed
> > > > > clusters,
> > > > > > > > etc.
> > > > > > > > > >
> > > > > > > > > > Therefore I'm adding
> > > > > > NearCacheConfiguration#platformNearCacheEnabled
> > > > > > > > > > boolean flag.
> > > > > > > > > > Are there any objections or better ideas to configure
> this
> > > > > > behavior?
> > > > > > > > > >
> > > > > > > > > > Thanks,
> > > > > > > > > > Pavel
> > > > > > > > > >
> > > > > > > > > > [1] https://issues.apache.org/jira/browse/IGNITE-12691
> > > > > > > > > >
> > > > > > > > >
> > > > > > > >
> > > > > > >
> > > > > > >
> > > > > > > --
> > > > > > > Alex.
> > > > > > >
> > > > > >
> > > > >
> > > >
> > >
> >
>

Reply via email to