Skip to content

Latest commit

 

History

History
155 lines (94 loc) · 6.1 KB

ReadMe.md

File metadata and controls

155 lines (94 loc) · 6.1 KB

Network Project Fall 2021

Teammates

Allison Wu, Brian Koehler, Anurag Akkiraju


Demonstration

Click here to visit our project demonstration video.


Notes

The read me is mainly for running the solution among process instances on localhost, rather than across devices. An external, unprovided script must be used to run the solution across several devices, which may require ssh'ing as well.


Configuration

NOTE: Any change in configuration requires the project to be rebuilt.

The configuration file located at network-project/PeerProcess/src/main/resources/Common.cfg follows the same specifications outlined in the project description. Certify that FileName and FileSize are correct.

For example:

NumberOfPreferredNeighbors 3
UnchokingInterval 5
OptimisticUnchokingInterval 10
FileName thefile
FileSize 2167705
PieceSize 16384

The peers involved can also be configured at network-project/PeerProcess/src/main/resources/PeerInfo.cfg. This file also follows the specification located in the project description.

For example:

1001 localhost 4001 1
1002 localhost 4002 0
1003 localhost 4003 0
1004 localhost 4004 0
1005 localhost 4005 0
1006 localhost 4006 1
1007 localhost 4007 0
1008 localhost 4008 0
1009 localhost 4009 0

If a peer begins with the file, it must have its own directory in network-project/PeerProcess/src/main/resources/ corresponding to its peer id, such as 1001/. This directory should also contain the file it begins with.

For example, following the PeerInfo.cfg shown above, both 1001/ and 1006/ would be found in network-project/PeerProcess/src/main/resources/, and thefile would be located in both of those.


Compilation

Compilation of this project requires the following:

In order to compile the project:

  1. Download the zip file that is submitted.

  2. Unzip the downloaded file.

  3. Launch IntelliJ. You should see the window pictured below.

intellij-launch

  1. Create a New Project, and use Gradle with Java for compilation.

create-new-project

  1. Replace the default src directory with the unzipped src directory provided in the Canvas submission. If you wish to configure anything before building, please refer to the Configuration section.

  2. In the project tree on the left, expand src/main/. There should be two directories inside: java/ and resources/. Right click java/ and select Mark Directory as Sources Root. Then right click resources/ and select Mark Directory as Resources Root. If these options are not available, skip this step.

mark-dir

  1. Now right click PeerProcess/ in the project tree and click the Build Module 'PeerProcess' option.

intellij-build

  1. Open the build tab in the bottom left and ensure that the console reads BUILD SUCCESSFUL (view previous screenshot).

Compilation Without IntelliJ IDEA (For CISE Machines)

If you would instead like to build the project without IntelliJ, follow the instructions below.

  1. Download the zip file that is submitted.

  2. Unzip the downloaded file.

  3. Navigate to <project-name>/src/main/java in your terminal and run the following command: rm -rf ../../../build mkdir ../../../build && javac -d ../../../build/classes/java/main *.java && cd ../../../build && mkdir resources && cd resources && mkdir main && cd main && mkdir 1001 && cp ../../../src/main/resources/PeerInfo.cfg ./PeerInfo.cfg && cp ../../../src/main/resources/Common.cfg ./Common.cfg && cp ../../../src/main/resources/1001/thefile ./1001/thefile && cd ../../classes/java/main/


Execution

The example here will only be with 2 peers. However, as seen in the demonstration video, more peers may be used if configured correctly.

In order to execute the project:

  1. Follow the compilation directions from the previous section.

  2. Navigate to <project-name>/build/classes/java/main/ in the unzipped file from yout terminal.

  3. Run the command java PeerProcess 1001. You should see output similar to the screenshot below.

terminal-first-peer

  1. In order to run a second peer locally, open a separate terminal window and follow steps 2 and 3, but replace 1001 with 1002. The output should be similar too the screenshot below.

terminal-second-peer

  1. After execution, you may find a summary and individual peer logs in <project-name>/build/resources/main/. NOTE: The summary log must be deleted before each run to have an updated version.

Resources folder hierarchy (post-execution)

After executing the solution (see instructions here here), <project-name>/build/resources/main should look similar to the screenshot below.

resources-hierarchy

Hierarchy Description

  1. <project-name>/build/resources/main/<id>
  • Directory containing the peers pieces and file
    • Ex: Peer 1001 has <project-name>/build/resources/main/1001
    • <project-name>/build/resources/main/<id>/pieces
      • Ex: Peer 1001's piece 50 is at <project-name>/build/resources/main/1001/pieces/50
      • Contains all pieces files that make up the file
    • <project-name>/build/resources/main/<id>/<filename>
      • Ex: Peer 1001's completed file, tree.jpg, is at <project-name>/build/resources/main/1001/tree.jpg
      • The path to the target file
  1. <project-name>/build/resources/main/log_peer_<id>
    • Ex: Peer 1001 logs everything to <project-name>/build/resources/main/log_peer_1001
    • Contains all of a peers message and event logs
  2. <project-name>/build/resources/main/summary
    • All peers log their completion statement to this file
  3. All other files in the resources folder are unchanged after compilation