-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME~
50 lines (44 loc) · 2.82 KB
/
README~
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
LAB PROJECT OF DISTRIBUTED SYSTEMS
Introduction
------------
The project aims to implement a distributed systems with three clients, three databases and a "middleware".
The middleware has three nodes and each nodes correspond to a database and a client.
Databases are simply replicas of each others and all databases contain 3 integer objects.
Objects are stored in an integer array. Clients and middleware called the objects with their indexes.
Clients cannot communicate directly to the databases. They have to communicate via middleware.
When client requests to read an object it tries to connect to local database.
When client requests to change an object all nodes communicate each other and change the all replicas of databases.
Structure of Nodes
------------------
Each nodes consist of 3 parts, a sender and two receivers.
Sender of a node gets requests from the client and forwards to the one receiver of each other nodes.
all receivers communicate only one sender.
For example:
first receiver of first node communicates sender of second node
second receiver of first node communicates sender of third node
first receiver of second node communicates sender of first node
second receiver of second node communicates sender of third node
first receiver of third node communicates sender of second node
second receiver of third node communicates sender of first node
Initially sender checks the online nodes.
If there is at least one online node it locks mutexes of all objects, take the informations and release the mutexs.
When initialization done it waits request from client.
When a sender gets a reading request it can handle locally.
It simply locks the mutex of corresponding objects then read the object and release the mutex.
When a sender gets a writing request it should communicate other nodes with some steps.
1. Firstly it tries to reconnect offline nodes and sync the database.
2. it locks the mutex of corresponding object.
3. it requests to lock the mutex to receivers of online node(s) and waits for respons.
4. If the sender receives that one of node couldn't lock the mutex,
Then it unlock the mutex, send message to other nodes, wait for a random time and go back th first step.
5. If it cannot receive a respons then it assumes that connection failed and continues with this assumption.
6. If everything is OK, then it sends message to other nodes, change the object and unlock the mutex.
receivers are simply listeners. They wait simple commands from senders.
When a command is received, receiver tries the job and send back feedback to sender.
Client Instruction
------------------
1. At the beginning of the program client should enter IP and port numbers of each nodes.
2. When connection settled client can use three commands:
READ <index_of_object>
ASSIGN <index_of_object> <integer_value>
ADD <index_of_object> <integer_value>