sdkman / sdkman-cli

The SDKMAN! Command Line Interface
https://sdkman.io
Apache License 2.0
6.08k stars 629 forks source link

It is not possible to install java or groovy in a instance of Windows Subsystem for Linux #622

Open ilmoralito opened 6 years ago

ilmoralito commented 6 years ago

We require a conversation to take place in the appropriate Gitter Room before raising a new Github Issue. Please note that issues will be closed immediately if prior discussion did not take place. We need to do this to help manage the quality and validity of Issues raised on this project.

Please tick one:

Please explain the Issue / Feature Request here:

Hi everyone, I am trying to install java and groovy candidates in an instance of ubuntu bash shell in windows 10.

When I try

sdk install javajava 9.0.1-zulu

I get the following message

root@lab208:~# sdk install java 9.0.1-zulu

Downloading: java 9.0.1-zulu

In progress...

######################################################################## 100.0%
Download has failed, aborting!

Can not install java 9.0.1-zulu at this time...

I get a similar scenario when trying to install groovy, but with the following message

root@lab208:~# sdk install groovy 2.4.10

Downloading: groovy 2.4.10

In progress...

######################################################################## 100.0%
  End-of-central-directory signature not found.  Either this file is not
  a zipfile, or it constitutes one disk of a multi-part archive.  In the
  latter case the central directory and zipfile comment will be found on
  the last disk(s) of this archive.
unzip:  cannot find zipfile directory in one of /root/.sdkman/archives/groovy-2.4.10.zip or
        /root/.sdkman/archives/groovy-2.4.10.zip.zip, and cannot find /root/.sdkman/archives/groovy-2.4.10.zip.ZIP, period.

Stop! The archive was corrupt and has been removed! Please try installing again.

On the other hand grails and gradle are installed correctly.

Any idea how to fix this problem? Thanks in advance

marc0der commented 6 years ago

How long does the download take? Does it seem like it's actually downloading something?

Also, it might be worth turning on debugging and posting the result here. You can do so by changing the sdkman_debug_mode flag to true in the ~./sdkman/etc/config.

ilmoralito commented 6 years ago

It does not take much time, just print the text ######################################################################## 100.0% And then the message

This is the debug result when trying to install java

root@lab213:~# sdk install java
==== BROADCAST =================================================================
* 17/01/18: Kotlin 1.2.20 released on SDKMAN! #kotlin
* 09/01/18: Gradle 4.5-rc-1 released on SDKMAN! #gradle
* 06/01/18: sbt 1.1.0 released on SDKMAN! #scala
================================================================================
Validate java 8u152-zulu for Linux64: valid
Validation URL: https://api.sdkman.io/2/candidates/validate/java/8u152-zulu/linux64
Get pre-installation hook: https://api.sdkman.io/2/hooks/pre/java/8u152-zulu/linux64
Copy remote pre-installation hook: /root/.sdkman/tmp/hook_pre_java_8u152-zulu.sh
No Linux pre-install hook found for Java 8u152-zulu.
Completed pre-installation hook...

Downloading: java 8u152-zulu

In progress...

######################################################################## 100.0%
Downloaded binary to: /root/.sdkman/tmp/miCAOn6UhLRUMlJ7fLihwM7fC0lwn88y.bin
Get post-installation hook: https://api.sdkman.io/2/hooks/post/java/8u152-zulu/linux64
Copy remote pre-installation hook: /root/.sdkman/tmp/hook_pre_java_8u152-zulu.sh
A Linux post-install hook was found for Java 8u152-zulu.
Download has failed, aborting!

Can not install java 8u152-zulu at this time...

This is the debug result when trying install groovy

root@lab213:~# sdk install groovy
SDKMAN: No update needed. Using existing candidates cache: ant,asciidoctorj,ceylon,crash,gaiden,glide,gradle,grails,griffon,groovy,groovyserv,java,jbake,kobalt,kotlin,kscript,lazybones,leiningen,maven,sbt,scala,spark,springboot,sshoogr,vertx,visualvm
Not refreshing version cache now...
Validate groovy 2.4.13 for Linux64: valid
Validation URL: https://api.sdkman.io/2/candidates/validate/groovy/2.4.13/linux64
Get pre-installation hook: https://api.sdkman.io/2/hooks/pre/groovy/2.4.13/linux64
Copy remote pre-installation hook: /root/.sdkman/tmp/hook_pre_groovy_2.4.13.sh
No Linux pre-install hook found for Groovy 2.4.13.
Completed pre-installation hook...

Downloading: groovy 2.4.13

In progress...

######################################################################## 100.0%
Downloaded binary to: /root/.sdkman/tmp/RcR68iQXgNm5reTBuGsbz0vx3o8XPMq8.bin
Get post-installation hook: https://api.sdkman.io/2/hooks/post/groovy/2.4.13/linux64
Copy remote pre-installation hook: /root/.sdkman/tmp/hook_pre_groovy_2.4.13.sh
No Linux post-install hook found for Groovy 2.4.13.
Moving /root/.sdkman/tmp/RcR68iQXgNm5reTBuGsbz0vx3o8XPMq8.bin to /root/.sdkman/tmp/RcR68iQXgNm5reTBuGsbz0vx3o8XPMq8.zip
Processed binary as: /root/.sdkman/tmp/RcR68iQXgNm5reTBuGsbz0vx3o8XPMq8.zip
Completed post-installation hook...
Moved to archive folder: /root/.sdkman/archives/groovy-2.4.13.zip
  End-of-central-directory signature not found.  Either this file is not
  a zipfile, or it constitutes one disk of a multi-part archive.  In the
  latter case the central directory and zipfile comment will be found on
  the last disk(s) of this archive.
unzip:  cannot find zipfile directory in one of /root/.sdkman/archives/groovy-2.4.13.zip or
        /root/.sdkman/archives/groovy-2.4.13.zip.zip, and cannot find /root/.sdkman/archives/groovy-2.4.13.zip.ZIP, period.

Stop! The archive was corrupt and has been removed! Please try installing again.

Thanks for answering

neversleepz commented 6 years ago

Tested this with my WSL Ubuntu install but wasn't able to reproduce. Could install Groovy and Kotlin (from a sudo bash shell) successfully Noticed from your logs, that the download directory is going to /root and not /home/<username> Wondering if there are any permission issues? I also tried running sudo bash in the Ubuntu shell prior to running sdkman (its still using my homedir though according to the logs) How did you get to be the root user?

Here's a copy of my install log to compare

svenHues commented 6 years ago

tl;dr For me installing tar helped. It is used in the post-installation-hook when I run sdk install java, but sdkman hasn't reported it as a missing dependency.


I'm running sdkman from inside a container (opensuse/tumbleweed). Already during the installation sdkman reports missing dependencies: which unzip zip. I install them. I try to sdk install java, but sdkman aborts at the very end. I try different versions of java, yet, it always aborts at the very end (after the download bar has reached 100%):

Download has failed, aborting! Can not install java 8.0.181-zulu at this time...

sdk install gradle works, though.

I change

the sdkman_debug_mode flag to true in the ~./sdkman/etc/config

, as @marc0der suggested, to get some clues to what is happening under the hood. I run sdk install java again. sdkmans's output looks like what @ilmoralito has posted when he ran sdk install java. Ending with the same:

######################################################################## 100.0% Downloaded binary to: [...] Get post-installation hook: [...] Copy remote pre-installation hook: [...] A Linux post-install hook was found for Java [8.0.181-zulu]. Download has failed, aborting!

Can not install java [8.0.181-zulu] at this time...

So it fails after it's found that post-install hook.

I run sdk install java again, but this time I turn some shell options for debugging on for the bash-shell I'm running sdk install java in: set -ETx (Maybe set -x would do just fine. I don't know.).

I also open up the post-installation hook that sdkman has mentionned before: _~/.sdkman/tmp/hook_post_java8.0.181-zulu.sh

I scroll upwards in what sdkman outputs and find:

+ __sdkman_validate_binary_input [\~]/.sdkman/tmp/ykOtgndRnbqfzLy6WIwv3HMUv4uMwbAa.bin + tar tzf [\~]/.sdkman/tmp/ykOtgndRnbqfzLy6WIwv3HMUv4uMwbAa.bin + echo 'Download has failed, aborting!' Download has failed, aborting! + echo ''

+ echo 'Can not install java 8.0.181-zulu at this time...'

I look at the __sdkman_validate_binary_input in the post-installation hook:

function __sdkman_validate_binary_input {
    if ! tar tzf "$1" &> /dev/null; then
        echo "Download has failed, aborting!"
        echo ""
        echo "Can not install java 8.0.181-zulu at this time..."
        return 1
    fi
}

Then it occures to me: Maybe I don't have tar installed? :sweat_smile:

abelsromero commented 5 years ago

I am running on WSL Arch and I also unable to install java. It downloads and install, and everything seems fine, but it is not added to the PATH javac: command not found. Also sdk ls java returns this:

<!DOCTYPE html>
<html lang="en">
    <head>
        <title>Bad Request</title>
        <link rel="shortcut icon" href="">
        <style>
            html, body, pre {
                margin: 0;
                padding: 0;
                font-family: Monaco, 'Lucida Console', monospace;
                background: #ECECEC;
            }
            h1 {
                margin: 0;
                background: #AD632A;
                padding: 20px 45px;
                color: #fff;
                text-shadow: 1px 1px 1px rgba(0,0,0,.3);
                border-bottom: 1px solid #9F5805;
                font-size: 28px;
            }
            p#detail {
                margin: 0;
                padding: 15px 45px;
                background: #F6A960;
                border-top: 4px solid #D29052;
                color: #733512;
                text-shadow: 1px 1px 1px rgba(255,255,255,.3);
                font-size: 14px;
                border-bottom: 1px solid #BA7F5B;
            }
        </style>
    </head>
    <body>
        <h1>Bad Request</h1>

        <p id="detail">
            For request 'GET /bad-request' [invalid version format: FILES/DOCKER/DOCKER/RESOURCES/BIN:/MNT/C/PROGRAM FILES (X86)/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/ICLS:/MNT/C/PROGRAM FILES/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/ICLS:/MNT/C/WINDOWS/SYSTEM32:/MNT/C/WINDOWS:/MNT/C/WINDOWS/SYSTEM32/WBEM:/MNT/C/WINDOWS/SYSTEM32/WINDOWSPOWERSHELL/V1.0:/MNT/C/PROGRAMDATA/CHOCOLATEY/BIN:/MNT/C/PROGRAM FILES/GIT/CMD:/MNT/C/PROGRAM FILES/MICROSOFT VS CODE/BIN:/MNT/C/PROGRAM FILES (X86)/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/DAL:/MNT/C/PROGRAM FILES/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/DAL:/MNT/C/PROGRAM FILES (X86)/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/IPT:/MNT/C/PROGRAM FILES/INTEL/INTEL(R) MANAGEMENT ENGINE COMPONENTS/IPT:/MNT/C/PROGRAM FILES/JAVA/JDK1.8.0_181/BIN:/MNT/C/PROGRAM FILES/JAVA/JDK1.8.0_191/BIN:/MNT/C/USERS/XXX/.CARGO/BIN:/MNT/C/USERS/XXX/APPDATA/LOCAL/MICROSOFT/WINDOWSAPPS:/MNT/C/PROGRAM FILES/MICROSOFT VS CODE/BIN:/MNT/C/HOME/PATH:/MNT/C/HOME/BIN/MSYS64/MINGW64/BIN:/MNT/C/PROGRAM FILES/DOCKER TOOLBOX:/MNT/C/TOOLS/KUBERNETES-CLI/BIN:/USR/LIB/JVM/DEFAULT/BIN:/USR/BIN/SITE_PERL:/USR/BIN/VENDOR_PERL:/USR/BIN/CORE_PERL:/HOME/XXX/.RVM/BIN&amp;INSTALLED= HTTP/1.0]
        </p>

    </body>
</html>
abelsromero commented 5 years ago

After several remove/uninstall java 11 installed, but for java8 it was impossible. It failed when moving from temp/out to candidate stating that the target path was not a directory. I just resorted to move files manually and now it works.

jvr-ks commented 3 years ago

Installed both sdkman and java 21.0.0.r11-grl as root. Is ok, but only root has access? Not what was expected!

matthunt1984 commented 2 years ago

I had a similar issue to this on WSL1 after upgrading Ubuntu from 18.04 (as SDKMAN needed GLIBC newer than 2.7). Similar to above my issue was related to gzip rather than tar. Resolved with:

Actually those were all 0x1000 already. In gzip 1.10-4ubuntu4 I only had to change the value at offset 0x189 using echo -en '\x10' | sudo dd of=/usr/bin/gzip count=1 bs=1 conv=notrunc seek=$((0x189))

Originally posted by @dreamlayers in https://github.com/microsoft/WSL/issues/8219#issuecomment-1110508016