Secondary Storage Devices
Secondary Storage Devices
Secondary Storage Devices
By Hirdesh 1
• Magnetic Disks
• Optical Disks
• Floppy Disks
• Magnetic Tapes
By Hirdesh 2
Secondary Storage Devices
Two major types of secondary storage devices:
2. Direct Access Storage Devices (DASDs)
– Magnetic Discs
Hard disks (high capacity, low cost, fast)
Floppy disks (low capacity, lower cost, slow)
– Optical Disks
CD-ROM = (Compact disc, read-only memory
3. Serial Devices
– Magnetic tapes (very fast sequential access)
By Hirdesh 3
Storage and Files
• Storage has major implications for DBMS design!
– READ: transfer data from disk to main memory (RAM).
– WRITE: transfer data from RAM to disk.
– Both operations are high-cost operations, relative to in-memory
operations, so DB must be planned carefully!
• Why Not Store Everything in Main Memory?
– Costs too much: Cost of RAM about 100 times the cost of the
same amount of disk space, so relatively small size.
– Main memory is volatile.
– Typical storage hierarchy:
• Main memory (RAM) (primary storage) for currently used
data.
• Disk for the main database (secondary storage).
• Tapes for archiving older versions of the data (tertiary storage).
By Hirdesh 4
Storage Hierarchy
By Hirdesh 5
Units of Measurement
Spatial units:
o byte: 8 bits
o kilobyte (KB): 1024 or 210 bytes
o megabyte (MB): 1024 kilobytes or 220 bytes
o gigabyte (GB): 1024 megabytes or 230 bytes
Time units:
o nanosecond (ns) one- billionth (10-9 ) of a second
o microsecond ( µs) one- millionth (10-6 ) of a second
o millisecond (ms) one- thousandth (10-3 ) of a second
Primary versus Secondary Storage
– Primary storage costs several hundred times as much per
unit as secondary storage, but has access times that are
250,000 to 1,000,000 times faster than secondary storage.
By Hirdesh 6
Memory Hierarchy
– At the primary storage level, the memory hierarchy
includes, at the most expensive end’ cache memory,
which is a static RAM (Random Access Memory).
– The next level of primary storage is DRAM (Dynamic
RAM), The advantage of DRAM is its low cost, lower
speed compared with static RAM.
– Programs normally reside and execute in DRAM.
– Now that personal computers and workstations have 10s
of gigabytes of data in DRA, in some cases, entire
databases can be kept in the main memory (with a backup
copy on magnetic disk), leading to main memory
databases.
By Hirdesh 7
Memory Hierarchy-flash memory
– Flash memory, since 1988 it has become
common, particularly because it is nonvolatile,
using EEPROM (Electrically Erasable Programmable
Read-Only Memory) technology. Its life is 10,000-
1,000,000 times erase… Read/write is fast, but
erase is slow…
– Therefore special arrangements are made for the
file system, regarding file delete or update.
– Capacities up to 128 GB has been realized todate.
By Hirdesh 8
Magnetic Disks
By Hirdesh 9
A Disk Drive
surfaces
Spindle Boom
Read/Write heads
tracks
sector
Surface of disk showing tracks and sectors
By Hirdesh 11
Organization of Disks
• Disk contains concentric tracks.
• Tracks are divided into sectors
• A sector is the smallest addressable unit in
a disk.
By Hirdesh 12
Components of a Disk
Spindle
Tracks
Disk head
❖ The platters spin (say, 90rps).
❖ The arm assembly is Sector
moved in or out to position
a head on a desired track.
Tracks under heads make
a cylinder (imaginary!). Platters
Arm movement
❖ Only one head
reads/writes at any
one time.
Arm assembly
❖ Block size is a multiple
of sector size (which is often
fixed). By Hirdesh 13
Disk Controller
By Hirdesh 15
Cylinders
• A cylinder is the set of tracks at a given
radius of a disk pack.
– i.e. a cylinder is the set of tracks that can be
accessed without moving the disk arm.
• All the information on a cylinder can be
accessed without moving the read/write
arm.
By Hirdesh 16
Cylinders
By Hirdesh 17
Estimating Capacities
By Hirdesh 18
Exercise
• Store a file of 20000 records on a disk with
the following characteristics:
# of bytes per sector = 512
# of sectors per track = 40
# of tracks per cylinder = 11
# of cylinders = 1331
Q1. How many cylinders does the file require
if each data record requires 256 bytes?
Q2. What is the total capacity of the disk?
By Hirdesh 19
Organizing Tracks by sector
6 10
7 3
5 6
4 8 2 7
3 9 9 11
2 5
10 4
1 11 1 8
By Hirdesh 22
Extents
• If there is a lot of room on a disk, it may be
possible to make a file consist entirely of
contiguous clusters. Then we say that the
file is one extent. (very good for sequential
processing)
• If there isn’t enough contiguous space
available to contain an entire file, the file is
divided into two or more noncontiguous
parts. Each part is a separate extent.
By Hirdesh 23
Internal Fragmentation
Internal fragmentation: loss of space
within a sector or a cluster.
• Due to records not fitting exactly in a sector:
e.g. Sector size is 512 and record size is 300
bytes. Either
– store one record per sector, or
– allow records span sectors…
• Due to the use of clusters: If the file size is not a
multiple of the cluster size, then the last cluster
will be partially used.
By Hirdesh 24
Choice of cluster size
Some operating systems allow system
administrator to choose cluster size.
By Hirdesh 25
Organizing Tracks by Block
• Disk tracks may be divided into user-defined blocks rather
than into sectors.
• Blocks can be fixed or variable length.
• A block is usually organized to hold an integral number of
logical records.
• Blocking Factor = number of records stored in a block.
• No internal fragmentation, no record spanning over two
blocks.
• In block-addressing scheme each block of data may be
accompanied by one or more subblocks containing extra
information about the block: record count, last record key
on the block…
By Hirdesh 26
Non-data Overhead
• Both blocks and sectors require non-data overhead
(written during formatting)
• On sector addressable disks, this information
involves sector address, track address, and
condition (usable/defective). Also pre-formatting
involves placing gaps and synchronization marks
between the sectors.
• On block-organized disk, where a block may be of
any size, more information is needed and the
programmer should be aware of some of this
information to utilize it for better efficiency…
By Hirdesh 27
Exercise
• Consider a block-addressable disk with the
following characteristics:
– Size of track 20,000 bytes.
– Nondata overhead per block = 300 bytes.
– Record size = 100 byte.
• Q) How many records can be stored per track
if blocking factor is 10 or 60?
a) 10 (20000/1300*10=150)
b) 60 (20000/6300*60=180)
By Hirdesh 28
The Cost of a Disk Access
The time to access a sector in a track on a surface is
divided into 3 components:
By Hirdesh 29
Seek time
• Seek time is the time required to move the arm to
the correct cylinder.
• Largest in cost.
Typically:
– 5 ms (miliseconds) to move from one track to the next
(track-to-track)
– 50 ms maximum (from inside track to outside track)
– 30 ms average (from one random track to another
random track)
By Hirdesh 30
Average Seek Time (s)-1
• It is usually impossible to know exactly how many
tracks will be traversed in every seek,
– we usually try to determine the average seek time (s)
required for a particular file operation.
• If the starting positions for each access are
random, it turns out that the average seek traverses
one third of the total number of cylinders.
– Why? There are more ways to travel short distance than
to travel long distance…
• Manufacturer’s specifications for disk drives often
list this figure as the average seek time for the
drives.
• Most hard disks today have s under 10 ms, and
high-performance disks have s as low as 7.5 ms. 31
By Hirdesh
Average Seek Time (s)-2
• Seek time depends only on the speed with which
the head rack moves, and the number of tracks that
the head must move across to reach its target.
• Given the following (which are constant for a
particular disk):
– Hs = the time for the I/ O head to start moving
– Ht = the time for the I/ O head to move from one track
to the next
• Then the time for the head to move n tracks is:
• Seek(n)= Hs+ Ht*n
By Hirdesh 32
Latency (Rotational Latency)-1
• Latency is the time needed for the disk to rotate so
the sector we want is under the read/write head.
• Hard disks usually rotate at about 5000-7000 rpm,
– 12-8 msec per revolution.
• Note:
– Min latency = 0
– Max latency = Time for one disk revolution
– Average latency (r) = (min + max) / 2
= max / 2
= time for ½ disk revolution
• Typically 6 – 4 ms, at average
By Hirdesh 33
Rotational Latency-2
• Given the following:
– R = the rotational speed of the spindle (in
rotations per second)
θ = the number of radians through which the
track must rotate
– then the rotational latency θ radians is:
• Latency= (θ/2Π)*(1000/R), in ms
By Hirdesh 34
Transfer Time-1
• Transfer time is the time for the read/write head
to pass over a block.
• The transfer time is given by the formula:
number of sectors
Transfer time = --------------------------------- x rotation time
track capacity in number of sectors
By Hirdesh 40
Fast Sequential Reading
• We assume that blocks are arranged so that there
is no rotational delay in transferring from one
track to another within the same cylinder. This is
possible if consecutive track beginnings are
staggered (like running races on circular race
tracks)
• We also assume that the consecutive blocks are
arranged so that when the next block is on an
adjacent cylinder, there is no rotational delay after
the arm is moved to new cylinder
• Fast sequential reading: no rotational delay after
finding the first block.
By Hirdesh 41
Assuming Fast Reading, Consequently
Reading b blocks:
ii. Sequentially:
s + r + b * btt
insignificant for large files, where b is very large:
⇒ b * btt
vi. Randomly:
b * (s + r + btt)
By Hirdesh 42
Exercise
• Given a file of 30000 records, 1600 bytes
each, and block size 2400 bytes, how does
record placement affect sequential reading
time, in the following cases? Discuss.
i) Empty space in blocks-internal fragmentation.
ii) Records overlap block boundaries.
By Hirdesh 43
Exercise
• Specifications of a disk drive:
– Min seek time, track-to-track = 6ms.
– Average seek time = 18ms
– Rotational delay = 8.3ms
– Transfer time or byte transfer rate=16.7 ms/track or 1229 bytes/ms
– Bytes per sector = 512
– Sectors per track = 40
– Tracks per cylinder = 12 (number of surfaces)
– Tracks per surface = 1331
– Non Interleaving
– Cluster size= 8 sectors
– Smallest extent size = 5 clusters
Q) How long will it take to read a 2048KB file that is
divided into 8000 records, each record 256 bytes?
i) Access the file sequentially, ie. In physical order.
ii) Access the file randomly, in some logical record order.
By Hirdesh 44
Secondary Storage Devices:
Magnetic Tapes
By Hirdesh 45
Characteristics
• No direct access, but very fast sequential
access.
• Resistant to different environmental
conditions.
• Easy to transport, store, cheaper than disk.
• Before it was widely used to store
application data; nowadays, it’s mostly used
for backups or archives.
By Hirdesh 46
MT Characteristics-2
• A sequence of bits are stored on magnetic
tape.
• For storage, the tape is wound on a reel.
• To access the data, the tape is unwound
from one reel to another.
• As the tape passes the head, bits of data are
read from or written onto the tape.
By Hirdesh 47
Reel 1 Reel 2
tape
Read/write head
By Hirdesh 48
Tracks
• Typically data on tape is stored in 9
separate bit streams, or tracks.
• Each track is a sequence of bits.
• Recording density = # of bits per inch (bpi).
Typically 800 or 1600 bpi.
30000 bpi on some recent devices.
By Hirdesh 49
MT recording in detail
8 bits = 1 byte
… 0 0 0 0 …
1 1 1 1
1 1 1 1
0 0 0 0
1 1 1 1 ½”
1 1 1 1
0 0 0 0
…
…
1
0
1
0
1
0
1
0
…
…
parity bit
By Hirdesh 50
Tape Organization
logical record
2400’
EOT
BOT Data blocks Interblock gap marker
marker (for acceleration &
Header block deceleration of tape)
(describes data blocks)
By Hirdesh 51
Data Blocks and Records
• Each data block is a sequence of contiguous
records.
• A record is the unit of data that a user’s
program deals with.
• The tape drive reads an entire block of
records at once.
• Unlike a disk, a tape starts and stops.
• When stopped, the read/write head is over
an interblock gap.
By Hirdesh 52
Example: tape capacity
• Given the following tape:
– Recording density = 1600 bpi
– Tape length = 2400 '
– Interblockgap = ½ "
– 512 bytes per record
– Blocking factor = 25
• How many records can we write on the
tape? (ignoring BOT and EOT markers and
the header block for simplicity)
By Hirdesh 53
Secondary Storage Devices:
CD-ROM
By Hirdesh 54
Physical Organization of CD-ROM
• Compact Disk – read only memory (write once),
R/W is also available.
• Data is encoded and read optically with a laser
• Can store around +600MB data
• Digital data is represented as a series of Pits and
Lands:
– Pit = a little depression, forming a lower level in the
track
– Land = the flat part between pits, or the upper levels
in the track
By Hirdesh 55
Organization of data
• Reading a CD is done by shining a laser at the disc and
detecting changing reflections patterns.
– 1 = change in height (land to pit or pit to land)
– 0 = a “fixed” amount of time between 1’s
LAND PIT LAND PIT LAND
...------+ +-------------+ +---...
|_____| |_______|
..0 0 0 0 1 0 0 1 0 0 0 0 0 0 1 0 0 0 1 0 0 ..
By Hirdesh 56
CD-ROM
∀ • While the speed of CD-ROM readers is
relatively higher, such as 24X(24 times CD audio
speed), the speed of writing is much slower, as
low as 2X.
– Note that the speed of the audio is about 150KB per
second.
∀ •The DVD (Digital Video Disc or Digital
Versatile Disc) technology is based on CD
technology with increased storage density.
• The DVD technology allows two-side medium,
with a storage capacity of up to 10GB.
By Hirdesh 57
CD-ROM
• Because of the heritage from CD audio, the data is stored as
a single spiral track on the CD-ROM, contrary to magnetic
hard disk’s discrete track concept.
• Thus, the rotation speed is controlled by CLV-Constant
Linear velocity. The rotational speed at the center is
highest, slowing down towards the outer edge. Because, the
recording density is the same every where.
• Note that with CLV, the linear speed of the spiral passing
under the R/W head remains constant.
• CLV is the culprit for the poor seek time in CD-ROMs
• The advantage of CLV is that the disk is utilized at its best
capacity, as the recording density is the same every where.
By Hirdesh 58
CD-ROM
• Note that: Since 0's are represented by the length
of time between transitions, we must travel at
constant linear velocity (CLV)on the tracks.
• Sectors are organized along a spiral
• Sectors have same linear length
• Advantage: takes advantage of all storage space
available.
• Disadvantage: has to change rotational speed
when seeking (slower towards the outside)
By Hirdesh 59
CD-ROM
Question: Why does it take only 70 minutes of
playing time in an CD audio.
∀ • Ans.: If the sound frequency is 20 kilohertz, we
need twice as much frequency for sampling
speed to reconstruct the sound wave. Each
sample may take up to 2 bytes.
– -An accepted standard allows a sampling speed of
44100 times per second, which requires 88200 bytes
for 2 bytes per sample. For stereo, this becomes
176400 bytes per second. If
– -If the capacity is about 600MB, you can compute
number of minutes required…
By Hirdesh 60
Addressing
• 1 second of play time is divided up into 75
sectors.
• Each sector holds 2KB
• 60 min CD:
60min * 60 sec/min * 75 sectors/sec =
270,000 sectors = 540,000 KB ~ 540 MB
• A sector is addressed by:
Minute:Second:Sector
e.g. 16:22:34
By Hirdesh 61
File Structures for CD-ROM
By Hirdesh 64
File Structures for CD-ROM
• A forth method, assume directories as files as well
and use a special index that organizes the
directories and the files into a hierarchy where a
simple parental index indicates the relationship
between all entries.
Rec Number File or dir name Parent
0 Root
1 Subdir1 0
2 Subdir11 1
3 Subdir12 1
4 File11 1
5 File 0
6 Subdir2 0
By Hirdesh 65
Representation of individual files on CD-ROM
By Hirdesh 66
Representation of individual files on CD-ROM
By Hirdesh 67
A journey of a Byte
and
Buffer Management
By Hirdesh 68
A journey of a byte
• Suppose in our program we wrote:
outfile << c;
• This causes a call to the file manager (a part of
O.S. responsible for I/O operations)
• The O/S (File manager) makes sure that the byte is
written to the disk.
• Pieces of software/hardware involved in I/O:
– Application Program
– Operating System/ file manager
– I/O Processor
– Disk Controller
By Hirdesh 69
• Application program
– Requests the I/O operation
• Operating system / file manager
– Keeps tables for all opened files
– Brings appropriate sector to buffer.
– Writes byte to buffer
– Gives instruction to I/O processor to write data from this buffer
into correct place in disk.
– Note: the buffer is an exact image of a cluster in disk.
• I/O Processor
– a separate chip; runs independently of CPU
– Find a time when drive is available to receive data and put dat in
proper format for the disk
– Sends data to disk controller
• Disk controller
– A separate chip; instructs the drive to move R/W head
– Sends the byte to th surface when the proper sector comes under
R/W head.
By Hirdesh 70
Buffer Management
• Buffering means working with large chunks of
data in main memory so the number of accesses to
secondary storage is reduced.
• Today, we’ll discuss the System I/O buffers.
These are beyond the control of application
programs and are manipulated by the O.S.
• Note that the application program may implement
its own “buffer” – i.e. a place in memory
(variable, object) that accumulates large chunks of
data to be later written to disk as a chunk.
• Read Section 4.2 for using classes to manipulate
program buffers.
By Hirdesh 71
System I/O Buffer
Data transferred
by blocks
Secondary
Storage Buffer Program
Data transferred
by records
Temporary storage in MM
for one block of data
By Hirdesh 72
Buffer Bottlenecks
• Consider the following program segment:
while (1) {
infile >> ch;
if (infile.fail()) break;
outfile << ch;
}
• What happens if the O.S. used only one I/O buffer?
⇒ Buffer bottleneck
• Most O.S. have an input buffer and an output
buffer.
By Hirdesh 73
Buffering Strategies
• Double Buffering: Two buffers can be used to
allow processing and I/O to overlap.
– Suppose that a program is only writing to a disk.
– CPU wants to fill a buffer at the same time that I/O is
being performed.
– If two buffers are used and I/O-CPU overlapping is
permitted, CPU can be filling one buffer while the other
buffer is being transmitted to disk.
– When both tasks are finished, the roles of the buffers
can be exchanged.
• The actual management is done by the O.S.
By Hirdesh 74
Other Buffering Strategies
• Multiple Buffering: instead of two buffers any
number of buffers can be used to allow processing
and I/O to overlap.
• Buffer pooling:
– There is a pool of buffers.
– When a request for a sector is received, O.S. first looks
to see that sector is in some buffer.
– If not there, it brings the sector to some free buffer. If
no free buffer exists, it must choose an occupied buffer.
(usually LRU strategy is used)
By Hirdesh 75