BlueMap

BlueMap

85.1k Downloads

CLI crashes just after reporting "finished"

ComputerJock opened this issue ยท 27 comments

commented

BlueMap Version:
BlueMap-1.0.0-cli.jar

I am using:

  • [12 ] mods (on the rendered world)
    Is this applicable for the CLI? Minecraft was not running at this point. Regardless, here is the list of mods I use:
    fabric-api-0.20.1+build.401-1.16.jar
    fabric-carpet-1.16.3-1.4.10+v200907.jar
    fabricmod_VoxelMap-1.10.10_for_1.16.2.jar
    Hwyla-Mod-Fabric-1.16.2.jar
    litematica-fabric-1.16.2-0.0.0-dev.20200824.031346.jar
    lithium-fabric-mc1.16.2-0.5.4.jar
    malilib-fabric-1.16.2-0.10.0-dev.21+arne.1.jar
    minihud-fabric-1.16.2-0.19.0-dev.20200829.031650.jar
    modmenu-1.14.6+build.31.jar
    WI-Zoom-1.2-MC1.16.2.jar
    worldedit-fabric-mc1.16.2-7.2.0-beta-04.jar
    WorldEditCUI-1.16.2+01.jar

  • [0 ] resourcepacks (in bluemaps config/resourcepack folder)

Description:
This mod really looks promising. I tried it running a fabric server & the game on the same PC (win7x64, core i7 3GHz) and it was beautiful -- but it was impractical due to how slowly the browser rendered/moved/zoomed the map.

I then tried the CLI: BlueMap-1.0.0-cli.jar

I pointed the generated render.conf file to an existing 1.16.2 world. Running
the CLI with the "-r" flag gave a bunch of warnings & then crashed just after
saying "Render finished!". Note: I'm using Openjdk 14.0.2
Perhaps the "exception trying to load chunk..." is because the chunk does not exist?
The world is not entirely connected.

Here's the tail end of all the messages:

[DEBUG] Unexpected exception trying to load chunk ((286, -154)):java.io.IOException: Exception trying to load chunk ((286, -154))    
[INFO] Rendering map '1_16':                                                                                                         
[INFO] Rendered 8226 of 8245 tiles in 37 minutes 44 seconds | 3.633 tiles/s                                                          
[INFO] 99.77% | Estimated remaining time: 5 seconds                                                                                  
[DEBUG] Unexpected exception trying to load chunk ((286, -152)):java.io.IOException: Exception trying to load chunk ((286, -152))    
[DEBUG] Unexpected exception trying to load chunk ((286, -150)):java.io.IOException: Exception trying to load chunk ((286, -150))    
[DEBUG] Unexpected exception trying to load chunk ((286, -148)):java.io.IOException: Exception trying to load chunk ((286, -148))    
[DEBUG] Unexpected exception trying to load chunk ((286, -146)):java.io.IOException: Exception trying to load chunk ((286, -146))    
[DEBUG] Unexpected exception trying to load chunk ((286, -144)):java.io.IOException: Exception trying to load chunk ((286, -144))    
[DEBUG] Unexpected exception trying to load chunk ((280, -164)):java.io.IOException: Exception trying to load chunk ((280, -164))    
[DEBUG] Unexpected exception trying to load chunk ((282, -164)):java.io.IOException: Exception trying to load chunk ((282, -164))    
[DEBUG] Unexpected exception trying to load chunk ((284, -164)):java.io.IOException: Exception trying to load chunk ((284, -164))    
[DEBUG] Unexpected exception trying to load chunk ((286, -164)):java.io.IOException: Exception trying to load chunk ((286, -164))    
[DEBUG] Unexpected exception trying to load chunk ((280, -162)):java.io.IOException: Exception trying to load chunk ((280, -162))    
[DEBUG] Unexpected exception trying to load chunk ((282, -162)):java.io.IOException: Exception trying to load chunk ((282, -162))    
[DEBUG] Unexpected exception trying to load chunk ((284, -162)):java.io.IOException: Exception trying to load chunk ((284, -162))    
[INFO] Render finished!                                                                                                              
[ERROR] Unexpected exception in render-thread!                                                                                       
java.util.concurrent.CompletionException: java.lang.InterruptedException: sleep interrupted                                          
        at de.bluecolored.shadow.benmanes.caffeine.cache.LocalLoadingCache.lambda$newMappingFunction$2(LocalLoadingCache.java:146)   
        at de.bluecolored.shadow.benmanes.caffeine.cache.BoundedLocalCache.lambda$doComputeIfAbsent$14(BoundedLocalCache.java:2344)  
        at java.base/java.util.concurrent.ConcurrentHashMap.compute(ConcurrentHashMap.java:1916)                                     
        at de.bluecolored.shadow.benmanes.caffeine.cache.BoundedLocalCache.doComputeIfAbsent(BoundedLocalCache.java:2342)            
        at de.bluecolored.shadow.benmanes.caffeine.cache.BoundedLocalCache.computeIfAbsent(BoundedLocalCache.java:2325)              
        at de.bluecolored.shadow.benmanes.caffeine.cache.LocalCache.computeIfAbsent(LocalCache.java:108)                             
        at de.bluecolored.shadow.benmanes.caffeine.cache.LocalLoadingCache.get(LocalLoadingCache.java:54)                            
        at de.bluecolored.bluemap.core.mca.MCAWorld.getChunk(MCAWorld.java:202)                                                      
        at de.bluecolored.bluemap.core.mca.MCAWorld.isChunkGenerated(MCAWorld.java:273)                                              
        at de.bluecolored.bluemap.core.world.World.isAreaGenerated(World.java:142)                                                   
        at de.bluecolored.bluemap.core.world.World.isAreaGenerated(World.java:131)                                                   
        at de.bluecolored.bluemap.core.world.World.isAreaGenerated(World.java:122)                                                   
        at de.bluecolored.bluemap.core.render.TileRenderer.render(TileRenderer.java:47)                                              
        at de.bluecolored.bluemap.common.MapType.renderTile(MapType.java:70)                                                         
        at de.bluecolored.bluemap.common.RenderTicket.render(RenderTicket.java:42)                                                   
        at de.bluecolored.bluemap.common.RenderManager.renderThread(RenderManager.java:164)                                          
        at java.base/java.lang.Thread.run(Thread.java:832)                                                                           
Caused by: java.lang.InterruptedException: sleep interrupted                                                                         
        at java.base/java.lang.Thread.sleep(Native Method)                                                                           
        at de.bluecolored.bluemap.core.mca.MCAWorld.loadChunkOrEmpty(MCAWorld.java:220)                                              
        at de.bluecolored.bluemap.core.mca.MCAWorld.lambda$new$0(MCAWorld.java:149)                                                  
        at de.bluecolored.shadow.benmanes.caffeine.cache.LocalLoadingCache.lambda$newMappingFunction$2(LocalLoadingCache.java:141)   
        ... 16 more                                                                                                                  
commented

@ComputerJock
Since mods can alter the way a world is saved, this is also applicable for the CLI, thanks for including them :D

So the error at the end is a small bug, but nothing severe, i'll fix that with the next version ..

Those warnings however are unusual on the cli, while the server is not running. (Usually they only occur if Minecraft saves some chunks at the same time BlueMap tries to read them ..)
Could you maybe send me this file from your world: region/r.8.-6.mca .. it should contain one of the chunks that has failed to load.. Maybe that gives me some more information.

Other than that: All chunks that could be loaded should have been rendered correctly. So your map should be good to go, despite the error in the end :)

commented

@ComputerJock
I believe the attached file did not get uploaded correctly? ^^

(Also, OpenJDK is most likely not the problem)

commented
commented

@ComputerJock
I think GitHub is not able to process E-Mail attachments in general, try to answer on GitHub, not via mail ^^

commented

OK, here's another try. BTW, I noticed that there were several MCA files in the region/ directory that had zero length. I checked another 1.16.2 world and found the same so I guess that's normal.
r.8.-6.mca.zip

commented
commented
commented

Most likely my error report is caused by my running java under the bash shell with Msys2. Some time ago I saw this same sort of issue with another java app.

I appologize for taking up your time.

So I ran two more tests. I used a cmd.exe window and I ran BlueMap-1.0.0-cli.jar with both versions of java:

C:/Program Files/Java/jre1.8.0_181/bin/java.exe
java version "1.8.0_181"
Java(TM) SE Runtime Environment (build 1.8.0_181-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.181-b13, mixed mode)

