-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Documentation for installing GeoSupport on Linux? #23
Comments
As you've guessed, this message is generated because Gradle chokes while trying to configure machine-specific paths for the build. On the dev branch: I've added some additional info about building Geoclient to the In meantime, please have a look at the comments in Stay tuned and thanks for filing this issue. |
Hi, thank you! Looks like I'm much closer now. I made the various additions, but I'm not sure what you mean by "replacing the original geosupport headers as indicated". I'm looking at the files in geoclient-native/etc and not seeing anything with instructions about that, unless maybe you're referring to this GLUEGEN issue? But I'm building for linux, so still not sure. The build now fails at :
Also, I noticed what could be typos on the dev branch readme:
|
Thanks for pointing these errors out. I'll fix them. Regarding the current build error: this is the Java runtime telling you it can't find the Geosupport and Geoclient shared libraries. Geosupport's libraries for the Linux distribution are under the By default, after successfully running The error you are seeing seems to indicate that Java doesn't know where to find the Geosupport I'm redacting the rest of my original response because it is TMI and confusing to the solution for your issue. |
Address typos discovered by chrismarx (thanks!) and move detailed build documentation to src/doc/BUILD.md.
Thank you for your patience and the fixes! I feel like I'm getting closer... now I'm stuck here:
some kind of c++error? not sure where to go with this |
It looks as though the linker can't find a math library that's part of Linux systems ( In the geoclient source, the file linker.args "-L${gsLibraryPath}", "-lc", "-lm", "-lgeo", "-ledequiv", "-lapequiv", "-lsan", "-lsnd", "-lstExcpt", "-lStdLast", "-lStdUniv", "-lstEnder", "-lstretch", "-lthined" The
Turns out my explanation is relevant only to certain gcc configurations and further obfuscated by the fact that the build relies on Gradle's algorthm for ordering of the separately specified compiler and linker args. Please see the following for more info:
Also, note that when Gradle chokes because the native compiler is angry that Gradle's error message to The naming conventions are such that Can you run the build again with the -i flag and post the result? E.g., from the geoclient project root directory, run $ ./gradlew -i regenerate > build.log 2>&1 Can you also please provide details on your Linux distro? If none of the above makes any sense, feel free to contact me offline and we can talk on the phone for a few minutes which will be faster. |
Apologies for jumping into the thread, but @mlipper, can you share what distro you use internally? We favor Ubuntu LTS ourselves and was wondering if you have any experience getting Geoclient running on 16.04 or 14.04. Also, will it work with OpenJDK or do I need to use Oracle Java? Thanks! |
Hey @jqnatividad , Long-time-no-see! Yes, I have definitely built and run Geoclient on one or both Ubuntu versions (using Vagrant/Virtual Box, Docker, or similar). It was a while ago but basically, all the info described in https://github.com/CityOfNewYork/geoclient/blob/master/src/doc/BUILD.md applies generally to any x86_64 modern Linux distribution. Also, Issue #19 is about using OpenJDK and Issue #18 was about someone creating a Docker container for Geoclient on (I think) Ubuntu. To summarize (from memory):
I realize the docs are spare , so please LMK if you want to talk it through the old fashioned way. BTW, completely unrelated: IMHO, this latest geospatial standardization thing being discussed is on the wrong track. Your proposal in Issue #4 is a much better solution; more scalable, accurate, maintainable, de-duplicating, etc...I've stated my opinion too much already but if you're involved it's worth considering... |
Dunno if you heard, but Ontodia was acquired by OpenGov earlier this year, so been busy with integration and building product. ;) But I'm back and getting caught up again on my home open data community - NYC! Anyway, on geospatial standardization, I put in my 2 cents via the feedback form (https://talk.beta.nyc/t/give-feedback-on-nyc-s-proposed-geospatial-opendata-standards/2179/2), and we're actually putting together something to demo our perspective as it integrates into CKAN. |
Nice! Congratulations! |
Hi, |
https://github.com/kurtraschke/geoclient-docker/blob/master/geoclient-build.patch ./gradlew lspathGS_LIBRARY_PATH From: chris marx [mailto:[email protected]] Hi, — This e-mail, including any attachments, may be confidential, privileged or otherwise legally protected. It is intended only for the addressee. If you received this e-mail in error or from someone who was not authorized to send it to you, do not disseminate, copy or otherwise use this e-mail or its attachments. Please notify the sender immediately by reply e-mail and delete the e-mail from your system. |
I was able to successfully complete the build, the final problems with the math libraries in linux (ubuntu specifically) were indeed the problem, the fix you pointed to here was all I needed to do to finish the build: https://github.com/kurtraschke/geoclient-docker/blob/master/geoclient-build.patch It seems this is a known problem on ubuntu - http://stackoverflow.com/questions/7824439/c-math-linker-problems-on-ubuntu-11-10 Thanks for all the help so far. Now I'm looking at this section: https://github.com/CityOfNewYork/geoclient/blob/dev/src/doc/BUILD.md#java And I'm wondering if there are any more details about what I would be deploying locally, I'm not seeing a standard war file that I would normally deploy to tomcat? |
Now run $ ./gradlew build That should build the deployable war file. It also runs unit and integration tests, some of which use JNI. If you get an UnsatisfiedLinkError, ClassNotFoundException or similar it means that the testLibraryPath is not set correctly. By default it uses the following: testLibraryPath=$GS_LIBRARY_PATH:build/libs:$LD_LIBRARY_PATH The second path element is relative from the project root and gets created by the regenerate task (which actually calls the C build in geoclient-native/build.grade) Please let me know how that goes and we'll figure out how to configure your Servlet container. Matt Sent from my iPhone On Sep 21, 2016, at 9:33 PM, chris marx <[email protected]mailto:[email protected]> wrote: I was able to successfully complete the build, the final problems with the math libraries in linux (ubuntu specifically) were indeed the problem, the fix you pointed to here was all I needed to do to finish the build: https://github.com/kurtraschke/geoclient-docker/blob/master/geoclient-build.patch It seems this is a known problem on ubuntu - http://stackoverflow.com/questions/7824439/c-math-linker-problems-on-ubuntu-11-10 Thanks for all the help so far. Now I'm looking at this section: https://github.com/CityOfNewYork/geoclient/blob/dev/src/doc/BUILD.md#java And I'm wondering if there are any more details about what I would be deploying locally, I'm not seeing a standard war file that I would normally deploy to tomcat? — This e-mail, including any attachments, may be confidential, privileged or otherwise legally protected. It is intended only for the addressee. If you received this e-mail in error or from someone who was not authorized to send it to you, do not disseminate, copy or otherwise use this e-mail or its attachments. Please notify the sender immediately by reply e-mail and delete the e-mail from your system. |
Hi, Ok, the build failed, the dependency for "spring-jsonp-support" was missing. I saw it's not in maven, so went to the github repo, built it and installed it locally in my local maven repo, and added mavenLocal() to the gradle.build. After I did all that, I saw the "TODO" about this in the geoclient-service/build.gradle That solved that problem. But the build still failed after that. The error was:
Now, it's true, that jar is not at the above location. But it is here: http://central.maven.org/maven2/javax/media/jai_core/1.1.3/ I added another maven repo pointing to that url to the geoclient-service/build.gradle, but it had no effect, it seems like gradle is intent on finding that jar at that location. I grepped to try and find where this is being called from, but didn't get any hits. |
Hi Chris, I’ve seen this behavior also for reasons that were not clear to me at the time. I’ve had problems in the past with GeoTools and its use of its own Maven repo. I already created a ticket to get rid of the GeoTools dependency since it is only used for coordinate transformations but didn’t find anything leaner. I’ll try upgrading to the latest version or coming up with a new approach but I may not have time to close it out today**. Regarding use of the spring-jsonp library, I think Ialready know a simple, better solution: use Spring’s built-in support for CORS in the most recent releases. I’m going to upgrade to the latest Spring versions anyway, so hopefully that won’t cause other unintended version conflicts. Would you mind filing a couple of GitHub issues using the descriptions of each particular problem you’ve encountered? I’m most interested in missing documentation for specific tasks and straight-up bugs (like the Ubuntu link issue, missing dependencies, etc.). If you don’t have time to do this yourself, would you mind if I do it by cut and pasting some of the email content we’ve exchanged in the last few days? Thanks, Matt **In the meantime you could try explicitly declaring the jai_core dependency and excluding it from the GeoTools dependency. You mentioned that you’re not familiar with Gradle so no worries if this seems like too much to bite off at once. From: chris marx [mailto:[email protected]] Hi, Ok, the build failed, the dependency for "spring-jsonp-support" was missing. I saw it's not in maven, so went to the github repo, built it and installed it locally in my local maven repo, and added mavenLocal() to the gradle.build. After I did all that, I saw the "TODO" about this in the geoclient-service/build.gradle That solved that problem. But the build still failed after that. The error was: Could not resolve all dependencies for configuration ':geoclient-service:compileClasspath'. Now, it's true, that jar is not at the above location. But it is here: http://central.maven.org/maven2/javax/media/jai_core/1.1.3/ I added another maven repo pointing to that url to the geoclient-service/build.gradle, but it had no effect, it seems like gradle is intent on finding that jar at that location. I grepped to try and find where this is being called from, but didn't get any hits. — This e-mail, including any attachments, may be confidential, privileged or otherwise legally protected. It is intended only for the addressee. If you received this e-mail in error or from someone who was not authorized to send it to you, do not disseminate, copy or otherwise use this e-mail or its attachments. Please notify the sender immediately by reply e-mail and delete the e-mail from your system. |
Sure, I can create some tickets. I was going to suggest the same thing for jsonp issue, Spring 4 added really nice jsonp with controller advices, and cors support as well. Spring boot really cuts down on the configuration too. As for the jai issue, yes I will gave that a try, I'm picking up gradle fairly quickly. In general, I just don't know how much time to invest on my own figuring out problems if they're already known, so I usually opt to post about it, unless it looks straightforward, like the jsonp problem- |
Ok, I gave this a go. The build does complete now. First I tried this:
That didn't fix anything.
And that eventually did the trick. Seemed like I had to clear gradles cache for that work. Interestingly, I thought maybe the jai_core dependency was being pulled as a transitive dependency from another source. A couple of websites mentioned the following method to show a complete transitive dependency tree from gradle: http://stackoverflow.com/a/29671233/228369 So I did that. But the output lacks any reference at all to jai* anything. It might be worth pointing out that the war file is generated in the : ~/git/geoclient/geoclient-service/build/libs folder. Not being familiar with gradle, my first thought was that the war file never got generated, but grepping around did the trick :) I installed jetty, and deployed the war. On startup I get this, which you mentioned I might see duing the tests, but the tests succeeded (or would they not fail upon getting kind of error?):
|
The is issue is that the JVM used to run Jetty cannot find the shared object files for Geosupport and Geoclient. To fix this I recommend the following (container-agnostic) steps:
This means that if you deploy the Geoclient war file into the same Tomcat container (defined in I'm not sure whether this applies to Jetty but unless absolutely necessary, I suggest using virtual hosts and deploying WARs which use the geoclient JNI jar files in-process (through
Let me know how it goes, Matt |
Hi all, I was tinkering with installing GeoSupport on Ubuntu (16.04 in a docker container) and had success calling the My intent is to write node.js bindings for geosupport. https://gist.github.com/chriswhong/2e5f0f41fc5d366ec902613251445b30 |
Hey Chris, Thanks for sharing this information. As an FYI: Geoclient already provides an in-process Java API that you can use locally instead of the REST interface. Like the rest of the Geoclient source, it is not well documented yet, but running on 64-bit Linux, using Java 7 or 8, it provides near or equal performance to native C. Our intention is to eventually provide basic bindings for languages which have basic C integration (Python, Ruby, etc.) and Node certainly falls into that category. JVM languages (Groovy, Jython, JRuby, Clojure, etc..) can already use the various Geoclient API's including the core Function/WorkArea/Field abstractions. I know there's JVM-based Node implementations that might "just work" as well but I don't have any direct experience with them. Please let me know how it goes with your project and if you're interested in providing feedback for or contributing to Geoclient in some way. Thanks, |
Will do. I have about as much experience with java as I do with C (read: none). What are the benefits of using node > java > geosupport instead of just node > geosupport? The obvious is that you have already written the java api, that abstracts the direct communication with geosupport, but to use it I would need to have a more complex environment with both java and node, and the dependency issues that both involve, right? Any pitfalls there? |
You've mentioned the primary benefit: Geoclient already exists and has worked well both in-process and remotely. I'm not sure there is a benefit here but the JRuby, Clojure, etc. communities report platform independence, real threads (w/out GIL) and performance as a few benefits running on the JVM. In this case, I think it depends upon how you're trying to use Geosupport. Are you looking for an easily scripted way to geocode large files on a single machine or are you looking to build an industrial strength distributed batch processor capable 100's of transactions per second (like the one Geosupport provides on the mainframe)? I guess the flip-side of your question is whether your app has to be written in Node if it is intended for this type of use in-process? Another thing to consider is running Geoclient/Tomcat on localhost and accessing it via loopback. This performs well but I agree direct integration is ultimately better. |
I think the most likely use case is ETL, such as in this example: https://github.com/NYCPlanning/dob-permits-geocode We geocode the DOB permits data nightly, and output a shapefile. To avoid The other use case is on-the fly inclusion into the node-js (express) On Sun, Oct 2, 2016 at 1:36 PM, Matthew Lipper [email protected]
|
If you're looking up attribute information based on known identifiers (BIN, BBL) that's already available from a relational database then I'm not sure why you would use Geosupport in the first place; the NYC-domain/context-specific search is awesome but otherwise it's just another type of data source minus: the ability to do actual spatial queries, the support for a well-supported and easy to use query language (SQL, OGC spatial, etc..) and the prepackaged installation. (I'm being dork and exaggerating but my point is that Geosupport scratches a different kind of itch than an RDBMS). In my personal experience, integration with ETL's using asynchronous file streams are often the easiest to maintain and re-use from multiple runtimes regardless of the language in which they're written. Geoclient has been used this and in other in-process ways for a while now. Also there's a big difference between a call to a truly remote host and one that uses the loopback to use HTTP for inter-process communication (yes, I know that this is a bad idea if speed and throughput are your primary concerns). Regardless, I clearly know nothing about your goals/needs for stuff you're working on so I'm just flapping my lips. I like the idea of having dead-simple, low-level bindings for Geosupport for easy integration with popular runtimes so if there's specific things you think would make it more usable for your needs please let me know. Suggestions, contributions, discussions, etc. are always welcome too. |
The readme says that "details are coming soon", I'm wondering if there are any basic pointers for where to put/setup the geosupport library. I tried to build geoclient, but I get:
"java.lang.IllegalArgumentException: Neither path nor baseDir may be null or empty string. path='null' basedir='/home/git/geoclient/geoclient-native"
I suspect this has something to do with it not finding geosupport?
The text was updated successfully, but these errors were encountered: