OBP API Setup for Fault Tolerance - OpenBankProject/OBP-API GitHub Wiki
- NGINX Configuration for Load Balancing
- Create file /etc/nginx/sites-available/api
- Configure as follows
upstream backend {
least_conn;
server host1:8080; # The name of the server shall be changed as appropriate
server host2:8080;
server host3:8080;
}
server {
server_name obptest.com www.obptest.com; # The server name should be changed as appropriate
access_log /var/log/nginx/api.access.log;
error_log /var/log/nginx/api.error.log;
location / {
proxy_pass http://backend/;
}
location /obp/v2.1.0/sandbox/data-import {
proxy_pass http://backend/;
}
}
- Zookeeper/Kafka Cluster Setup
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 the topics
bin/kafka-topics.sh --create --zookeeper host1:2181,host2:2181,host3:2181 --replication-factor 1 --partitions 1 --topic Request
bin/kafka-topics.sh --create --zookeeper host1:2181,host2:2181,host3:2181 --replication-factor 1 --partitions 1 --topic Response
- OBP-API Configuration
- Edit the OBP-API/src/main/resources/props/default.props so that it contains the following lines. This should be done on each node.
connector=kafka
kafka.zookeeper_host=localhost:2181
kafka.request_topic=Request
kafka.response_topic=Response
- Start the server
cd OBP-API
mvn jetty:run
OBP-JVM
- Build the package
cd OBP-JVM
mvn install
- Run the demo
java -jar obp-ri-demo/target/obp-ri-demo-2016.9-SNAPSHOT-jar-with-dependencies.jar&
Here be aware that the name of the jar file might be different, so make sure to use the correct name of the jar file
OBP-Kafka-Python
- Run from the command line
cd OBP-Kafka-Python
python server.py
To test the setup, try a request
http://localhost:8080/obp/v2.0.0/banks