Αρχική ΑΕΠΠ - Δομές Δεδομένων Λειτουργικά Συστήματα Δίκτυα Υπολογιστών ΙΙ Βάσεις Δεδομένων Παιδαγωγικά - Διδακτική
Εισαγωγή στα Λ.Σ. Βασικές Δομές Η/Υ Βασικές Δομές Λ.Σ
Διεργασίες Χρονοπρογραμματισμός Συγχρονισμός
Μονοπρογραμματισμός Εναλλαγή Εικονική Μνήμη Κατάτμηση
Ένας δίσκος έχει 8 κεφαλές, 256 κυλίνδρους και 128 τομείς ανά κύλινδρο. Αν κάθε τομές έχει 512 bytes, ποια είναι η χωρητικότητα του δίσκου;
Κάνουμε αντικατάσταση στον τύπο: σύνολο κεφαλών × αριθμός κυλίνδρων × αριθμός τομέων/κύλινδρο × ΚB/τομέα
Έχουμε: 8 x 256 x 128 x 512 = 134217728 bytes ή 128MB
Ένας σκληρός δίσκος έχει 64 κεφαλές, 621 κυλίνδρους και 63 τομείς ανά κύλινδρο, ενώ το μέγεθος κάθε τομέα είναι 512 bytes. Ποια η συνολική χωρητικότητά του;
Ένας σκληρός δίσκος Α έχει 128 κεφαλές, 621 κυλίνδρους και 63 τομείς ανά κύλινδρο, ενώ το μέγεθος κάθε τομέα είναι 512bytes. Ένας δεύτερος σκληρός δίσκος Β έχει 32 κεφαλές, 1242 κυλίνδρους και 63 τομείς ανά κύλινδρο. Το μέγεθος κάθε τομέα είναι 512bytes και στις δύο περιπτώσεις. Τι σχέση έχουν ως προς τη χωρητικότητά τους;
Έστω ένας σκληρός δίσκος με 32 κεφαλές, 1242 κυλίνδρους και 252 τομείς ανά κύλινδρο. Ο δίσκος έχει χωρητικότητα 5GB περίπου. Ποιο είναι το μέγεθος κάθε τομέα;
Έστω σκληρός δίσκος με 32 κεφαλές, 310 κυλίνδρους και 63 τομείς ανά κύλινδρο. Το μέγεθος κάθε τομέα είναι 1ΚΒ. Ο δίσκος, διαμορφώνεται από το λειτουργικό σύστημα, ώστε να έχει συνολικά 156.240 συστοιχίες. Πόσοι τομείς ανήκουν σε κάθε συστοιχία;
A floppy disk has 40 cylinders. A seek takes 6 msec per cylinder moved. If no attempt is made to put the blocks of a file close to each other, two blocks that are logically consecutive (i.e., follow one another in the file) will be about 13 cylinders apart, on the average. If, however, the operating system makes an attempt to cluster related blocks, the mean interblock distance can be reduced to 2 cylinders (for example). How long does it take to read a 100-block file in both cases, if the rotational latency is 100 msec and the transfer time is 25 msec per block?
The time per block is built up of three components: seek time, rotational latency, and transfer time. In all cases the rotational latency plus transfer time is the same, 125 msec. Only the seek time differs. For 13 cylinders it is 78 msec; for 2 cylinders it is 12 msec. Thus for randomly placed files the total is 203 msec, and for clustered files it is 137 msec.
One way to use contiguous allocation of the disk and not suffer from holes is to compact the disk every time a file is removed. Since all files are contiguous, copying a file requires a seek and rotational delay to read the file, followed by the transfer at full speed. Writing the file back requires the same work. Assuming a seek time of 5 msec, a rotational delay of 4 msec, a transfer rate of 8 MB/sec, and an average file size of 8 KB, how long does it take to read a file into main memory then write it hack to the disk at a new location? Using these numbers, how long would it take to compact half of a 16-GB disk?
It takes 9 msec to start the transfer. To read 213 bytes at a transfer rate of 223 bytes/sec requires 2−10 sec (977 msec), for a total of 9.977 msec. Writing it back takes another 9.977 msec. Thus copying a file takes 19.954 msec. To compact half of a 16-GB disk would involve copying 8 GB of storage, which is 220 files. At 19.954 msec per file, this takes 20,923 sec, which is 5.8 hours. Clearly, compacting the disk after every file removal is not a great idea.
Consider a disk with 131,072 bytes per track, a rotation time of 8.33 msec, and an average seek time of 10 msec. Which is the time in milliseconds to read a block of 2K bytes?
The time is the sum of the seek, rotational delay, and transfer times: seek time + rotation delay/2 + (block size in bytes/bytes per track) x rotation delay
So, we have: 10 + 8.33/2 + (2*1024/131072) x 8.33 = 10 + 4.165 + 0,13015625 = 0,13015625 msec
Consider a disk with a mean seek time of 8 msec, a rotational rate of 15,000 rpm, and 262,144 bytes per track. What are the data rates for block sizes of 1KB, 2KB, and 4KB, respectively?
A rotational rate of 15,000rpm gives 60sec/150000rmp = 4msec to go around once. The average access time (in msec) to read k bytes is then: seek time + rotation delay/2 + (block size in bytes/bytes per track) x rotation delay = 8 + 2 + (k / 262144) × 4
.
8 + 2 + (1024 / 262144) × 4 = 10,015625 msec
k (in KB) / read time (in seconds) = 1 / 10,015625x10-3 = 99.84KB/sec
8 + 2 + (2048 / 262144) × 4 = 10,03125 msec
k (in KB) / read time (in seconds) = 2 / 10,03125x10-3 = 199.38KB/sec
8 + 2 + (4096 / 262144) × 4 = 10,062088013 msec
k (in KB) / read time (in seconds) = 4 / 10,062088013x10-3 = 397.53KB/sec
The beginning of a free space bitmap looks like this after the disk partition is first formatted: 1000 0000 0000 0000
(the first block is used by the root directory). The system always searches for free blocks starting at the lowest numbered block, so after writing file A, which uses 6 blocks, the bitmap looks like this: 1111 1110 0000 0000
. Show the bitmap after each of the following additional actions:
1111 1111 1111 0000
1000 0001 1111 0000
1111 1111 1111 1100
1111 1110 0000 1100
Free disk space can be kept track of using a free list or a bitmap. Disk addresses require D bits. For a disk with B blocks, F of which are free, state the condition under which the free list uses less space than the bitmap. For D having the value 16 bits, express your answer as a percentage of the disk space that must be free.
The bitmap requires B bits. The free list requires DF bits. The free list requires fewer bits if DF < B. Alternatively, the free list is shorter if F/B < 1/D, where F/B is the fraction of blocks free. For 16-bit disk addresses, the free list is shorter if 6 percent or less of the disk is free.
Ένας ελεγκτής του συστήματος αρχείων έχει δημιουργήσει τους μετρητές του όπως φαίνονται παρακάτω.
Αριθμός Μπλοκ: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 Σε Χρήση: 1 0 1 0 0 1 0 1 1 0 1 0 0 1 0 Ελεύθεροι: 0 0 0 1 1 1 0 0 0 1 0 1 1 0 1
Υπάρχουν λάθη; Αν ναι, είναι σοβαρά; Γιατί;
Υπάρχουν λάθη στα μπλοκ 1, 5 και 6. Τα μπλοκ 1 και 6 δεν εμφανίζονται ούτε στη λίστα των μπλοκ σε χρήση ούτε στη λίστα των ελεύθερων. Αυτό το πρόβλημα δεν είναι σοβαρό, διότι μπορεί απλά να λυθεί τοποθετώντας τα μπλοκ στη λίστα των ελεύθερων, δηλαδή, κάνοντας τα αντίστοιχα bit 1.
Το πρόβλημα με το μπλοκ 5 είναι πιο σοβαρό διότι το μπλοκ εμφανίζεται και στις δύο λίστες.
Σε ένα σύστημα UNIX, πόσες αναγνώσεις από το δίσκο πρέπει να γίνουν για να διαβαστεί ο κόμβος-i για το αρχείο /usr/ast/courses/os/handout.t
;. Υποθέστε ότι ο κόμβος-i για τον κατάλογο της ρίζας βρίσκεται στη μνήμη. Κανένας από τους άλλους κόμβους-i καταλόγων της διαδρομής δεν βρίσκεται στην μνήμη.
Έχουμε τις παρακάτω αναγνώσεις:
/
(ο κόμβος-i δεν χρειάζεται να διαβαστεί για τη ρίζα, αφού σύμφωνα με την εκφώνηση είναι στη μνήμη ήδη).
/usr
/usr
/usr/ast
/usr/ast
/usr/ast/courses
/usr/ast/courses
/usr/ast/courses/os
/usr/ast/courses/os
/usr/ast/courses/os/handout.t
Συνολικά χρειάζονται 10 αναγνώσεις από το δίσκο.
Copyright 2008 - Άρης Φεργάδης