Sejak
ditemukan hingga sampai pada tahun 2010 ini komputer telah mengalami
perkembangan, dari sisi perangkat keras maupun perangkat lunaknya. Selain itu perkembangan
teknologi informasi yang berkolaborasi dengan teknologi komunikasi melahirkan
perangkat keras dan perangkat lunak yang digunakan dalam membangun jaringan
komputer, sehingga kedua teknologi itu disatukan dalam istilah TIK ( Teknologi
Informasi dan Komunikasi ).
Bentuk
jaringan komputer yang diwakili dalam topologi merepresentasikan bahwa komputer
tidak dapat terlepas dari komputer yang lainnya dalam sebuah jaringan komputer.
Hal ini karena susunan setiap komputer yang terdiri dari Prosesor dan memori
akan berhubungan dengan prosesor dan memori komputer yang lain dalam jaringan
komputer, tergantung dari perangkat lunak yang digunakan dalam jaringan
komputer tersebut.
Ketergantungan perangkat lunak
jaringan komputer ini akan membuahkan klasifikasi perangkat lunak dalam
jaringan komputer, yang pertama adalah sistem terpusat yang dimotori oleh
teknologi WEB, dan yang kedua adalah sistem terdistribusi yang dimotori
oleh aplikasi dan sistem operasi yang berbasis visual.
Gambar 1. 1 Kumpulan berbagai computer dalam
sistem terdistribusi
B.
Rumusan Masalah
1.
Mahasiswa
dapat mengetahui pengertian dari Sistem Terdistribusi
2.
Mahasiswa
dapat memahami dari tujuan Sistem Terdistribusi
3.
Mahasiswa
dapat memahami konsep Hardware (Perangkat Keras) dalam sistem terdistribusi
4.
Mahasiswa dapat
memahami konsep Software (Perangkat Lunak) dalam sistem terdistribusi
5.
Mahasiswa
dapat mengenal dan memahami model Client-Server
di dalam sistem terdistribusi.
BAB II
PEMBAHASAN
1.
Pengertian Sistem Terdistribusi
Berbagai definisi sistem terdistribusi telah diberikan
dalam beberapa literatur, tetapi tak satupun penjelasan itu memuaskan dan tidak
ada sebuah kesepakatan dalam pengertian sistem terdistribusi. Oleh sebab
itu diifinisi sistem terdistribusi memliki cakupan yang luas:
“Sebuah
sistem terdistribusi adalah kumpulan komputer independen yang digunakan oleh
pengguna sebagai satu kesatuan yang mempunyai fungsi yang sama.”
Definisi ini mempunyai dua aspek. Yang pertama berhubungan dengan hardware: mesin-mesin bersifat otonom. Yang kedua berhubungan dengan software: pengguna sistem memikirkan sebagai satu komputer. Keduanya sangat penting. Kita akan kembali ke dalam bab ini, setelah beberapa materi berlatarbelakang pada kedua hardware dan software.
Alih-alih
akan dengan definisi lebih lanjut, mungkin lebih bermanfaat memberikan beberapa
contoh dari sistem terdistribusi. Sebagai contoh pertama, pertimbangkan
jaringan dari workstation di universitas atau departemen dalam perusahaan.
Selain setiap pengguna komputer pribadi, mungkin ada banyak prosesor
dalam komputer yang tidak ditugaskan untuk melakukan hal tertentu namun
dialokasikan secara dinamis sesuai dengan keperluan. Sistem seperti ini mungkin
memiliki sistem berkas tunggal, dengan semua file yang dapat diakses dari semua
mesin dengan cara yang sama dan menggunakan nama path yang sama. Terlebih lagi,
ketika pengguna mengetik perintah, sistem bisa mencari tempat terbaik untuk
mengeksekusi perintah, mungkin pada komputer milik sendiri, mungkin pada
workstation yang idle milik orang lain, dan mungkin di salah satu unassigned
prosesor di ruang mesin superkomputer. Jika sistem secara keseluruhan terlihat
dan bertindak seperti halnya prosesor tunggal dengan sistem operasi yang time
sharing, akan memenuhi syarat sebagai didistribusikan sistem.
Contoh
kedua, sebuah pabrik yang penuh dengan robot, masing-masing berisi komputer
kuat untuk menangani tugas. Ketika robot di jalur perakitan pemberitahuan bahwa
sebuah bagian mengalami kecacatan, ia akan meminta robot lain untuk membawa
penggantiannya. Jika semua bertindak seperti robot yang memiliki
perangkat periferal yang sama, pusat komputer dan sistem dapat deprogram, hal
ini juga dikatakan sebagai sistem terdistribusi.
Contoh
terakhir, pikirkan tentang sebuah bank besar dengan ratusan kantor cabang
seluruh dunia. Setiap kantor memiliki komputer master untuk menyimpan
rekening lokal dan menangani transaksi lokal. Selain itu, setiap komputer
memiliki kemampuan untuk berbicara untuk semua cabang lainnya komputer dan
dengan komputer pusat di kantor pusat. Jika transaksi dapat dilakukan tanpa
memperhatikan di mana seorang pelanggan atau account, dan para pengguna tidak
akan melihat adanya perbedaan antara sistem ini dan terpusat mainframe, ini
juga dianggap sebagai sistem terdistribusi.
2. Tujuan
Sistem Terdistribusi
Setiap
sistem yang diciptakan pasti memeliki tujuan, begitupula dengan sistem
terdistribusi.
2.1.
Koneksi
Antara Pengguna dan Sumber Daya
Tujuan utama sistem
terdistribusi yaitu untuk memudahkan pengguna dalam mengakses sumber daya jarak
jauh secara bersama-sama dengan terkontrol dan efisien. Dengan semakin
meningkatnya konektivitas dan akses untuk dapat saling berbagi.
2.2.
Transparansi
Sistem terdistribusi
bertujuan untuk menyembunyikan fakta bahwa proses dan sumber daya fisik
didistribusikan ke banyak komputer. Anggapan pengguna bahwa aplikasi yang
dilihatnya merupakan satu sistem komputer inilah yang disebut transparency.
Access
transparency:
menyembunyikan perbedaan
representasi data dan bagaimana sumber daya diakses.
Contohnya : pemetaan drive
di samba, NFS, remote printer, dll. Sistem terdistribusi mungkin memiliki
sistem komputer yang menjalankan sistem operasi yang berbeda, masing-masing
memiliki konvensi sendiri penamaan file. Perbedaan dalam konvensi penamaan,
serta bagaimana file dapat dimanipulasi, semua harus disembunyikan dari
pengguna dan aplikasi.
Location
transparency:
menyembunyikan dimana sumber daya berada.
Contoh : transaksi perbankan ATM, web pages, dll. Nama
http://www.prenhall.com/index.html URL
yang tidak memberikan petunjuk tentang lokasi server utama Web Prentice
Hall.
Migration
transparency:
menyembunyikan bahwa sumber daya mungkin pindah ke
tempat lain.
Contoh : web pages, NFS, dll. URL http://www.prenhall.com/index.html tidak
memberikan petunjuk apakah index.html selalu berada di lokasi saat ini atau baru
pindah ke lain tempat.
Replication
transparency:
Menyembunyikan sumber daya direplikasi.
Contoh : distributed DBMS, mirroring web pages, dll.
Sumber daya dapat direplikasikan untuk meningkatkan ketersediaan atau untuk
meningkatkan kinerja dengan menempatkan salinan dekat ke tempat di mana ia
diakses.
Concurrency transparency :
Menyembunyikan bahwa sumber daya mungkin dibagi kepada
beberapa penggun Contoh : NFS, Automatic teller machine network,
Database Management System. Dua pengguna
independen mungkin masing-masing
memiliki file yang tersimpan di server file yang sama
atau mungkin mengakses tabel yang sama dalam database bersama.
Dalam kasus tersebut, adalah penting bahwa
setiap pengguna
tidak menyadari bahwa yang lain adalah
memanfaatkan sumber yang sama.
Failure transparency :
menyembunyikan kegagalan dan pemulihan dari sumber
daya.
Contoh : Database Management System. Contoh lain, saat menghubungi server web sibuk, browser akhirnya akan time out dan melaporkan bahwa halaman Web tidak tersedia .. Pada saat itu, pengguna tidak dapat menyimpulkan bahwa server benar-benar down.
Contoh : Database Management System. Contoh lain, saat menghubungi server web sibuk, browser akhirnya akan time out dan melaporkan bahwa halaman Web tidak tersedia .. Pada saat itu, pengguna tidak dapat menyimpulkan bahwa server benar-benar down.
Performance Transparency :
meminimalkan tambahan performance dalam menggunakan
remote resourse, sehingga response time dan throughput sebanding dengan ketika
mengakses resource secara lokal.
2.3.
Keterbukaan
(Oppennes)
Openness (Keterbukaan).
Sistem distribusi terbuka adalah suatu sistem yang menawarkan layanan sesuai
dengan aturan standar yang menjelaskan sintak dan semantik dari layanan. Dalam
sistem terdistribusi, layanan spesifikasi secara umum dalam tampilan antarmuka,
yang sering disebut Interface Definition Languaga (IDL). Kunci aspek openness adalah
antarmuka standar dan protokol serta mendukung keberagaman.
2.4.
Skalabilitas
Bertambahnya kebutuhan
terhadap sistem terdistribusi, memungkinkan untuk memperbesar dan memperkecil
infrastruktur dari sistem terdistribusi itu sendiri. Perubahan ukuran ini tidak
mempengaruhi sistem yang sedang berjalan. Perubahan skalabilitas ini pengguna
dan perangkat keras serta lunak sistem terdistribusi.
3.
Konsep Perangkat Keras (Hardware Concepts)
Meskipun semua sistem terdistribusi terdiri dari
beberapa CPU, ada beberapa cara berbeda dengan mengatur hardware, terutama
dalam hal bagaimana mereka saling berhubungan dan bagaimana mereka
berkomunikasi. Pada bagian ini kita akan mengambil sekilas perangkat keras
sistem terdistribusi, khususnya, bagaimana mesin terhubung antara satu dengan
yang lainnya. Pada bagian berikutnya kita akan meneliti beberapa isu perangkat
lunak yang berkaitan dengan sistem terdistribusi.
Berbagai
skema klasifikasi untuk beberapa CPU dari komputer telah pernah diusulkan
selama bertahun-tahun, namun tak satu pun dari mereka sudah benar-benar dapt
diadopsi secara luas. Mungkin yang paling sering dikutip adalah penggolongan
taksonomi Flynn (1972), meskipun cukup mendasar. Flynn mengambil dua ciri
dari CPU yang dianggap penting yaitu: jumlah aliran instruksi dan jumlah aliran
data . Sebuah komputer dengan satu aliran instruksi dan aliran data tunggal
adalah disebut SISD (single instruction stream and a single data stream). Semua
komputer Uniprocessor tradisional (yaitu, mereka hanya memiliki satu CPU)
termasuk dalam kategori ini, dari komputer pribadi ke mainframe besar.
Kategori
berikutnya adalah SIMD, single instruction stream multiple data stream. Jenis
ini mengacu pada array prosesor dengan satu unit instruksi yang mengambil suatu
instruksi, dan kemudian menginstruksikan banyak data untuk melaksanakannya
secara paralel, masing-masing dengan data sendiri. Mesin ini berguna untuk
perhitungan yang berulang.
Gambar 1.
Taksonomi terdistribusi dan paralel sistem komputer
Kategori berikutnya adalah MISD, multiple instruction stream, single data stream. Dan kategori terakhir adalah MIMD, yang pada dasarnya berarti sekelompok komputer independen, masing-masing dengan program counter, program, dan data. Semua sistem terdistribusi menggunakan MIMD
Meskipun Flynn berhenti di sini, kita akan lebih jauh. Dalam Gambar 1, kita membagi semua MIMD komputer menjadi dua kelompok: Tightly coupled yang share memori, biasanya disebut Multiprocessors, dan mereka yang tidak, kadang-kadang disebut multicomputers. Perbedaan yang esensial adalah: dalam multiprosesor, ada virtual address yaitu satu ruang yang digunakan bersama-sama oleh semua CPU. Jika ada CPU menulis, misalnya, nilai 44 menjadi alamat 1000, CPU lain kemudian membaca dari alamat 1000 akan mendapatkan nilai 44. Semua mesin memiliki memori yang sama.
Sebaliknya,
dalam multicomputer, setiap mesin memiliki memori pribadi. Jika satu CPU
menulis nilai 44 menjadi alamat 1000, ketika CPU lain reads 1000 alamat tidak
akan mendapatkan nilai apa pun yang ada di sana sebelumnya. Sebuah contoh umum
adalah sebuah komputer pribadi yang dihubungkan dengan jaringan membentuk
multicomputer.
Masing-masing
kategori ini dapat dibagi lagi berdasarkan arsitektur jaringan interkoneksi.
Dalam Gambar 1 kita menggambarkan dua kategori sebagai bus dan switched. Dengan
bus kami maksud bahwa ada jaringan tunggal, backplane, bus, kabel, atau media
lain yang menghubungkan semua mesin.
Sistem switched tidak memiliki satu backbone seperti televisi kabel. Sebaliknya, ada kabel individu dari mesin ke mesin, dengan berbagai pola kabel digunakan. Pesan bergerak sepanjang kabel, dengan eksplisit keputusan switching yang dibuat pada setiap langkah untuk rute pesan di sepanjang salah satu jalur kabel. Telepon umum diseluruh dunia sistem ini disusun dengan cara ini.
Dimensi lain penggolongan / taksonomi kita adalah bahwa dalam beberapa sistem mesin tightly coupled dan lainnya loosely coupled. Dalam tightly coupled, mengalami penundaan ketika pesan dikirim dari satu komputer ke komputer lain, dan data rate tinggi, yaitu jumlah bit per detik yang dapat ditransfer adalah besar. Dalam loosely coupled, kebalikannya adalah pesan dari satu jomputer ke computer yang dikirimkan mengalami penundaan dan data rate rendah. Untuk Misalnya, dua CPU sama chip pada printed circuit board dan dihubungkan oleh kabel seperti tightly coupled, sedangkan dua komputer terhubung dengan modem 2400 bit/sec melalui sistem telepon tertentu adalah loosely coupled.
Sistem Tightly-coupled digabungkan untuk digunakan sebagai sistem paralel (bekerja pada satu masalah) dan loosely coupled yang cenderung digunakan sebagai sistem terdistribusi (bekerja pada banyak masalah yang tidak berkaitan), meskipun hal ini tidak selalu benar. Salah satu yang terkenal adalah proyek di mana ratusan komputer semua dunia bekerja bersama-sama mencoba untuk mencari faktor dengan jumlah besar (sekitar 100 digit). Setiap computer ditugaskan dalam kisaran yang berbeda pembagi untuk melakukannya, dan mereka semua bekerja tidak serempak dan melaporkan hasil ketika mereka selesai.
Secara keseluruhan, Multiprocessors cenderung lebih Tightly-coupled daripada multicomputers, karena mereka dapat bertukar data pada memori yang cepat, tetapi beberapa fiberoptic berbasis multicomputers juga dapat bekerja pada memori yang cepat. Meskipun ketidak jelasan dari istilah "tightly coupled" dan "loosely coupled" mereka konsep yang berguna, seperti mengatakan "Jack is fat and Jill is thin" menyampaikan informasi tentang kegemukan meskipun salah satu dapat masuk ke cukup banyak berdiskusi tentang konsep-konsep dari "fatness" and "thinness."
Sistem switched tidak memiliki satu backbone seperti televisi kabel. Sebaliknya, ada kabel individu dari mesin ke mesin, dengan berbagai pola kabel digunakan. Pesan bergerak sepanjang kabel, dengan eksplisit keputusan switching yang dibuat pada setiap langkah untuk rute pesan di sepanjang salah satu jalur kabel. Telepon umum diseluruh dunia sistem ini disusun dengan cara ini.
Dimensi lain penggolongan / taksonomi kita adalah bahwa dalam beberapa sistem mesin tightly coupled dan lainnya loosely coupled. Dalam tightly coupled, mengalami penundaan ketika pesan dikirim dari satu komputer ke komputer lain, dan data rate tinggi, yaitu jumlah bit per detik yang dapat ditransfer adalah besar. Dalam loosely coupled, kebalikannya adalah pesan dari satu jomputer ke computer yang dikirimkan mengalami penundaan dan data rate rendah. Untuk Misalnya, dua CPU sama chip pada printed circuit board dan dihubungkan oleh kabel seperti tightly coupled, sedangkan dua komputer terhubung dengan modem 2400 bit/sec melalui sistem telepon tertentu adalah loosely coupled.
Sistem Tightly-coupled digabungkan untuk digunakan sebagai sistem paralel (bekerja pada satu masalah) dan loosely coupled yang cenderung digunakan sebagai sistem terdistribusi (bekerja pada banyak masalah yang tidak berkaitan), meskipun hal ini tidak selalu benar. Salah satu yang terkenal adalah proyek di mana ratusan komputer semua dunia bekerja bersama-sama mencoba untuk mencari faktor dengan jumlah besar (sekitar 100 digit). Setiap computer ditugaskan dalam kisaran yang berbeda pembagi untuk melakukannya, dan mereka semua bekerja tidak serempak dan melaporkan hasil ketika mereka selesai.
Secara keseluruhan, Multiprocessors cenderung lebih Tightly-coupled daripada multicomputers, karena mereka dapat bertukar data pada memori yang cepat, tetapi beberapa fiberoptic berbasis multicomputers juga dapat bekerja pada memori yang cepat. Meskipun ketidak jelasan dari istilah "tightly coupled" dan "loosely coupled" mereka konsep yang berguna, seperti mengatakan "Jack is fat and Jill is thin" menyampaikan informasi tentang kegemukan meskipun salah satu dapat masuk ke cukup banyak berdiskusi tentang konsep-konsep dari "fatness" and "thinness."
Dalam
empat bagian berikut, kita akan melihat empat kategori pada Gambar 1, secara
lebih rinci, yaitu bus Multiprocessors, switched Multiprocessors, bus
multicomputers, dan switched multicomputers. Walaupun topik ini tidak berkaitan
langsung dengan perhatian utama kami, sistem operasi terdistribusi, mereka
titik terang pada subjek karena seperti yang akan kita lihat, berbagai kategori
mesin menggunakan berbagai jenis sistem operasi.
Bus-based multiprocessors terdiri dari
beberapa jumlah CPU yang semua terhubung menggunakan bus, bersama dengan sebuah
modul memori.
Konfigurasi sederhana seperti terlihat di gambar, sebuah bus berkecepatan tinggi menghubungkan CPU dan memori. Tipikal bus memiliki 32 atau 64 jalur alamat, 32 atau 64 jalur data, dan mungkin 32 atau lebih banyak kontrol jalur, yang semuanya beroperasi secara paralel. Proses membaca (read) dari memori, dengan cara, CPU menempatkan alamat dari kata/data yang diinginkan pada bus yang berisi alamat, kemudian meletakkan sinyal pada bus kontrol yang tepat untuk menunjukkan bahwa akan terjadi proses read. Memori merespon dengan menempatkan data pada bus data untuk agar CPU yang meminta dapat membacanya dengan cara yang sama.
Konfigurasi sederhana seperti terlihat di gambar, sebuah bus berkecepatan tinggi menghubungkan CPU dan memori. Tipikal bus memiliki 32 atau 64 jalur alamat, 32 atau 64 jalur data, dan mungkin 32 atau lebih banyak kontrol jalur, yang semuanya beroperasi secara paralel. Proses membaca (read) dari memori, dengan cara, CPU menempatkan alamat dari kata/data yang diinginkan pada bus yang berisi alamat, kemudian meletakkan sinyal pada bus kontrol yang tepat untuk menunjukkan bahwa akan terjadi proses read. Memori merespon dengan menempatkan data pada bus data untuk agar CPU yang meminta dapat membacanya dengan cara yang sama.
Karena hanya ada satu memori, jika CPU A
menulis (write) data ke memori dan kemudian CPU B membaca data itu satu
mikrodetik kemudian, B akan mendapatkan nilai yang dituliskan (proses real
time). Sebuah memori yang memiliki properti ini dikatakan koheren. Koheren
memainkan peran penting dalam sistem operasi terdistribusi dalam berbagai cara
yang akan kita bahas nanti.
Masalahnya dengan skema ini adalah bahwa dengan jumlah CPU sebanyak 4 atau 5, akan membuat bus kelebihan beban dan menyebabkan kinerja akan menurun drastis. Solusi adalah menambahkan kecepatan memori yang tinggi (cache memory) antara CPU dan bus, seperti yang ditunjukkan pada gambar diatas. Cache memiliki data yang paling baru diakses dan semua memori melakukan permintaan melalui cache. Jika ada permintaan dalam cache, cache sendiri menanggapi ke CPU, dan tidak pada bus. Jika cache cukup besar, kemungkinan keberhasilan, yang disebut hit rate, akan tinggi, dan jumlah bus traffic per CPU akan turun drastis, sehingga memungkin penambahan CPU dalam sistem menjadi banyak lagi. Ukuran cache 64Kb untuk 1Mb memori adalah sebuah kewajaran, dan akan memberikan hit rate 90 persen atau lebih.
Namun, pengenalan cache juga membawa masalah serius. Misalkan dua CPU, A dan B, masing-masing membaca data yang sama ke dalam masing-masing cache. Maka A akan menimpa data. B berikutnya ketika membaca data itu, ia mendapatkan nilai lama dari cache, bukan nilai yang baru saja dituliskan dan sistem ini sulit untuk diprogram.
Masalahnya dengan skema ini adalah bahwa dengan jumlah CPU sebanyak 4 atau 5, akan membuat bus kelebihan beban dan menyebabkan kinerja akan menurun drastis. Solusi adalah menambahkan kecepatan memori yang tinggi (cache memory) antara CPU dan bus, seperti yang ditunjukkan pada gambar diatas. Cache memiliki data yang paling baru diakses dan semua memori melakukan permintaan melalui cache. Jika ada permintaan dalam cache, cache sendiri menanggapi ke CPU, dan tidak pada bus. Jika cache cukup besar, kemungkinan keberhasilan, yang disebut hit rate, akan tinggi, dan jumlah bus traffic per CPU akan turun drastis, sehingga memungkin penambahan CPU dalam sistem menjadi banyak lagi. Ukuran cache 64Kb untuk 1Mb memori adalah sebuah kewajaran, dan akan memberikan hit rate 90 persen atau lebih.
Namun, pengenalan cache juga membawa masalah serius. Misalkan dua CPU, A dan B, masing-masing membaca data yang sama ke dalam masing-masing cache. Maka A akan menimpa data. B berikutnya ketika membaca data itu, ia mendapatkan nilai lama dari cache, bukan nilai yang baru saja dituliskan dan sistem ini sulit untuk diprogram.
Banyak peneliti telah mempelajari
masalah ini, dan berbagai solusi diketahui. Anggaplah bahwa cache memori
dirancang sedemikian rupa agar setiap kali data yang ditulis ke cache, tertulis
melalui memori juga. Seperti cache, disebut writethrough cache. Dalam desain
ini, cache hits untuk membaca bus tidak menyebabkan macetnya trafik data, tapi
cache yang tidak dapat membaca dan menulis yang menyebabkan macetnya trafik
data pada bus.
Selain itu, semua cache selalu memantau bus. Cache setiap kali melihat alamat memori yang ada dalam cache, hal ini untuk menghapus yang entri dari cache, atau entri cache update dengan nilai baru. Seperti cache disebut snoopy cache (atau kadang-kadang, sebuah mengintai cache) karena selalu "mengintip" (menguping) di bus. Sebuah desain yang terdiri dari snoopy write-through cache adalah koheren dan ini tidak terlihat oleh programmer. Hampir semua bis Multiprocessors berbasis gunakan arsitektur atau satu ini berkaitan erat dengan hal itu, untuk menempatkan sekitar 32 atau mungkin 64 CPU pada satu bus. Untuk lebih lanjut tentang Multiprocessors berbasis bus, lihat Lilja (1993).
Selain itu, semua cache selalu memantau bus. Cache setiap kali melihat alamat memori yang ada dalam cache, hal ini untuk menghapus yang entri dari cache, atau entri cache update dengan nilai baru. Seperti cache disebut snoopy cache (atau kadang-kadang, sebuah mengintai cache) karena selalu "mengintip" (menguping) di bus. Sebuah desain yang terdiri dari snoopy write-through cache adalah koheren dan ini tidak terlihat oleh programmer. Hampir semua bis Multiprocessors berbasis gunakan arsitektur atau satu ini berkaitan erat dengan hal itu, untuk menempatkan sekitar 32 atau mungkin 64 CPU pada satu bus. Untuk lebih lanjut tentang Multiprocessors berbasis bus, lihat Lilja (1993).
Membangun
multiprosesor dengan lebih dari 64 prosesor, diperlukan metode yang berbeda
untuk menghubungkan CPU dengan memori. Satu kemungkinan adalah untuk membagi
memori ke dalam modul dan menghubungkan mereka ke CPU dengan crossbar switch,
seperti ditunjukkan pada gambar (a).
Setiap
CPU dan memori masing-masing memiliki sambungan input/ output. Di setiap
persimpangan adalah Crosspoint elektronik kecil yang dapat dibuka dan ditutup
dengan hardware. Ketika CPU ingin mengakses memori tertentu, switch
menghubungkan mereka Crosspoint ditutup sementara, untuk memungkinkan akses
berlangsung. Keutamaan crossbar switch adalah bahwa banyak CPU dapat mengakses
memori pada saat yang sama, walaupun jika dua CPU mencoba akses memori yang
sama secara bersamaan, salah satu dari mereka harus menunggu.
Kelemahan dari crossbar switch
adalah bahwa dengan n CPU dan n memori, n kuadrat Crosspoint switch
diperlukan. Untuk besarnya n, jumlah ini dapat menjadi penghalang. Akibatnya,
orang-orang yang telah mencari, dan menemukan, alternatif switching yang
memerlukan lebih sedikit switch. Jaringan omega gambar (b) adalah satu contoh.
Jaringan ini berisi empat (2 x 2) switch, masing-masing mempunyai dua input dan
dua output. Setiap switch dapat rute baik baik input ke output. Switch ini
dapat diatur dalam nanodetik atau kurang.
Dalam kasus umum, dengan n CPU dan n
memori, jaringan omega log2 n switching memerlukan tahap, masing-masing berisi
n/2 switch, dengan total (n log2 n) / 2 switch. Walaupun untuk n besar ini jauh
lebih baik daripada n kuadrat.
Selain
itu, ada masalah lain: penundaan. Sebagai contoh, untuk n = 1024, ada 10 tahap
beralih dari CPU ke memori, dan 10 untuk kata diminta untuk datang kembali.
Anggaplah bahwa CPU RISC chip modem berjalan pada 100 MIPS, yaitu waktu
eksekusi instruksi adalah 10 nsec. Jika Permintaan memori untuk melewati
total 20 switching tahap (10 outbound dan 10 belakang) dalam 10 nsec, waktu
switching harus 500 picosec (0,5 nsec). Multiprosesor memerlukan 5120
500-picosec switch.
Orang,
telah berusaha untuk mengurangi biaya dengan beralih ke sistem hirarkis.
Beberapa memori dikaitkan dengan masing-masing CPU. Setiap CPU dapat mengakses
local sendiri memori dengan cepat, tetapi orang lain mengakses memori yang
lebih lambat. Desain ini dikenal sebagai NUMA (Non Uniform Memory Access)
mesin. Meskipun mesin NUMA memiliki waktu akses rata-rata lebih baik daripada
mesin didasarkan pada jaringan omega, mereka memiliki komplikasi baru bahwa
penempatan program dan data menjadi penting untuk membuat kebanyakan akses ke
memori lokal.
Ringkasnya,
bus berbasis Multiprocessors, bahkan dengan snoopy cache, adalah dibatasi oleh
jumlah kapasitas bus untuk sekitar 64 CPU paling banyak.
Melampaui yang membutuhkan jaringan switching, seperti crossbar switch,
jaringan omega switching, atau sesuatu yang serupa. crossbar switch besar
sangat mahal, dan jaringan omega besar yang baik mahal dan lambat. Mesin NUMA
memerlukan kompleks algoritma untuk penempatan perangkat lunak yang baik.
Kesimpulannya jelas: building a large, tightly-coupled, shared memory
multiprocessor adalah mungkin, meski sulit dan mahal.
Dalam membangun multicomputer (yakni, tidak menggunakan mekanisme shared memory) akan lebih mudah. Setiap CPU memiliki koneksi langsung ke memori lokal sendiri. Meskipun begitu tetap saja ada masalah yaitu cara CPU berkomunikasi dengan satu sama lain. Jelas, beberapa skema interkoneksi dibutuhkan di sini, karena hanya untuk komunikasi CPU-ke-CPU, dapat menyebabkan trafik jaringan komputer akan beberapa kali lebih sibuk.
Dalam membangun multicomputer (yakni, tidak menggunakan mekanisme shared memory) akan lebih mudah. Setiap CPU memiliki koneksi langsung ke memori lokal sendiri. Meskipun begitu tetap saja ada masalah yaitu cara CPU berkomunikasi dengan satu sama lain. Jelas, beberapa skema interkoneksi dibutuhkan di sini, karena hanya untuk komunikasi CPU-ke-CPU, dapat menyebabkan trafik jaringan komputer akan beberapa kali lebih sibuk.
Dalam
Gambar diatas kita melihat bus berbasis multicomputer. Secara topologi
tampak/mirip dengan bus yang berbasis multiprosesor, tetapi karena lalu lintas
datanya lebih sedikit, tidak memerlukan bus berkecepatan tinggi. Bahkan,
kecepatan yang jauh lebih rendah dari LAN. Mengacu gambar diatas, 4
kumpulan workstation pada sebuah LAN lebih efisien daripada kumpulan CPU dimasukkan ke bus yang
cepat(backplane).
4.
Konsep Software (Software Concepts)
Meskipun hardware penting, software bahkan lebih
penting. Gambaran yang sistem berikan kepada para penggunanya, dan bagaimana
mereka berpikir tentang sistem, sangat ditentukan oleh sistem operasi dan
perangkat lunak, bukan perangkat keras. Dalam bagian ini kita akan
memperkenalkan berbagai jenis sistem operasi untuk Multiprocessors dan
multicomputers yang baru saja kita mempelajari, dan mendiskusikan jenis
perangkat lunak yang berjalan pada perangkat keras.
Sistem
operasi tidak dapat dimasukkan ke dalam computer secara assembling seperti
perangkat keras. Secara alamiah perangkat lunak yang samar dan tak berbentuk.
Namun, lebih-atau-kurang mungkin untuk membedakan dua jenis sistem operasi
untuk beberapa sistem CPU: loosely coupled dan tightly coupled. Sebagaimana
akan kita lihat, loosely coupled dan tightly coupled software secara analog
berbeda dengan loosely coupled dan tightly coupled.
Perangkat
lunak Loosely-coupled memungkinkan komputer dan pengguna dari suatu sistem
terdistribusi secara mendasar independen satu sama lain, tetapi tetap untuk
berinteraksi dengan terbatas tingkat mana yang diperlukan. Pertimbangkan
sekelompok personal komputer, masing-masing yang memiliki CPU, memori sendiri,
hard disk sendiri, dan sistem operasi sendiri, tetapi berbagi beberapa
sumber daya, seperti laser printer dan database, menggunakan LAN. Sistem ini
longgar digabungkan, karena individu mesin jelas dibedakan, masing-masing
dengan tugas untuk dilakukan.
Untuk menunjukkan betapa sulitnya membuat
definisi di daerah ini, sekarang mempertimbangkan sistem yang sama seperti di
atas, tetapi tanpa jaringan. Untuk mencetak file, user menulis file di floppy
disk, membawa ke mesin dengan printer, membacanya dan kemudian mencetaknya.
Apakah ini masih suatu sistem terdistribusi, hanya sekarang bahkan lebih
loosely coupled? Sulit untuk dijelaskan. Dari sudut pandang fundamental,
benar-benar tidak ada perbedaan teori antara berkomunikasi melalui LAN dan
berkomunikasi dengan membawa disket. Pada kebanyakan orang dapat mengatakan
bahwa penundaan dan kecepatan data yang lebih buruk.
Pada keadaan ekstrem yang lain kita mungkin menemukan
multiprosesor didedikasikan untuk menjalankan program secara paralel. Software
untuk sistem ini, baik aplikasi program dan sistem operasi yang dibutuhkan
untuk mendukung itu, jelas banyak lebih erat digabungkan daripada contoh
sebelumnya.
Kita
telah melihat empat jenis hardware dan didistribusikan dua jenis. Secara teori,
seharusnya ada delapan kombinasi hardware dan software. Pada kenyataannya,
hanya empat bernilai pembeda, karena bagi pengguna, teknologi interkoneksi
tidak terlihat. Bagi sebagian besar tujuan, sebuah multiprosesor adalah
multiprosesor, apakah itu menggunakan bus dengan snoopy cache atau menggunakan
jaringan omega. Pada bagian berikut, kita akan melihat beberapa yang kombinasi
paling baik dari hardware dan software.
5.
Model Client-Server
Bagaimana cara kerja sistem
terdistribusi antara komponen-komponen sistem dan bagaimana komponen tersebut
berada pada sistem terdistribusi :
- Client - Server Model
Sistem
yang terdiri dari kumpulan - kumpulan proses disebut dengan server, dan
memberikan layanan kepada user yang disebut dengan client.
Model client-server biasanya berbasiskan protokol
request/reply. Contoh implementasinya antara lain: RPC (Remote Procedure
Calling) dan RMI (Remote Method Invocation).
Client :Proses
akses data, melakukan operasi pada komputer lain.
Server :Proses mengatur data, proses mengatur resources, proses komputasi.
Interaksi :Invocation/result
Server :Proses mengatur data, proses mengatur resources, proses komputasi.
Interaksi :Invocation/result
·
Karakteristik
Client-Server
1.
Service : menyediakan layanan terpisah yang berbeda
2.
Shared Resource : server dapat melayani beberapa client pada
saat yang sama dan mengatur pengaksesan resource
3.
Asymmetrical
Protocol : antara client dan server merupakan hubungan
one to many
4.
Mix and Match : tidak tergantung pada platform
5.
Encapsulation
of Service : message memberitahu server apa yang akan
dikerjakan
6.
Transparency
Location : proses server dapat ditempatkan pada mesin
yang sama atau terpisah dengan proses client. Client/server akan menyembunyikan
lokasi server dari client
7. Message-based-exchange : antara client dan server berkomunikasi dengan
mekanisme pertukaran message
8.
Scalability : sistem client/server dapat dimekarkan baik
vertikal maupun horisontal
9. Integrity : kode dan data server diatur secara terpusat,
sedangkan pada client tetap pada komputer sendiri
·
Kelebihan
jaringan client server:
ü
Mendukung
keamanan jaringan yang lebih baik
ü
Kemudahan
administrasi ketika jaringan bertambah besar
ü
Manajemen
jaringan terpusat
ü
Semua data bisa
disimpan dan di backup terpusat di satu lokasi
·
Kekurangan
jaringan client server:
ü
Butuh
administrator jaringan yang profesional
ü
Butuh perangkat
bagus untuk digunakan sebagai komputer server
ü
Butuh software
tool operasional untuk mempermudah manajemen jaringan
ü
Anggaran untuk
manajemen jaringan menjadi besar
ü
Bila server
down, semua data dan resource diserver tidak bisa diaks
BAB III
PENUTUP
a.
Kesimpulan
Sebenarnya definisi dari sebuah Sistem Terdistribusi
sangat luas, akan tetapi di sini kami mencoba mengutarakan bahwa :
Sebuah sistem terdistribusi
adalah kumpulan komputer independen yang digunakan oleh pengguna sebagai satu
kesatuan yang mempunyai fungsi yang sama.
Dan
Definisi tersebut pun mempunyai dua aspek. Yang pertama berhubungan dengan
hardware: mesin-mesin bersifat otonom. Yang kedua berhubungan dengan software:
pengguna sistem memikirkan sebagai satu komputer. Keduanya sangat penting.
Setiap
sistem yang diciptakan pasti memeliki tujuan, begitupula dengan sistem terdistribusi.
Berikut
adalah beberapa tujuan dari sistem terdistribusi;
ü
Koneksi
Antara Pengguna dan Sumber Daya (Connecting User and Resources)
ü
Transparansi
(Transparency)
Access
transparency
Location
transparency
Migration
transparency
Replication
transparency
Concurrency transparency
Failure transparency
Performance Transparency
ü
Keterbukaan
(Oppennnes)
ü
Skalabilitas
(Scalability)
Adapun konsep hardware yang akan
dibahas pada sistem distribusi yaitu adalah, dimana hardware ini yang bertujuan
untuk mengkoordinir seluruh perangkat-perangkat yang terdapt pada mainframes,
server, workstation, ataupun Personal Computer.
Nah selain itu software juga
berperan penting terhadap sistem terdistribusi, disini yang akan di utarakan
adalah pemakaian sistem operasi yang diterapkan atau digunakan pada sistem
terdistribusi.
Kemudian adalah client-server , dimana client
didefinisikan sebagai proses akses data, melakukan operasi pada komputer
lain, dan server di definisikan sebagai proses mengatur data, proses mengatur
resources, proses komputasi. Dan clinet-server ini pula saling berhubungan dan
saling melengkapi satu sama lain dalam menjalankan tugas nya.
Daftar Pustaka
EmoticonEmoticon