Parallel Virtual Machine (disingkat PVM) adalah sebuah perangkat lunak yang digunakan untuk pembuatan jaringan komputer paralel. Perangkat lunak ini didesain sedemikian rupa untuk mengizinkan sebuah jaringan komputer yang heterogen yang terdiri atas mesin yang menjalankan sistem operasi Windows atau Unix agar digunakan sebagai sebuah prosesor paralel tunggal yang terdistribusi. Hal ini bertujuan untuk menyelesaikan beberapa masalah komputasi secara lebih murah dengan menggunakan kemampuan pemrosesan dan memori dari komputer-komputer yang terjaring tersebut. Perangkat lunak itu sendiri bersifat portabel, dan kode sumbernya pun tersedia secara bebas melalui netlib, yang sekarang telah dikompilasi untuk digunakan oleh beragam jenis komputer, dari mulai laptop hingga superkomputer Cray.
PVM mengizinkan pengguna untuk menggunakan perangkat keras komputer yang telah ada untuk menyelesaikan problem yang lebih rumit pada harga yang lebih murah. PVM juga digunakan sebagai alat bantu dalam akademisi, khususnya untuk mengajarkan pemrograman paralel (dalam fakultas ilmu komputer, dan tentu saja digunakan untuk menyelesaikan beberapa masalah praktikal.
Versi pertama dari PVM dikembangkan di ORNL pada tahun 1989, dan lalu setelah dikembangkan dari awal kembali oleh University of Tennessee, versi 2 pun dirilis pada bulan Maret 1991. Versi 3 dirilis pada 1993 dan mendukung fitur toleransi kesalahan (fault-tolerance;;) dan portabilitas yang lebih baik. Versi terbarunya adalah 3.4.6 yang dirilis pada tanggal 2 Februari 2009.
PVM pun terus dikembangkan secara aktif, meskipun maturitas dan stabilitas relatif yang ditunjukkannya tidak seberapa signifikan. PVM dianggap sebagai sebuah langkah baru dalam tren pemrosesan paralel modern dan juga grid computing. Penggunaannya pun banyak, dan kini pun bermunculan beberapa binding bahasa pemrograman yang baru (seperti halnya modul dalam bahasa Perl
Parallel::PVM, yang ada dalam pengembangan yang aktif). Antarmuka Perl dirilis di bawah Artistic License, meski PVM sendiri dirilis dengan lisensi BSD License dan GNU General Public License.
.
Detail
Komputer-komputer individual dapat saja menggunakan multiprosesor dengan memori bersama atau memori lokal, super komputer dengan prosesor vektor, beberapa jenis mesin pemrosesan grafik, atau workstation dengan prosesor skalar, dan tentu saja komputer pribadi (PC) yang dapat saling dihubungkan dengan beragam jenis interkoneksi jaringan komputer, mulai dari Eternet atau FDDI.
PVM terdiri atas sebuah lingkungan runtime dan pustaka untuk melakukan message-passing, manajemen tugas serta manajemen sumber daya dan tentu saja notifikasi saat terjadi kesalahan (fault notification). Memang PVM tidak secara otomatis membuat sebuah paket program komersial untuk berjalan lebih cepat, tapi, PVM menyediakan banyak fungsi yang powerful untuk secara manual melakukan paralelisasi sebuah program sumber yang telah ada, atau untuk menulis program baru yang menggunakan konsep komputasi terdistribusi/komputasi paralel.
Perangkat lunak PVM harus secara spesifik diinstalasikan di atas masing-masing komputer yang hendak digunakan dalam sebuah mesin
Virtual (
Virtual Machine). Hingga sekarang tidak ada cara otomatis untuk menginstalasikan program ke dalam komputer jarak jauh melalui PVM, meskipun hanya menyalin folder/direktori pvm3/lib dan pvm3/bin ke komputer yang lain (lalu menyunting $PVM_ROOT dan $PVM_ARCH) cukup dapat menjalankan program PVM. Namun, melakukan kompilasi atau membangun program PVM membutuhkan instalasi penuh dari PVM.
Program-program pengguna yang ditulis dalam bahasa pemrograman C, C++ atau Fortran dapat mengakses PVM melalui rutin-rutin pustaka yang telah disediakan.
PVM juga mendukung broadcasting melalui PVM_bcast yang dapat mengirim semua proses dalam sebuah kelompok dan juga multicasting melalui PVM_mcast yang mengirim pesan ke sebuah daftar tertentu dari proses.
Lihat juga
Virtual Machine
CORBA
Globus Alliance
Occam programming language
Ease programming language
Linda (coordination language)
Calculus of communicating systems
Calculus of Broadcasting Systems
Message Passing Interface (MPI)
Referensi
Artikel ini berdasarkan bahan-bahan dari Free On-line Dictionary of Computing, yang diberi lisensi GFDL.
Pranala luar
PVM home
PVM++: A C++-Library for PVM
Free library for code mobility
PVM in the Parawiki Diarsipkan 2006-10-04 di Wayback
Machine.