• Tidak ada hasil yang ditemukan

Sistem Operasi 11. Implentasi File system. Antonius Rachmat C, S.Kom, M.Cs

N/A
N/A
Protected

Academic year: 2021

Membagikan "Sistem Operasi 11. Implentasi File system. Antonius Rachmat C, S.Kom, M.Cs"

Copied!
32
0
0

Teks penuh

(1)

Sistem Operasi 11

“Implentasi File system”

(2)

Struktur File System

• Karakteristik penting dari disk :

– Disk tersebut dapat ditulis ulang di disk tersebut, hal ini memungkinkan untuk membaca, memodifikasi, dan menulis di disk tersebut

– Dapat diakses langsung ke setiap block di disk. Hal ini memudahkan untuk mengakses setiap file baik secara berurut maupun tidak berurut, dan berpindah dari satu file ke file lain dengan hanya mengangkat head disk dan menunggu disk berputar

• Membuat algoritma dan struktur data yang

memetakan struktur logical file system ke tempat

penyimpanan sekunder

(3)

Struktur File System

• I/O control (driver device dan interrupt handler)

– Driver device adalah perantara komunikasi antara sistem operasi dengan perangkat keras

• Basic file system

– Mengeluarkan perintah generic ke device driver baca dan tulis pada suatu block dalam disk

• File-organization module

– Informasi tentang logical address dan physical address dari file tersebut, mengatur juga sisa disk dengan melacak alamat yang belum dialokasikan dan menyediakan alamat tersebut saat user ingin menulis file ke dalam disk

• Logical file system

– tingkat ini berisi informasi tentang simbol nama file, struktur dari direktori, proteksi dan sekuriti dari file tersebut

(4)
(5)
(6)
(7)

Directory Implementation

• Linear list dari nama-nama file dengan pointer

ke data blocks.

– simple to program

– time-consuming to search & execute

– Solusi : linked list dan “Software Cache”

• Hash Table – linear list dengan hash data

structure.

– mengurangi directory search time

– collisions – situasi dimana dua file names hash ke lokasi yg sama

– Bersifat fixed size dan dan ketergantungan dari fungsi hash dengan ukuran hash table

(8)

Contoh Directory di Linux

• "/“ direktori root

• /bin perintah binari esensial • /boot file statis dari boot loader • /dev device files

• /etc konfigurasi sistem host-specific

• /lib shared libraries essential dan modul kernel

• /mnt mount point untuk me-mount suatu file system sementara • /opt tambahan paket aplikasi piranti lunak

• /sbin sistem binari esensial • /tmp file sementara

• /usr secondary hierarchy • /var data variabel

(9)

/bin

• /bin mengandung

perintah-perintah yang dapat digunakan baik itu oleh sistem

administrasi dan oleh users. Dapat juga

mengandung perintah-perintah yang dipakai secara tidak langsung oleh scripts.

• Tidak boleh ada sub-direktori di /bin

• cat perintah untuk mengkonkatenasi file • chgrp perintah untuk mengubah

kepemilikan file group

• chmod perintah untuk mengubah ijin akses file

• chown perintah untuk mengubah kepemilikan file dan group

• cp perintah untuk mengcopy file dan direktori

• date perintah untuk mencetak waktu sistem

• dd perintah untuk men-convert dan meng-copy file

• df perintah untuk melaporkan penggunaan ruang disk

• dmesg perintah untuk mencetak pesan kernel

• echo perintah untuk menampilkan sebaris teks

(10)

Perintah di /bin

• kill perintah untuk mengirim signal ke process

• login perintah untuk memulai masuk ke dalam sistem • ls perintah untuk mendaftar isi direktori

• mkdir perintah untuk membuat direktori baru

• more perintah untuk melihat halaman per halaman • mount perintah untuk mount file system

• mv perintah untuk memindahkan/rename file

• pwd perintah untuk mencetak nama direktori yg sedang aktif • rm perintah untuk menghapus file atau direktori

• rmdir perintah untuk menghapus direktori kosong • su perintah untuk berganti user ID

• umount perintah untuk unmount filesystem

(11)

/boot, /dev, /etc

• Direktori ini mengandung semua yang diperlukan untuk proses boot kecuali konfigurasi file dan map installer. • /boot menyimpan data yang digunakan sebelum kernel

mulai mengeksekusi program user-mode. /boot juga berisi sektor saved master boot, sektor map files, dan data lain yang tidak di-edit langsung dengan tangan. • /dev adalah lokasi dari suatu file khusus piranti keras. • /etc mengandung konfigurasi file dan direktori yang

spesifik ke current system

