cancel
Showing results for 
Search instead for 
Did you mean: 

Head's Up! These forums are read-only. All users and content have migrated. Please join us at community.neo4j.com.

Error on 4.2 - New

Neo.ClientError.Procedure.ProcedureCallFailed

Failed to invoke procedure apoc.path.subgraphNodes: Caused by: java.lang.ClassNotFoundException: org.neo4j.graphdb.TransactionGuardException

This procedure was working fine in 4.1 is now breaking in 4.2 - Any hints ?

8 REPLIES 8

ameyasoft
Graph Maven

Same thing I also experienced. It's because of APOC version . Looks like there is no latest version of APOC. After a while my database started working with APOC version 4.1.0.2 that was there with 4.1 version.

Groan. Yeah, I think I see it.

We run our builds from actual scripts. Last time, on the basis of the comments here, we understood that APOC was going to be part of the product. Ok - That wasn't quite what happened. So we had to re-modify the scripts to pick it up. Now we see that there is no official build for APOC. There is a "not ready" version but no official one.
Thanks - That was helpful.

I think the post about 4.2 is withdrawn!

I love how Neo4j releases a new version, takes the time to deprecate "whitelist" forcing everyone to go change their configs to "allowlist" but neglects to document that their new version (SURPRISE!) requires APOC 4.2 to work. Skip the rest of this diatribe and go directly to the solution at the bottom if you wish.

Now, they "bundled" the download of APOC with 4.1 - basically acknowledging that nobody (in their right mind) attempts to use Neo4j without APOC. Apparently, so that they could release 4.2 one day early they bundled APOC 4.2.RC02 (Release Candidate 02) code with the download. For the uninitiated, "bundled" means they acknowledge that nobody (in their right mind) can get anything done on Neo4j without APOC, but APOC is not a Neo4j-supported set of code. So they download it to a "labs" directory and make you take the affirmative action of moving it to plugins yourself.

It's kind of like "Welcome to your new car! We realize that it may be difficult to drive without a steering wheel but you will find a steering wheel made by a totally unrelated third party under the back seat. If you decide you really need a steering wheel, please remove it from under the back seat and attach it to the steering column. We make no warranty as to the effectiveness of the steering wheel."

The production version of APOC 4.2 was released the day AFTER Neo4j released 4.2. A 24-hour delay by Neo4j on the 4.2 release would have resulted in a semi-seamless experience for the user base.

You just can't make this stuff up - over, and over, and over again. At least I have learned along the way from 3.x through 4.0 (don't do that one!) to 4.1 and I installed 4.2 on one server to test first. I also --exclude neo4j* from my dnf updates.

ON THE POSITIVE SIDE - with only one day of experience - my team is reporting that 4.2 appears to be faster in some respects important to us and have asked that it be migrated to all the servers. Good for them. The poor infrastructure guy will continue to wait and hope for the surprise-free version release. Note to data analysis team: "Infrastructure assigns no priority to the resolution of any problems created by your decision to proceed. Think APOC and steering wheels."

Bottom line for Linux users:
upgrade your neo4j (and cypher-shell if used) to 4.2 via your preferred method (yum/dnf/apt/etc) then
(Edited 11/20/20 so you can just cut and paste)

cd /$NEO4J_HOME/plugins # set directory explicitly if NEO4J_HOME variable is not set
rm -f apoc* # you don't need the old version of APOC
wget https://github.com/neo4j-contrib/neo4j-apoc-procedures/releases/download/4.2.0.0/apoc-4.2.0.0-core.j...
chown neo4j:neo4j apoc* # change ownership so neo4j has permission
chmod 655 apoc* # make executable across users and groups
systemctl restart neo4j # restart neo4j

Then, just for giggles, do a journalctl -xe and then see if you can tell me why we now get a new error on startup: ERROR StatusLogger Log4j2 could not find a logging implementation. Please add log4j-core to the classpath. Using SimpleLogger to log to the console...

I will figure this out eventually, but if anyone has the solution in their back pocket and can give it to me "doggy, horsey, fishy" simple like my APOC solution above - PLEASE. Otherwise, I will bang my head against the desk and burn up Google until I figure it out and then post here. Just once - one time - a surprise free, error free, deprecation free release. Just once. Is it too much to ask?

Note to data analysis team: "Infrastructure assigns no priority to the resolution of any problems created by your decision to proceed. Think APOC and steering wheels."

On behalf of the data analysis team, we acknowledge and understand. Best summed up by "your mileage may vary".

Thank you

i have same problem but different procedure.

Neo.ClientError.Procedure.ProcedureCallFailed

Failed to invoke procedure netscan.find_communities: Caused by: java.lang.NoSuchMethodError: 'org.neo4j.graphdb.Result org.neo4j.graphdb.GraphDatabaseService.execute(java.lang.String)'

I have tried to use APOC version 4.1.0.2 but it not solve my problem.
Any hint or something like that?

then did you got its solution? as i am getting same problem.