All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.locationtech.geowave.python.GeoWavePy4JGateway Maven / Gradle / Ivy

There is a newer version: 2.0.1
Show newest version
/**
 * Copyright (c) 2013-2020 Contributors to the Eclipse Foundation
 *
 * 

See the NOTICE file distributed with this work for additional information regarding copyright * ownership. All rights reserved. This program and the accompanying materials are made available * under the terms of the Apache License, Version 2.0 which accompanies this distribution and is * available at http://www.apache.org/licenses/LICENSE-2.0.txt */ package org.locationtech.geowave.python; import java.net.InetAddress; import java.net.UnknownHostException; import java.util.concurrent.TimeUnit; import org.locationtech.geowave.python.cli.PythonRunGatewayOptions; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import py4j.GatewayServer; public class GeoWavePy4JGateway { private static final Logger LOGGER = LoggerFactory.getLogger(GeoWavePy4JGateway.class); /** * Declaring public fields which act as "submodules" */ private final Debug debug = new Debug(); public Debug getDebug() { return debug; } public static void runGateway(final PythonRunGatewayOptions options) throws InterruptedException, UnknownHostException { final GatewayServer server = new GatewayServer( new GeoWavePy4JGateway(), options.getPort(), options.getPythonPort(), InetAddress.getByName(options.getAddress()), InetAddress.getByName(options.getPythonAddress()), GatewayServer.DEFAULT_CONNECT_TIMEOUT, GatewayServer.DEFAULT_READ_TIMEOUT, null); GatewayServer.turnLoggingOn(); server.start(); System.out.println("GeoWave Py4J Gateway started..."); Runtime.getRuntime().addShutdownHook(new Thread() { @Override public void run() { System.out.println("Shutting down GeoWave Py4J Gateway!"); try { server.shutdown(); } catch (final Exception e) { LOGGER.warn("Error shutting down Py4J Gateway", e); System.out.println("Error shutting down Py4J Gateway."); } } }); while (true) { Thread.sleep(TimeUnit.MILLISECONDS.convert(Long.MAX_VALUE, TimeUnit.DAYS)); } } public static void main(final String[] args) throws InterruptedException, UnknownHostException { runGateway(new PythonRunGatewayOptions()); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy