Skip to content
/ is2 Public
forked from mecdcme/is2

An open source runtime environment to execute statistical services

License

Notifications You must be signed in to change notification settings

Nolife999/is2

 
 

Repository files navigation

Build Status Docker hub Docker hub

IS2

A runtime environment to execute statistical services. IS2 is a workbench that offers a set of tools for data analysis and processing.

What you’ll need

In order to build the IS2 application, your environment should fulfill the following requirements:

  • A favorite text editor or IDE
  • JDK 1.8 or later
  • Maven 3.0+
  • Mysql Server 8.0 or later

What you’ll build

IS2 is a workbench that, regardless of the statistical method executed, provides the following functionalities:

  1. Upload and management of input data and metadata;
  2. Setting of variables and parameters needed by an algorithm, written in Java, R or PL/SQL;
  3. Algorithm execution;
  4. Analysis of output data and reports.

The main concepts in the context of IS2 are:

  1. Work Session: a work session is a logical environment that allows to upload and preprocess your data. The system provides a set of functionalities to create new variables by transforming the existing ones, or select a subset of records and/or variables.
  2. Processing Session: by mapping initial data with standardized metadata, input data are transformed in working data. In this step, the user can classify and manage the information to process by: i) assigning specific roles to some variables (e.g. identification variable, classification, core variables); ii) selecting auxiliary information (if needed); iii) setting the model parameters.
  3. Run method: working data, with their standardized data structures, can be processed by one or more iterations of the statistical method. The result of each iteration is stored in standardized data structures (output data).
  4. Analyse output: this process step can be used to perform quality checks and/or to calculate statistical indicators to assess the outcome of each iteration.

How to build

Download and unzip the source code in your workspace IS2_PATH. Before building the application you must create a MySQL database. From the command line go to MySQL installation directory MYSQL_PATH:

cd MYSQL_PATH\bin;
mysql -u db_username -p
mysql> create database is2;

Then create the tables needed to run the application, using the script is2.sql stored in the IS2_PATH/db folder:

mysql> use is2;
mysql> source is2.sql

The script will populate the USER/ROLES tables with the user:

Username: [email protected]
Password: istat

After DB installation, you need to increase the max_allowed_packet parameter in the my.ini configuration file and restart the MySQL Sever:

max_allowed_packet=256M

From your IDE select and open the unzipped maven project. As a first step check the content of the application.properties file, located in the path Other Sources > src/main/resources:

spring.datasource.url = jdbc:mysql://localhost:3306/IS2?useSSL=false&useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
spring.datasource.username = db_username
spring.datasource.password = db_password

Now you can perform your first build of the application. If the build process ends successfully, you are ready to run the application. The application is built using the open source framework Spring Boot, which generates an executable jar (that can be run from the command line). Spring Boot creates a stand-alone Spring based Applications, with an embedded Tomcat, that you can "just run".

java –jar is2.jar

Dockerize the MySQL database

docker build -t i3sessnet/is2-mysql . -f db.Dockerfile
docker run -p 3306:3306 i3sessnet/is2-mysql

Dockerize the web application

docker build -t i3sessnet/is2 . -f app.Dockerfile
docker run -p 8080:8080 i3sessnet/is2 

Docker compose

docker-compose up

The application will be at http://localhost:8080/is2 If you want to inspect the database you can use the Adminer application at http://localhost:8081/

License

IS2 is EUPL-licensed

About

An open source runtime environment to execute statistical services

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 39.9%
  • CSS 24.4%
  • HTML 20.1%
  • JavaScript 7.8%
  • TSQL 4.9%
  • R 2.8%
  • Other 0.1%