– Tidak ada binari yang bolah diletakkan di bawah /etc

• /home adalah suatu konsep standar, tetapi juga merupakan site-specific file system.

(12)

/lib, /mnt

• /lib adalah direktori yang mengandung shared library image yang diperlukan untuk mem-boot sistem dan menjalankan perintah dalam root file system, contoh: dengan binari dalam /bin dan /sbin

• /mnt disediakan agar sistem administrasi bisa secara sementara me-mount filesystem sesuai dengan yang

dibutuhkan. Isi dari direktori ini adalah isu lokal dan tidak boleh mempengaruhi manner dimana program sedang berjalan.

– Direktori ini tidak boleh digunakan untuk instalasi program: direktori sementara yang tepat, yang sedang tidak digunakan oleh sistem, harus digunakan.

• /opt disediakan untuk instalasi dari tambahan untuk paket aplikasi piranti lunak.

– Paket yang akan diinstalasi di /opt harus menempatkan file statis di direktori tree /opt/<paket> yang berbeda, dimana <paket>

(13)

/sbin, /tmp

• /sbin : utilitas yang digunakan untuk sistem

administrasi (dan perintah root-only yang lain)

disimpan di /sbin/, /usr/sbin, dan /usr/local/sbin.

/sbin mengandung binari esensial untuk boot,

meyimpan kembali, mengembalikan seperti

semula, dan/atau membetulkan sistem dalam

penambahan ke binari dalam /bin.

• Direktori /tmp harus dibuat siap pakai untuk

program yang membutuhkan file sementara

– Program tidak boleh berasumsi bahwa file atau

direktori dalam /tmp disediakan diantara invokasi dari program

(14)

/usr

• /usr adalah second major section file system.

• /usr adalah data read-only yang dapat digunakan bersama-sama. Hal ini menandakan bahwa /usr harus bisa dipakai bersama-sama oleh various FHS-compliant hosts dan tidak boleh ditimpa. Informasi yang host-specific atau bervariasi dengan waktu disimpan dimana saja.

– Paket piranti lunak besar tidak boleh menggunakan sub-direktori langsung di bawah hierarki /usr.

• Direktori dibawah /usr

– bin perintah yang paling sering digunakan user

– include header files termasuk dalam program berbasis C – lib perpustakaan

– local hierarki lokal (kosong setelah instalasi awal) – sbin sistem binari yang non-vital

(15)

/var

• /var berisi variabel file data. Variabel file data ini

mengandung direktori spool dan file, administratif dan logging data, dan file sementara.

• Beberapa bagian dari /var tidak bisa digunakan bersama antara sistem yang berbeda. Contohnya, /var/log,

/var/lock, dan /var/run. Bagian lain mungkin ada yang bisa dipakai bersama-sama, yang dapat dilihat /var/mail, /var/cache/man, /var/cache/fonts, dan /var/spool/news. • /var dispesifikasi agar memungkinkan untuk me-mount

user read-only. Semuanya yang mula-mula dimasukkan ke dalam /usr yang ditulis selama sistem operasi

(kebalikan dari instalasi dan pemeliharaan piranti lunak) harus terletak di /var.

(16)

Di dalam dir /usr

• cache aplikasi data cache

• lib: variable status informasi

• local variabel data untuk /usr/local

• lock mengunci file

• log log file dan direktori

• opt Variabel data untuk /opt

• run data yang relevan dengan proses yang

berjalan

• spool aplikasi data spool

• tmp file sementara

(17)

Metode Alokasi

• Untuk mengalokasikan file agar dapat

diakses dengan cepat dan disk dapat

dimanfaatkan secara efektif

• Metode yang sering digunakan ialah:

– Contiguous allocation

– Linked allocation

(18)

Contiguous Allocation

• Sebuah file didefinisikan oleh alamat disk

(mendefinisikan urutan linier dari disk) dan panjangnya (dalam satuan blok) dari blok pertama

• Contiguous allocation mendukung pengaksesan secara sekuensial dan juga pengaksesan secara langsung

• Random access