C:/Program Files/Java/jdk-14.0.2/bin/java.exe
openjdk version "14.0.2" 2020-07-14
OpenJDK Runtime Environment (build 14.0.2+12-46)
OpenJDK 64-Bit Server VM (build 14.0.2+12-46, mixed mode, sharing)

Both ran to completion with no error messages at all. I am guessing that the Msys2 environment has some issue which interferes with java apps.

I then compared the resulting web/ directory. Unfortunately, a simple recursive compare failed because it looks like all of the data/1_16/.../*.json files have a "uuid" string which differed. I picked one such file from each run, removed the uuid string and the files compared identically.

Unfortunately, I still cannot view the map. I tried with two quite recent browsers:

Chromium
Version 87.0.4249.0 (Developer Build) (64-bit)
Portable Firefox
80.0 (64-bit)

In windows explorer, I click on web/index.html
The result is a totally black page
I copied the url from chromium (my default browser) and pasted it into Firefox.
Again the result was a totally black page.

commented

One more note: when I ran a 1.16.2 fabric server with mods:

BlueMap-1.0.0-fabric-1.16.2.jar
fabric-api-0.20.1+build.401-1.16.jar
fabric-carpet-1.16.3-1.4.10+v200907.jar
lithium-fabric-mc1.16.2-0.5.4.jar
worldedit-fabric-mc1.16.2-7.2.0-beta-04.jar

/and/ a Minecraft client on the same machine, I was able to view the map with my browser (chromium -- firefox would probably also worked but I did not try that). As I mentioned though, the map was extremely slow to render in the browser. Most likely, running the server on a different machine would have made an improvement.

commented

So, i tested this with your region-file as well. I also had no warnings, but the map also stayed dark ..

A dark map means that BlueMap did not render anything, so all the tiles are empty.
(So this is nothing browser related)
Also it is worth to note, that the rendering process is absolutely identical between cli and fabric.

I checked the region-file and noticed that every chunk is in a "pre-generated" state, meaning that there are no blocks generated yet. This usually only occurs on the edge of the generated world, but the whole region file (a big chunk of chunks) was like this. I don't know how this happened in your world, but if the rest of the world is the same, it would explain the dark Map :D
(BlueMap does not modify any world data, so it can not have caused this)

commented

Not sure what to tell you. It's a simple test world for 1.16 created (probably) when the first snapshots appeared. It's not huge but it's not just the spawn chunks either. It was last played with MC 1.16.2.

I would expect that something would be visible.

I ran mcaselector-1.12.3.jar on the world's region folder and it displayed what is possibly the entire extent of the overworld.

I've attached
1_16
a screenshot of the mcaselector window if you wish to investigate further. You can download the world (link is probably good for a week) at: https://transferxl.com/00vYPdnB3twj2x

Thank you for taking the time to look at this and, regardless, I will keep my eye on the mod.

commented

Now that I think about it, that world might have been created as a little test world when 1.13 was being developed. I recall messing around with bees. For each subsequent Minecraft release, I think I copied the world, renamed it, and did the "optimize world" option to bring it up to that release. Therefore this world might have gone through 3 upgrades -- from 1.13 to 1.16.

commented

So i tried opening the region-file you sent me (r.8.-6.mca) with mcaselector and it seems like it is one of the fully black (not grey) squares on your screenshot..
If you want me to try to render that map with BlueMap again you can send me either your world or another one of the region files, preferably one that is not fully black on mcaselector :)

commented

Please see the link above for the world download: https://transferxl.com/00vYPdnB3twj2x

commented

Hmm .. i have no problems rendering that map:
image

Seems like i can not reproduce your problem :/

commented

That's probably beyond my expertise. I do see that web\data\1_16\hires\x0\z0.json.gz has other numbers besides -1, 0 & 1 so there is definitely something there. Maybe it's my rather old video card... although only I've only had one sort-of-recent video game that did not work.

Again, thank you for taking the time to look at this, and I am definitely interested in keeping up with your progress.

commented

well you said, other maps work for you .. so i don't think its the video card, right?

No problem, tell me if you figure it out! :)

(I'm keeping this issue open until i fixed that small error you reported ^^)

commented

Very strange. Can you say what browser you use? I'm wondering if my problem might be some sort of interaction with ad blockers. Other apps that used leaflet (and previously Google Maps API) worked fine.

commented

Chrome .. but it also works on Edge and Firefox for me ^^

commented

Thanks for looking into the problem. I don't know what the problem is on my end.

If I get some time, what is the format for the .json files in the data/ directory? I assume each is a tile and it should be relatively easy to convert to a simple format like PPM and convert to PNG to view. Assuming the result is a valid tile, then it's some problem with my browser setup (lots of ad blockers).

commented

they are exactly what the file-ending says .. GZip`ed JSON-Files ..
You can just unpack them with 7zip and then open them with a text editor ..
and the json is a threejs buffergeometry

There are no png or other images in there, since it is 3D and not 2D ^^

commented

There is a difference between the file:// and http:// url's. With the Bluemap served by the Abyss web server, I now see the Bluemap menu and X/Z coordinates. Previously then entire page was black. Now, although I see the menu, the map is still black.

I again started up the Fabric server (without connecting with a Minecraft client). I connected to localhost:8100 and I /do/ see the map rendering in all three browsers: FF, Edge and Chromium.

Why? I have no idea, however there may be an actual problem with accessing the map with file:// Perhaps the javascript expects an actual web server and cannot deal with file:// url's

commented

Ooooohhhhhhhhhhhhhh okay! That changes everything, now i know what went wrong! :D

BlueMap normally uses an internal webserver to host the map .. that is configured to do everything for you, but if you use an other webserver you there is a problem:
The tiles are stored by default GZip compressed but the web-app is asking for the uncompressed files!

To fix your issue you have 3 options:

  • Use the internal webserver: Run the command java -jar bluemap-cli.jar -w to start the webserver (see webserver.conf to configure it)
  • Turn off GZip compression in the render.conf (this increases the size of your rendered map by about 500%), re-render your map and use your webserver
  • Leave GZip compression on and configure your websever correctly: https://github.com/BlueMap-Minecraft/BlueMap/wiki/Configuring-external-web-servers
commented

Interesting.

One other note: I found that chromium is extremely sluggish when compared to either FF or Edge. I'm running the MC client right now and am able to move/scroll the map with ease using FF. I have enabled "use hardware acceleration" for all my browsers but perhaps chromium is not making good use of it. (I've been using chromium rather than chrome -- I don't like companies dictating what extensions I can/can not use) and chromium always reports "some apis are missing" due to something or other (probably like the google map api's are now no longer free to use).

commented

Do you have any estimate of the performance impact on a server with Bluemap?
Currently I'm renting a server and I'm running 1.14.4 Spigot with Dynmap. We've seen issues with lag and rubber-banding when we travel -- especially to brand new chunks. With 1.16.3 around the corner, I'm planning to switch to a Fabric server rather than Spigot. Bluemap seems to be a drop-in replacement for Dynmap.
As an aside, if server performance becomes an issue, perhaps a 2D overhead map could be an option.

I'm very impressed with how the map looks. Very nice!

commented

Depends on the server, especially on the core-count .. if you have 3 cores or more, chances are good that there is no real performance impact.
BlueMap is rendering entirely off the server-thread.
Minecraft is single threaded and BlueMap plugins (by default) leaves 2 cores for the server and renders on the remaining.
So if you have 3 cores, BlueMap runs (slowly) on one render-thread.. If you have 6 BlueMap runs on 4 threads , and so on.
But if you have one or two cores, BlueMap might take away performance from your server while rendering ..

commented

FYI, I installed MS Edge on my win7x64 system -- still no go. My video card is ca. 2011, an AMD HD6950. It's not longer supported by AMD (next time I'll buy Nvidia). Since all three of my browsers show a black screen (I rendered a different world for my last test), I am strongly suspecting that there's some OpenGL feature or video card issue that's required for this much more modern rendering.

It is strange, though, that when I ran the Fabric server & the Minecraft client, I was able to see the map... I don't know. It's a mystery.

One other thought -- I have just used the url file:///C:/Users/imdave/Desktop/Minecraft%20Tools/Downloads/Bluemap/web/index.html

Could that be a problem? I've got a simple web server (Abyss). I'm going to fire that up and use http://localhost/... and see if that could possibly be the issue.