liquibase.example.StartH2Main Maven / Gradle / Ivy
package liquibase.example;
import java.lang.reflect.InvocationTargetException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.concurrent.TimeUnit;
/**
* Wrapper around the h2 console for use in the "examples" directory
*/
@SuppressWarnings("java:S2189")
public class StartH2Main {
private static final String dbPort = "9090";
private static final String webPort = "8090";
private static final String username = "dbuser";
private static final String password = "letmein";
public static void main(String[] args) throws Exception {
System.out.println("Starting Example H2 Database...");
System.out.println("NOTE: The database does not persist data, so stopping and restarting this process will reset it back to a blank database");
System.out.println();
try {
Class.forName("org.h2.Driver");
} catch (ClassNotFoundException e) {
String msg = "ERROR: H2 was not configured properly. To use Liquibase and H2, you need to have the JDBC driver .jar file. Liquibase includes the H2 in-memory database and the h2-.jar file in liquibase/lib. Learn more at https://docs.liquibase.com/";
System.out.println(msg);
throw e;
}
try (Connection devConnection = DriverManager.getConnection("jdbc:h2:mem:dev", username, password);
Connection intConnection = DriverManager.getConnection("jdbc:h2:mem:integration", username, password)) {
startTcpServer();
Object webServer = startWebServer();
String devUrl = createWebSession(devConnection, webServer, true);
String intUrl = createWebSession(intConnection, webServer, false);
System.out.println("Connection Information:" + System.lineSeparator() +
" Dev database: " + System.lineSeparator() +
" JDBC URL: jdbc:h2:tcp://localhost:" + dbPort + "/mem:dev" + System.lineSeparator() +
" Username: " + username + System.lineSeparator() +
" Password: " + password + System.lineSeparator() +
" Integration database: " + System.lineSeparator() +
" JDBC URL: jdbc:h2:tcp://localhost:" + dbPort + "/mem:integration" + System.lineSeparator() +
" Username: " + username + System.lineSeparator() +
" Password: " + password + System.lineSeparator() +
"" + System.lineSeparator() +
"Opening Database Console in Browser..." + System.lineSeparator() +
" Dev Web URL: " + devUrl + System.lineSeparator() +
" Integration Web URL: " + intUrl + System.lineSeparator());
while (true) {
try {
Thread.sleep(TimeUnit.SECONDS.toMillis(60));
} catch (InterruptedException interruptedException) {
Thread.currentThread().interrupt();
}
}
} catch (Throwable e) {
e.printStackTrace();
System.exit(-1);
}
}
protected static void startTcpServer() throws Exception {
final Class> serverClass = Class.forName("org.h2.tools.Server");
final Object tcpServer = serverClass.getMethod("createTcpServer", String[].class)
.invoke(null, (Object) new String[]{"-tcpAllowOthers", "-tcpPort", dbPort});
tcpServer.getClass().getMethod("start")
.invoke(tcpServer);
}
protected static Object startWebServer() throws Exception {
final Class> serverClass = Class.forName("org.h2.tools.Server");
final Object webServer = Class.forName("org.h2.server.web.WebServer").newInstance();
Object web = serverClass.getConstructor(Class.forName("org.h2.server.Service"), String[].class).newInstance(webServer, (Object) new String[]{"-webPort", webPort});
web.getClass().getMethod("start").invoke(web);
return webServer;
}
private static String createWebSession(Connection connection, Object webServer, boolean openBrowser) throws Exception {
final Class> serverClass = Class.forName("org.h2.tools.Server");
String url = (String) webServer.getClass().getMethod("addSession", Connection.class).invoke(webServer, connection);
if (openBrowser) {
try {
serverClass.getMethod("openBrowser", String.class).invoke(null, url);
} catch (Exception e) {
String message = e.getMessage();
if (message == null && e.getCause() != null) {
message = e.getCause().getMessage();
}
System.out.println("Cannot open browser: "+ message);
System.out.println("");
}
}
return url;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy