[ 
https://issues.apache.org/jira/browse/CASSANDRA-18264?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17689942#comment-17689942
 ] 

Stefan Miklosovic commented on CASSANDRA-18264:
-----------------------------------------------

4.1 https://ci-cassandra.apache.org/view/patches/job/Cassandra-devbranch/2282/

trunk is basically carbon copy of that. Nothing changed in trunk in that regard.

btw, unfortunately, the second example for k8s does not compile either so I 
fixed it here. (1) The problem is that when using our custom file / paths util, 
it somehow need to have Cassandra / Descriptor initialised otherwise Config has 
null variables and it throws NPE ... The easiest solution is to just use Java 
stuff and thats it. 

[~brandon.williams] What do you think?

(1) 
https://github.com/apache/cassandra/pull/2159/commits/d659522c7816fb35acdfe9ce6914b2b4abc35fc6

> CustomClassLoader does not load jars rendering triggers from JARs broken
> ------------------------------------------------------------------------
>
>                 Key: CASSANDRA-18264
>                 URL: https://issues.apache.org/jira/browse/CASSANDRA-18264
>             Project: Cassandra
>          Issue Type: Bug
>          Components: Legacy/Core
>            Reporter: Stefan Miklosovic
>            Assignee: Stefan Miklosovic
>            Priority: Normal
>             Fix For: 4.1.x, 4.x
>
>          Time Spent: 1h 20m
>  Remaining Estimate: 0h
>
> A user had to downgrade to 4.0.7 from 4.1.0 because they hit a problem with 
> CustomClassLoader for triggers. 
> User says that in Apache Cassandra 4.1.0 the trigger mechanism does not work, 
> not their trigger, but the possibility of loading any trigger in Cassandra.
> In the Cassandra 4.1.0 version of CustomClassLoader 
> (https://github.com/apache/cassandra/blob/cassandra-4.1/src/java/org/apache/cassandra/triggers/CustomClassLoader.java)
>  the code is changed in such a way that when copying the JAR Cassandra uses 
> java.nio.file.Files, while earlier versions (cassandra 4.0.X or 3.X) used 
> Guava com.google.common.io.Files to copy the JAR file.
> The difference between one and the other is that Guava by default overwrites 
> the file if it already exists and user has permissions to do so, and in Java 
> by default it does not overwrite.
> Copying is done here (1) from inputJar to out. However, the problem is that 
> we are getting temporary file from here (2) and the implementation loops 
> unless it succeeds to create an empty file. (3) - But that fails to copy the 
> file to out because copying does not work when the target file already exists.
> (1) 
> https://github.com/apache/cassandra/blob/cassandra-4.1/src/java/org/apache/cassandra/triggers/CustomClassLoader.java#L86
> (2) 
> https://github.com/apache/cassandra/blob/cassandra-4.1/src/java/org/apache/cassandra/triggers/CustomClassLoader.java#L81
> (3) 
> https://github.com/apache/cassandra/blob/cassandra-4.1/src/java/org/apache/cassandra/io/util/FileUtils.java#L152



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscr...@cassandra.apache.org
For additional commands, e-mail: commits-h...@cassandra.apache.org

Reply via email to