COMP 3000 Lab 6 2012: Difference between revisions
No edit summary |
No edit summary |
||
Line 27: | Line 27: | ||
P1 C2 ... | P1 C2 ... | ||
P1 C3 ... | P1 C3 ... | ||
Note that the interleaving of output from P1 and P2 can be in any order so long as the sequence for each is always C1, C2, then C3. | Note that the interleaving of output from P1 and P2 can be in any order so long as the sequence for each is always C1, C2, then C3. NOTE: You may want to avoid doing this on a non-local filesystem, e.g., don't put race.txt in your home directory on the Lambda machines. Doing this in a VM should work fine. |
Revision as of 16:00, 5 November 2012
This lab is due on Friday, Nov. 9, at 11:55 PM.
Run the following three commands in bash. (Note the \ is just to note the command continues on the following line.)
x=0; while builtin test $x -lt 50000; do echo "P1 C1 $x"; echo "P1 C2 $x"; \ echo "P1 C3 $x"; let x=$(($x + 1)); done >> race.txt & y=0; while builtin test $y -lt 50000; do echo "P2 C1 $y"; echo "P2 C2 $y"; \ echo "P2 C3 $y"; let y=$(($y + 1)); done >> race.txt &
The following questions are based on these three lines.
- Describe the output of the above lines. In particular, how is the output of the two commands intermingled in the file race.txt?
- How could you modify the lines so that output to the file race.txt continues until a file "done" is created in the current directory (instead of testing the values of x and y)?
- Approximately how many processes do these two lines generate on your system? How can you tell?
- Change each line into a stand-alone shell script with no semicolons.
- Use flock in the shell script versions of the commands to keep the output of the three echo's in the inner loop from being broken apart (make them "atomic"). Thus, in race.txt, you'll have lines starting with:
P1 C1 ... P1 C2 ... P1 C3 ... P2 C1 ... P2 C2 ... P2 C3 ... P2 C1 ... P2 C2 ... P2 C3 ... P1 C1 ... P1 C2 ... P1 C3 ...
Note that the interleaving of output from P1 and P2 can be in any order so long as the sequence for each is always C1, C2, then C3. NOTE: You may want to avoid doing this on a non-local filesystem, e.g., don't put race.txt in your home directory on the Lambda machines. Doing this in a VM should work fine.