-
Notifications
You must be signed in to change notification settings - Fork 435
OBP API Install Guide Bare Metal
- Instructions assume Debian Jessie server (but should work on other GNU/Linux distributions or UNIX as well)
-
Install git, maven, java 8, Jetty 9
-
Clone the OBP-API source code from the repositoty
git clone https://github.com/OpenBankProject/OBP-API.git
-
Change the working directory to
OBP-API
and copy the configuration filecd OBP-API cp src/main/resources/props/sample.props.template src/main/resources/props/default.props
-
Edit the configuration file
src/main/resources/props/default.props
and uncomment the following linesconnector=mapped db.driver=org.h2.Driver db.url=jdbc:h2:./lift_proto.db;DB_CLOSE_ON_EXIT=FALSE hostname=http://127.0.0.1:8080
-
Comment out the following lines in the configuration file
#db.driver=org.postgresql.Driver #db.url=jdbc:postgresql://localhost:5432/dbname?user=dbusername&password=thepassword
-
Build the
WAR
package for the OBP-APImvn package
Note that the packaging take a few minutes to finish.
-
When the packaging is completed, you will find the
OBP-API-1.0.war
file under the directoryOBP-API/target/
-
(Optional) If you have to change settings on the configuration file after the application has been packaged, you can update the configuration in the packaged
WAR
file like so-
First, make a directory structure as follows
mkdir -p WEB-INF/classes/props/
-
Copy the edited props file to the
props
directorycp default.props WEB-INF/classes/props/
-
Update the
default.props
file inside the package using thejar
commandjar uf /path/to/package/OBP-API-1.0.war WEB-INF/classes/props/default.props
-
-
To run the application on Jetty, copy the
OBP-API-1.0.war
file to the/var/lib/jetty9/webapps
directory and rename it asROOT.war
-
You can now point your browser to
http://localhost:8080
- This assumes that Docker Community Edition or Docker Enterprise Edition is installed on the server
-
Using the steps from above, make the packaged OBP API software ready
-
Run the OBP API package inside the Jetty 9 Docker container (whose official image can be found on Docker Hub https://hub.docker.com/_/jetty/). You may want to change the container name or port forwarding as per your requirements.
docker run -d \ --name obp-api \ -v /path/to/package/OBP-API-1.0.war:/var/lib/jetty/webapps/ROOT.war \ -p 8080:8080 \ jetty
-
You can now point your browser to
http://localhost:8080
- Instructions in this section assume that you have a PostgreSQL (or Oracle) database setup on the local server
- Following instructions about database creation are for PostgreSQL only. Please use the equivalent commands if you have an Oracle DB
-
Create a database on PostgreSQL
root@sandbox ~ # sudo -i -u postgres postgres@sandbox:~$ psql postgres=# CREATE DATABASE <dbname>; postgres=# CREATE USER <username> WITH PASSWORD 'xxx'; postgres=# GRANT ALL PRIVILEGES ON DATABASE <dbname> to <username>;
-
Edit the API configuration file
default.props
so that the API uses the local database. Uncomment the following lines in the filedb.driver=org.postgresql.Driver db.url=jdbc:postgresql://localhost:5432/dbname?user=dbusername&password=thepassword
-
Make sure to replace
dbname
,dbusername
, andthepassword
as per your database's configuration -
Comment out the following lines
#db.driver=org.h2.Driver #db.url=jdbc:h2:./lift_proto.db;DB_CLOSE_ON_EXIT=FALSE
-
Copy the edited props file to the
props
directorycp default.props WEB-INF/classes/props/
-
Update the
default.props
file inside the package using thejar
commandjar uf /path/to/package/OBP-API-1.0.war WEB-INF/classes/props/default.props
-
To run the application on Jetty, copy the
OBP-API-1.0.war
file to the/var/lib/jetty9/webapps
directory and rename it asROOT.war
-
You can now point your browser to
http://localhost:8080
- This assumes that Docker Community Edition or Docker Enterprise Edition is installed on the server
-
Edit the API configuration file
default.props
so that the API uses the PostgreSQL container. Update the following line in the filedb.url=jdbc:postgresql://obp-postgres:5432/obp-api-db?user=obp-api-db-user&password=thepassword
-
Replace
obp-postgres
,obp-api-db
,obp-api-db-user
, andthepassword
as required (but make sure that they are the same as the respective values of the environment variables for the PostgreSQL container below) -
Update the
default.props
file inside the package using thejar
commandjar uf /path/to/package/OBP-API-1.0.war WEB-INF/classes/props/default.props
-
Run PostgreSQL using the
postgres:9.5
official Docker image from Docker Hub. Use a local directory and map it to the/var/lib/postgresql/data
of the container to persist the data.docker run -d \ --name obp-postgres \ -v /path/to/data/directory/dbdata:/var/lib/postgresql/data \ -e POSTGRES_USER=obp-api-db-user \ -e POSTGRES_PASSWORD=thepassword \ -e POSTGRES_DB=obp-api-db \ postgres:9.5
-
Run the OBP API package inside the Jetty 9 Docker container (whose official image can be found on Docker Hub https://hub.docker.com/_/jetty/). You may want to change the container name or port forwarding as per your requirements.
docker run -d \ --name obp-api \ --link obp-postgres:obp-postgres \ -v /path/to/obp/OBP-API/target/OBP-API-1.0.war:/var/lib/jetty/webapps/ROOT.war \ -p 8080:8080 \ jetty9
-
You can now point your browser to
http://localhost:8080
-
Akka is a toolkit and runtime for building highly concurrent, distributed, and resilient message-driven applications on the JVM. See http://akka.io
-
To use Akka, you want to have two different machines:
- One considered
remote
which stores the data - One considered
local
which is the public facing side of the API, where your users will connect
- One considered
-
Both run current versions of the Open Bank Project API, but configured and run differently.
- Not all models have been ported yet to be retrieved via Akka. See
modelsRemotedata
insrc/main/scala/bootstrap/liftweb/Boot.scala
to get a current list.
- Configure
src/main/resources/default.props
:
# Remote end gets data 'locally'
remotedata.enable=false
# Your remote's external IP address
remotedata.hostname=xx.xx.xx.xx # Replace with external IP address of the host
# Arbitrary port of your choosing
remotedata.port=5448
# Optionally configure postgres, otherwise file-based H2 will be used
remotedata.db.driver=org.postgresql.Driver
remotedata.db.url=jdbc:postgresql://localhost:5432/dbname?user=user&password=password
#!/bin/sh
cd ${HOME}/OBP-API/ && /usr/bin/nohup /usr/bin/mvn compile exec:java -Dexec.mainClass="code.remotedata.RemotedataActors" -Dexec.args="standalone" > ${HOME}/akka_remote_api.log &
- You can run with above using this unit:
obp-remotedata.service
[Unit]
Description=Open Bank Project Remotedata Standalone
[Service]
Type=simple
User=deploy
Group=deploy
SyslogIdentifier=obp-remotedata
Restart=on-failure
WorkingDirectory=/home/deploy/OBP-API
ExecStart=/usr/bin/mvn compile exec:java -Dexec.mainClass=code.remotedata.RemotedataActors -Dexec.args=standalone
[Install]
WantedBy=multi-user.target
- Configure
src/main/resources/default.props
:
# Local end gets data remotely
remotedata.enable=true
# Your remote's public IP address
remotedata.hostname=xx.xx.xx.xx # Replace with external IP address of the remote host
# Arbitrary port of your choosing, has to match remote above
remotedata.port=5448
# Timeout for connection attempts
remotedata.timeout = 1
#!/bin/sh
cd ${HOME}/OBP-API/ && /usr/bin/nohup /usr/bin/mvn jetty:run -Djetty.port=8080 -DskipTests > ${HOME}/akka_local_api.log &
-
Optionally, like the steps in the previous sections, copy the edited props file to the
props
directorycp default.props WEB-INF/classes/props/
-
Update the
default.props
file inside the package using thejar
commandjar uf /path/to/package/OBP-API-1.0.war WEB-INF/classes/props/default.props
-
To run the application on Jetty, copy the
OBP-API-1.0.war
file to the/var/lib/jetty9/webapps
directory and rename it asROOT.war
- In this section we assume Debian Jessie server for hosting the OBP API, PostgreSQL host, Zookeeper cluster and Kafka cluster in place
-
Kafka binary can be downloaded from https://kafka.apache.org/downloads
-
The Zookeeper/Kafka cluster is deployed on 3 nodes. The following configurations need to be done on each of the three nodes
-
Zookeeper configuration
- Inside the Kafka directory, edit the file conf/zookeeper.properties and include these lines
dataDir=/home/user/zookeeper
server.1=host1:2888:3888 # The name of the servers shall be changed as appropriate
server.2=host2:2888:3888
server.3=host3:2888:3888
initLimit=5
syncLimit=2
- Create a
myid
file under dataDir which is /home/user/zookeeper in this example
echo “1” > /home/user/zookeeper/myid #Insert unique id’s on each of the machines
- Start the zookpeer daemons on each of the 3 machines
bin/zookeeper-server-start.sh config/zookeeper.properties &
- Kafka Configuration
Inside the Kafka directory, edit the file conf/server.properties and include these lines
broker.id=1 # The broker.id should be unique for each host
num.partitions=4
zookeeper.connect=host1:2181,host2:2181,host3:2181
- Start the kafka broker daemons on all the machines
bin/kafka-server-start.sh config/server.properties &
-
Create two topics named
Request
andResponse
on the Kafka cluster (this assumes a 3-host cluster, please adjust as necessary)bin/kafka-topics.sh --create --zookeeper host1:2181,host2:2181,host3:2181 \ --replication-factor 3 --partitions 3 --topic Request bin/kafka-topics.sh --create --zookeeper host1:2181,host2:2181,host3:2181 \ --replication-factor 3 --partitions 3 --topic Response
-
Rename the
default.props
file asproduction.default.props
-
Change the
connector
and include settings for Kafka and Zookeeper clustersconnector=kafka_JVMcompatible # Address to be used by consumer kafka.zookeeper_host=zookeeper_cluster:2181 # Replace zookeeper_cluster as necessary # Address to be used by producer kafka.host=kafka_cluster:9092 # Replace kafka_cluster as necessary kafka.request_topic=Request kafka.response_topic=Response
-
Copy the edited props file to the
props
directorycp production.default.props WEB-INF/classes/props/
-
Update the
default.props
file inside the package using thejar
commandjar uf /path/to/package/OBP-API-1.0.war WEB-INF/classes/props/production.default.props
-
To run the application on Jetty, copy the
OBP-API-1.0.war
file to the/var/lib/jetty9/webapps
directory and rename it asROOT.war
-
You can now point your browser to
http://localhost:8080