Hello,
I’m trying to compact Artemis journal with ./artemis data compact however no
matter what I do I always get this error:
[root@activemq-artemis-node-1 bin]# ./artemis data compact
2025-01-09 07:23:24,038 WARN [org.apache.activemq.artemis.logs] AMQ202017:
Algorithm two-way is deprecated and will be removed from the default codec in a
future version. Use a custom codec instead. Consult the manual for details.
Error:Given final block not properly padded. Such issues can arise if a bad key
is used during decryption.
javax.crypto.BadPaddingException: Given final block not properly padded. Such
issues can arise if a bad key is used during decryption.
at
java.base/com.sun.crypto.provider.CipherCore.unpad(CipherCore.java:862)
at
java.base/com.sun.crypto.provider.CipherCore.fillOutputBuffer(CipherCore.java:942)
at
java.base/com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:735)
at
java.base/com.sun.crypto.provider.BlowfishCipher.engineDoFinal(BlowfishCipher.java:321)
at java.base/javax.crypto.Cipher.doFinal(Cipher.java:2205)
at
org.apache.activemq.artemis.utils.DefaultSensitiveStringCodec$BlowfishAlgorithm.decode(DefaultSensitiveStringCodec.java:200)
at
org.apache.activemq.artemis.utils.DefaultSensitiveStringCodec.decode(DefaultSensitiveStringCodec.java:70)
at
org.apache.activemq.artemis.utils.DefaultSensitiveStringCodec.decode(DefaultSensitiveStringCodec.java:52)
at
org.apache.activemq.artemis.utils.PasswordMaskingUtil.resolveMask(PasswordMaskingUtil.java:68)
at
org.apache.activemq.artemis.core.deployers.impl.FileConfigurationParser.parseMainConfig(FileConfigurationParser.java:541)
at
org.apache.activemq.artemis.core.config.impl.FileConfiguration.parse(FileConfiguration.java:56)
at
org.apache.activemq.artemis.core.config.FileDeploymentManager.readConfiguration(FileDeploymentManager.java:81)
at
org.apache.activemq.artemis.cli.commands.Configurable.readConfiguration(Configurable.java:89)
at
org.apache.activemq.artemis.cli.commands.Configurable.getFileConfiguration(Configurable.java:66)
at
org.apache.activemq.artemis.cli.commands.tools.journal.CompactJournal.execute(CompactJournal.java:37)
at
org.apache.activemq.artemis.cli.Artemis.internalExecute(Artemis.java:225)
at org.apache.activemq.artemis.cli.Artemis.execute(Artemis.java:171)
at
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
at
java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:569)
at org.apache.activemq.artemis.boot.Artemis.execute(Artemis.java:152)
at org.apache.activemq.artemis.boot.Artemis.main(Artemis.java:64)
This is probably due to password masking which we are using. So far the things
I tried:
1. pass -Dartemis.default.sensitive.string.codec.key=myKey in
artemis-utility.properties
2. pass configuration to ./artemis data compact via both unnamed argument
and –brokerConfig (this one is a little bit not clear because parameters differ
if I type “artemis help” and in documentation and it’s unclear if configuration
parameter requires broker.xml or bootstrap.xml, but I tried with both files)
3. searched for any way to pass username/password directly, but could not
find any
Artemis version is 2.39.0, but 2.34.0 produces the same result.
What I’m doing wrong?
--
Best Regards,
Vilius Šumskas
Rivile
IT manager