Can I suggest shading Guava? Guava and Netty are two notorious libraries for version conflicts because of their popularity and usefulness. Other projects (ES for example solved it by shading them it https://github.com/elastic/elasticsearch/issues/2091#issuecomment-7156766).
We use Ignite entirely as a thick client and already have Guava version conflicts from other projects (Calcite being one because we use it directly already) so Ignite bringing its own will only make this worse when we get to V3. Even Calcite itself already has Guava conflicts because of the Cassandra adapter. I'd +1 this but really only if it will be shaded. Regards, Courtney Robinson Founder and CEO, Hypi Tel: ++44 208 123 2413 (GMT+0) <https://hypi.io> <https://hypi.io> https://hypi.io On Thu, Aug 5, 2021 at 5:56 PM Zhenya Stanilovsky <arzamas...@mail.ru.invalid> wrote: > > alexpolovtcev please clarify what do you mean under : «possibility of > using Guava in Ignite 3», using how necessary dependency of calcite or > using like «using in our code» ? If using in code, i -1 here. > thanks. > > > >Hello, dear Igniters! > > > >I would like to discuss the possibility of using Guava > >< https://github.com/google/guava > in Ignite 3. I know about the > restrictive > >policy of using it in Ignite 2, but I have the following reasons: > > > >1. We are de-facto using it already as an implicit dependency, since the > >Calcite module depends on it, and Calcite is going to stay for a while =) > >2. AFAIK, the "bytecode" module is copied into the codebase only to strip > >Guava away from it. We can remove this module, which will improve the > >maintainability of the project. > >3. We have some copy-paste of Guava code in the project. For example, see > >this > >< > https://github.com/apache/ignite-3/blob/main/modules/core/src/main/java/org/apache/ignite/internal/util/IgniteUtils.java#L136 > > > >and this > >< > https://github.com/apache/ignite-3/blob/main/modules/core/src/main/java/org/apache/ignite/internal/util/IgniteUtils.java#L428 > > > >. > >4. Regarding security concerns, this report > >< > https://www.cvedetails.com/product/52274/Google-Guava.html?vendor_id=1224 > > > >shows no major vulnerability issues for the last three years. > > > >Taking these points into account, I propose to allow using Guava both in > >production and test code and to add it as an explicit dependency. > > > >What do you think? > > > >-- > >With regards, > >Aleksandr Polovtcev > > > >