• Wasteful of space (dynamic storage-allocation problem • Files cannot grow

• Kelemahan:

– Mencari ruang untuk file baru – External fragmentation

– Menentukan berapa banyak ruang yang dibutuhkan untuk suatu file

(19)
(20)

Linked Allocation

• Direktori mengandung sebuah pointer untuk blok pertama dan blok terakhir dari sebuah file

• Setiap blok mengandung sebuah pointer untuk ke blok selanjutnya (tidak dapat di buat oleh user)

• External fragmentation tidak terjadi di metode ini • Efektif saat file diakses secara sequential

• Masalah:

– Tidak efisien saat file diakses secara langsung – Pointer membutuhkan ruang

– File berikutnya bergantung dengan file sebelumnya (dalam pointer)

(21)
(22)
(23)

Indexed Allocation

• Pointer digabungkan didalam suatu blok yang

dinamakan blok indeks

• Setiap file memiliki blok indeks masing-masing

• Direktori mengandung alamat dari blok indeks

• Kelemahan:

– Jika blok indeks terlalu kecil, maka itu tidak akan bisa memuat pointer yang cukup untuk sebuah file yang besar

– Suatu mekanisme akan dibutuhkan menangani masalah tersebut

(24)
(25)

Indexed Allocation – Mapping (Cont.)

M

outer-index

(26)

Kinerja dari Metode Alokasi

• Countiguous allocation:

– Efisien untuk file kecil

– Mendukung akses secara langsung

• Linked allocation

– Mendukung akses secara sequential

• Indexed allocation

– Tergantung dari struktur index, ukuran file,

dan posisi dari blok yang dibutuhkan

(27)

Manajemen Ruang Kosong

• Bit Vector

– Daftar ruang kosong diimplementasikan sebagai bit map atau bit vector

– Setiap bit merepresentasikan 1 blok. Jika bit tersebut bernilai 1 maka blok tersebut kosong. Dan bernilai 0 untuk sebaliknya. – Bit pertama untuk blok pertama, bit kedua untuk blok kedua, dst

• Linked List

– Skema ini menghubungkan blok-blok yang masih kosong menjadi linked list

– Linked List menyimpan suatu pointer di blok kosong yang pertama di lokasi yang khusus di disk dan menyimpannya di memori

– Blok pertama ini mengandung suatu pointer untuk ke blok disk kosong selanjutnya dan seterusnya

(28)

Manajemen Ruang Kosong

• Grouping

– Metode ini hampir sama dengan mekanisme linked scheme dari metode indexed allocation, tapi pointer-nya menunjukkan alamat blok yang kosong dan

pointer terakhir akan menunjukkan ke blok selanjutnya yang mengandung pointer

• Counting

– Metode ini mempunyai direktori yang menyimpan

awal dan panjang seperti contiguous allocation untuk file-file yang masih kosong

(29)

Efisiensi Penggunaan Space pada

Disk

• Untuk memperbaiki kinerja ada beberapa cara:

– Menggunakan page cache

(30)

Recovery

• Pemeliharaan harus dijalankan untuk

memastikan kegagalan sistem tidak akan

terjadi saat kehilangan data atau saat data

tidak konsisten

• Ada 2 jenis pemulihan:

– Pengecekan yang kontinu: dengan logging

– Backup and Restore

(31)

Log Structured File Systems

• Log structured (or journaling) file systems mencatat setiap update dari file system sebagai transaction • Semua transactions ditulis dalam sebuah log

– Sebuah transaction dilakukan committed jika ditulis dalam log – file system mungkin belum di-updated benar-benar

• Transactions dalam log ditulis secara asynchronously ke dalam file system

– Ketika file system dimodifikasi, transaction dibuang dari log

• Jika file system crashes, semua sisa transactions dalam log harus tetap dijaga

• Hasil implementasinya disebut log-based transaction-oriented

(32)

NEXT

Referensi

Dokumen terkait

Berdasarkan hasil penelitian yang dilakukan, maka didapatkan kesimpulan bahwa metode composite logic dapat diterapkan dalam membangun sebuah framework multimedia

2 Angka Kemiskinan Jika program raskin dihentikan dan diganti uang (e-money), maka banyak keluarga yang status sosial-ekonominya rendah (miskin) akan kesulitan memenuhi

Posisi penting Dewan Pengawas Syariah dalam organisasi mendorong anggota DPS untuk memiliki pengetahuan dalam berbagai aspek seperti sumber syariah (Al- Qur’an dan

Projek yang dicadangkan adalah untuk memberi rekabentuk dan konsep yang baru bagi pawagam Golden Screen Cinema di samping memberikan susana yang lebih praktikal dan

Sehingga dalam stuktur organisasi di Bank Syariah dapat dibentuk bagian/unit tersendiri yang berperan selaku Nazhir wakaf uang dengan beberapa masukan sebagai berikut:

So, the answer to the hypotheses of the simultaneous effect of independent variables to the dependent variable is to accept H1 and reject H0 or there is a

Aktivitas atau alat-alat kadang saya buat sendiri, karena dari buku kadang tidak sepenuhnya tepat untuk siswa di tempat ini. Jadinya saya

yang tidak merata akan membuat manfaat program. tidak dirasakan oleh semua