Common Internet File System: Perbedaan antara revisi
Konten dihapus Konten ditambahkan
k →''Batch Oplock'': clean up, removed stub tag, added uncategorised tag |
|||
(9 revisi perantara oleh 5 pengguna tidak ditampilkan) | |||
Baris 2:
'''CIFS''' atau '''''<u>C</u>ommon <u>I</u>nternet <u>F</u>ile <u>S</u>ystem''''' merupakan sebuah implementasi dari [[protokol]] berbagi berkas/''file-sharing'' [[Server Message Block|''Server Message Block'' (SMB)]] yang telah diusulkan agar menjadi [[standar Internet]] (statusnya saat ini masih menjadi ''draft''), sehingga dapat diperoleh secara mudah. Perbedaan dari protokol SMB adalah bahwa protokol ini telah diperbaiki agar dapat digunakan melalui Internet. Protokol ini merupakan "saingan tidak langsung" dari protokol [[NFS|Network File System]] yang digunakan dalam keluarga [[sistem operasi]] [[UNIX]]. Protokol ini menggunakan arsitektur [[client/server]]. [[Microsoft]] telah memberikan draf rancangan protokol CIFS kepada [[IETF|Internet Engineering Task Force (IETF)]] untuk dijadikan standar Internet. Meskipun demikian, klien dan server CIFS telah ada dalam Windows 2000 ke atas.
== Selayang pandang ==
Protokol CIFS mengizinkan sekelompok pengguna agar dapat berkolaborasi dan berbagi berkas melalui [[Internet]] atau [[intranet]] perusahaan. CIFS, saat ini banyak diimplementasikan, sehingga dukungannya pun semakin banyak, meski pada awalnya protokol ini hanya dimiliki oleh sistem operasi [[IBM OS/2]] dan [[Microsoft Windows]] saja. Dengan adanya beberapa implementasi dari protokol SMB dalam berbagai sistem operasi, CIFS pun dapat didukung oleh kebanyakan [[sistem operasi]]. Salah satu implementasi yang populer, selain yang terdapat dalam [[Microsoft Windows]] dan [[IBM OS/2]] adalah SAMBA yang dapat digunakan dalam keluarga [[sistem operasi]] [[UNIX]].
Baris 11:
Sementara, jika dibandingkan dengan protokol [[NFS]], CIFS menawarkan beberapa keunggulan peningkatan performa dengan adanya fitur ''read-ahead'', ''write-behind'' dan fitur ''opportunistic locks''.
== Implementasi ==
Beberapa implementasi yang dilakukan dari standar CIFS adalah sebagai berikut:<!--daftar ini kurang lengkap-->
* [[DFS|Microsoft Distributed File System (DFS)]] yang merupakan pengembangan pertama CIFS oleh Microsoft yang diterapkan dalam [[Windows 2000|Windows 2000 Server]] dan [[Windows Server 2003]].
Baris 17:
* dan beberapa lainnya <!--tambahkan-->
== Protokol lapisan transport yang digunakan ==
Meski pada awalnya protokol SMB dibuat menggunakan protokol [[NetBIOS]] sebagai protokol lapisan ''transport''-nya, berjalan di atas stack protokol [[TCP/IP]], [[IPX/SPX]], atau [[NetBEUI]] secara opsional, sekarang protokol SMB mendukung secara penuh protokol-protokol lapisan transport tersebut. Sebuah klien CIFS yang hendak mengakses sebuah file server atau print server akan membuat sebuah koneksi dengan server (dengan menggunakan protokol yang kompatibel di antara dua buah host yang saling berkomunikasi tersebut). Selanjutnya, klien akan membuat sesi NetBIOS di atas sesi koneksi yang sebelumnya dibuat, sebelum akhirnya klien pun menggunakan sesi NetBIOS tersebut untuk membuat sesi ''print-sharing'' atau ''file-sharing'' dengan server. Jika protokol [[TCP/IP]] digunakan sebagai protokol lapisan transport-nya, klien CIFS akan membuat sesi NetBIOS over TCP/IP, dengan membuka [[Port TCP|port 139]] yang terdapat pada sisi server.
Ketika Windows 2000 dirilis, yang di dalamnya terdapat komponen Distributed File System (DFS), dan berkurangnya dukungan Microsoft terhadap protokol NetBIOS, ''file server'' pun dapat secara langsung menyediakan layanan ''file sharing'' dan ''print sharing'', tanpa menggunakan NetBIOS lagi. Klien dapat membuka koneksi langsung dengan server dengan membuat sesi koneksi TCP dengan menggunakan port 445.
== Operasi CIFS ==
[[
Langkah-langkah yang terjadi dalam protokol CIFS dapat diringkas menjadi hal-hal seperti di bawah ini:
# Klien SMB/CIFS akan menentukan alamat IP dari server dan membuat koneksi dengan server SMB/CIFS dengan membuka [[Port TCP|port TCP 445]] (koneksi langsung) atau [[Port TCP|port TCP 139]] (jika protokol [[NetBIOS over TCP/IP]] digunakan) pada sisi server.
Baris 76:
|}
=== Fitur ''Read-Ahead'' dan ''Write-Behind'' ===
<!--sumber: Windows NT 4.0 Server Resource Kit-->
Untuk meningkatkan performanya, SMB dan CIFS mendukung fitur operasi ''read-ahead'' dan ''write-behind''. Dengan menggunakan ''read-ahead'', klien dapat memasukkan data yang telah dibaca ke dalam cache yang dimilikinya secara lokal, sehingga ia tidak akan meminta lagi kepada server ketika hendak melihat blok selanjutnya dari data yang ia kehendaki. Sementara ''write-behind'' mengizinkan klien untuk melakukan operasi penulisan (''write'') terhadap sebuah berkas dan dimasukkan ke dalam ''cache'' terlebih dahulu, sebelum di-''upload'' ke server, yang lebih efisien jika dibandingkan dengan mengirimkan setiap operasi read dan write secara terpisah.
=== Fitur ''Lock'' dan ''Unlock'' ===
<!--sumber: Windows NT 4.0 Server Resource Kit-->
Berkas yang terdapat di dalam server juga dapat dikunci atau dibuka. Sebuah berkas yang tidak dikunci (''unlocked'') adalah berkas yang tidak ada klien yang diberikan hak akses eksklusif untuk melakukan pembacaan dan penulisan terhadapnya, sementara berkas yang dikunci (''locked'') adalah berkas yang terdapat klien yang diberikan hak akses eksklusif untuk melakukan pembacaan dan penulisan terhadapnya. CIFS mendukung penggunaan cache (''read-ahead'' dan ''write-behind''), baik terhadap berkas yang dikunci atau berkas yang tidak dikunci, karena berkas tersebut dianggap "aman" selama tidak ada klien yang sedang melakukan penulisan secara eksklusif terhadapnya. Jika klien mencoba untuk menulis ke sebuah berkas, maka ia harus memberikan data yang hendak ditulisi kepada server untuk selanjutnya ditulisi oleh server atau dapat meminta server untuk mengunci berkas tersebut. Cara kedua merupakan cara yang sering digunakan.
=== ''Opportunistic Lock'' (''Oplock'') ===
<!--sumber: Windows NT 4.0 Server Resource Kit-->
Ketika klien sedang menulis ke dalam sebuah berkas dalam sebuah ''CIFS server'', maka akan lebih efisien bagi klien untuk menyangga (''buffer'') data yang hendak ditulisi dan mengirimkannya sebagai sebuah ''request'' bertumpuk. Akan tetapi, hal ini dapat meningkatkan kemungkinan bahwa berkas yang sama juga dibaca oleh klien yang lain dan data juga mungkin ditulisi oleh klien tersebut. Untuk membantu klien meningkatkan efisiensi penyanggaan datanya, CIFS menawarkan fitur ''opportunistic lock'' terhadap berkas secara keseluruhan, atau sebagian dari berkas sehingga ia tidak dapat ditulisi secara simultan oleh klien lainnya.
Baris 92:
* ''Level II Oplock''
* ''Batch Oplock''
==== ''Exclusive Oplock'' ====
Dalam ''exclusive oplock'', sebuah klien (ambil contoh Klien A) meminta kepada ''server'' untuk mendapatkan akses secara eksklusif terhadap sebuah berkas, sehingga Klien A merupakan klien satu-satunya yang diizinkan untuk menulisi data ke dalam berkas tersebut. Ketika Klien A membuka berkas, ia akan meminta ''exclusive oplock'' dari server. Jika ada klien lainnya (ambil contoh Klien B) yang sedang membuka berkas yang bersangkutan, server akan menolak permintaan ''exclusive oplock'' dari Klien A. Ketika hal ini terjadi, Klien A tidak menyangga data dan tidak melakukan operasi ''read-ahead''. Ketika tidak ada lagi klien yang membuka berkas tersebut, barulah server memberikan ''exclusive oplock'' kepada Klien A, dan selanjutnya Klien A pun dapat melakukan operasi ''read-ahead'' dan melakukan penyanggaan terhadap data yang hendak ditulisi ke dalam berkas. Jika ada klien lagi yang mencoba untuk membuka berkas ketika Klien A sedang memiliki ''exclusive oplock'' terhadap berkas (ambil contoh Klien C), server akan menginstruksikan kepada Klien A untuk membuka kunciannya. Dengan membuka kunciannya, maka Klien A harus memberikan ''lock'' yang disangganya atau menulis data yang sedang ia pegang di dalam ''buffer'' ke dalam berkas. Setelah kunci dibuka, maka Klien C pun dapat mengakses berkas yang bersangkutan.
==== ''Level II Oplock'' ====
''Level II Oplock'' mengizinkan beberapa klien untuk membuka berkas yang sama, sehingga tidak ada klien yang dapat menulisi berkas yang bersangkutan secara bersamaan, melainkan secara bergantian.
==== ''Batch Oplock'' ====
''Batch oplock'' seringnya digunakan oleh aplikasi-aplikasi yang menjalankan perintah-perintah yang ditumpuk (''batch'') yang terdiri atas beberapa operasi untuk membuka dan menutup berkas secara berulang-ulang yang akan dieksekusi secara berurutan.
{{Uncategorized|date=Januari 2023}}
|