- Clone the repo and cd into it:
git clone <url from the UI>
cd raft
- In
/logs
, make a file called tom_log.txt, jerry_log.txt, and spike_log.txt. In each of those files, paste the following and nothing else:
0 0 set unreachable
1 0 register tom 10000
2 0 register jerry 10001
3 0 register spike 10002
Why: you have to pre-populate the server logs with information about which other servers to contact about elections, or else they just send out broadcasts to no one and keep voting for themselves. This tells the servers who else they're supposed to be contacting.
- Open three terminal windows. In each one, go to the raft directory. Then, in each of the tree, paste one of the following:
python start_server.py tom 10000
python start_server.py jerry 10001
python start_server.py spike 10002
Now you need to wait 10-20 seconds for someone to get elected the leader.
- Open a fourth terminal window and navigate to the raft directory. Type
python start_client.py 10000
. When it says to type your message, typeclient|@get a
That command includes the name of the sender (client), a pipe to delimit the pipe from its port (which the client does not have, hence no number between | an @), an @ to delimit the sender from the message, and then the message "get a", which asks the server to get the value at the key a in the keystore. There is no value at the key a at the moment. This is fine.
The server will respond either with "name|port@" (if you guessed the port of the leader correctly) or "received b'name|port@I am not the leader. The last leader I heard from is some_other_server_name." if it's the latter, shut down the client, and then restart the client pointing at the port of the server indicated in the last message as the leader. Then when you send "client|@get a" you should get back from the server "name|port@" That means you're talking to the leader.
From there you can issue commands like "client|@set a 1". When you send that, the server will probably close the connection on you because it is very rude. However, it will execute and replicate the command (you can verify this by checking the tom_log.txt, jerry_log.txt, and spike_log.txt files, or by sending a command from the client "client|@get a" and confirming that the response includes the 1).