1 IMPLEMENTASI JAVA RMI PADA RANCANG BANGUN TES

advertisement
IMPLEMENTASI JAVA RMI PADA RANCANG BANGUN TES TOEFL ONLINE
BERBASIS WEB
Sri Lestari1), Maman Somantri2), R. Rizal Isnanto2)
Jurusan Teknik Elektro, Fakultas Teknik, Universitas Diponegoro
Jln. Prof. Sudharto, Tembalang, Semarang, Indonesia
Abstract
The development of Java can’t be separated from the development of the Internet that already connects
millions of computers in a single global network. Current technological developments likely to lead to a
distributed system with client-server communication and where the functions a computer can be used in a
coordinated manner with several other computers.
At the end of this task will be created a system that implements a distributed system with client-server
application systems are built using Java Remote Method Invocation technology on the online application webbased TOEFL test. To build such a system, it can be done making web-based applications using Java 2
Enterprise Edition, Java Server Face 2.0 as web programming, MySQL as a database, and Apache Tomcat as a
web server. The research steps include: systems requirements analysis, design methods include diagrams with
UML use-case, sequence diagram, class diagram, implementation or code generation program, and system
testing.
From the research results can be concluded that the Java RMI technology can be applied in a web-based
online test, Java RMI not only be built in one but to many computers, and the need for synchronization methods
to build a Java RMI technology is.
Keywords: Distributed System, Java RMI, Online TOEFL Test.
I.
komunikasi antara client dan server, JDBC untuk
mengakses basisdata soal. Komunikasi ini
dibangun dan diakes dengan platform yang sama
tetapi dalam mesin virtual yang berbeda dan
memberikan informasi secara timbal balik.
PENDAHULUAN
1.1 Latar Belakang
Perkembangan Java tidak lepas dari
perkembangan
internet
yang
telah
menghubungkan berjuta-juta komputer dalam
satu jaringan global. Jaringan ini memungkinkan
komputer-komputer tersebut untuk saling
berkomunikasi. Secara umum, semua mesin yang
terhubung ke internet dapat dikatagorikan dalam
dua tipe yaitu server dan client. Seperti halnya
dengan suatu komunikasi sistem terdistribusi
yang banyak digunakan dengan menggunakan
konsep terbuka yaitu komunikasi antar clientserver yang tersedia dalam berbagai platform
Bahasa pemrograman Java menyediakan
beberapa aplikasi untuk kedua situasi tersebut
dalam hal ini untuk situasi dimana pemrograman
dilakukan dengan bahasa yang sama, Java
menawarkan RMI (Remote Method Invocation)
sebagai alternatif dari dari teknologi sistem
terdistribusi dan meruapakan sebuah teknik
pemanggilan metode terpisah yang menggunakan
paradigma pemrograman berorientasi objek
(Object Oriented Programming).
Dalam penelitian ini dirancang dan dibahas
teknologi RMI sebagai salah satu teknologi
sistem terdistribusi yang diaplikasikan dalam
sebuah tes TOEFL online berbasis web sebagai
1.2 Tujuan
Tujuan penelitian tugas akhir ini adalah
untuk:
1. Dapat
mengetahui,
memahami,
dan
mengintegrasikan
teknologi
objek
terdistribusi ke dalam bahasa pemrograman
Java yang mendukung objek remote interface
dalam model komunikasi client-server
2. Mampu mengaplikasikan teknologi Java RMI
dengan arsitektur client-server dan membuat
aplikasi terdistribusi tes TOEFL Online
berbasis web.
3. Mengetahui dan memahami kelebihan dan
kekurangan implementasi teknologi Java
RMI.
1.3 Batasan Masalah
Agar tidak menyimpang dari pokok
permasalahan, maka Tugas Akhir ini mempunyai
batasan masalah:
1. Tugas Akhir ini membahas pembuktian
konsep dan teknologi sistem terdistribusi RMI
1
1) Mahasiswi Teknik Elektro Undip
2) Dosen Teknik Elektro Undip
2.
3.
4.
5.
6.
yaitu client dan server dalam aplikasi tes
TOEFL Online berbasis web.
Java RMI memungkinkan objek yang berjalan
di satu JVM untuk memanggil suatu metode
dari satu objek yang berjalan di JVM yang
lain.
Penelitian ini tidak membahas web aplikasi
tes TOEFL online.
Jaringan diterapkan hanya menggunakan
alamat IP Private.
Sistem operasi yang digunakan adalah
Windows 7.
Sistem ini hanya berjalan pada host yang
memiliki Java Virtual Machine, Java RMI,
dan Apache Server.
2.3 Java RMI
RMI didefinisikan sebagai sebuah fasilitas
standar Java dan merupakan salah satu teknologi
sistem terdistribusi yang menangani pemanggilan
(invocation) suatu metode secara jarak jauh
(remote) dalam suatu jaringan. Metode yang
dipanggil tersebut berada pada host server dan
dipanggil secara remote oleh host client pada
suatu jaringan. RMI juga disebut sebagai
jembatan penghubung antara satu aplikasi dengan
aplikasi yang lainnya.
Sistem RMI dibangun atas tiga lapisan yaitu
lapis stub/skeleton, lapis remote reference, dan
lapis transport. Tiap lapis dibangun dengan
menggunakan interface khusus dan didefinisikan
dengan protokol khusus. Oleh karena itu secara
lebih jelasnya dapat dilihat pada Gambar 2 yang
menunjukkan arsitektur RMI.
II. LANDASAN TEORI
2.1 Sistem Terdistribusi
Sistem terdistribusi adalah
kumpulan
komputer individu yang terhubung melalui
sistem jaringan komputer dan dilengkapi dengan
perangkat lunak sistem tedistribusi untuk
membentuk fasilitas komputer terintegrasi yaitu
sistem yang komponennya berada pada jaringan
komputer yang saling berkomunikasi dan
melakukan koordinasi hanya dengan pengiriman
pesan (message passing).
Aplikasi terdistribusi memberikan manfaat
yang cukup besar karena karakteristik yang
dimilikinya yaitu bersifat banyak pengguna,
penggunaan sumberdaya secara bersama-sama,
skalabilitas yang baik, efisien, toleransi terhadap
kesalahan, dan transparansi.
Gambar 2 Arsitektur RMI
Berikut penjelasan dari arsitektur RMI tersebut:
1. Lapis stub yang berlaku sebagai proxy yang
memiliki remote call.
2. Lapis Skeleton berada pada sisi server,
bertanggung jawab memanggil implementasi
pemanggilan objek yang sesuai bagi jaringan
untuk dikirim kembali ke client.
3. Lapis Remote Reference
Merupakan lapis yang tidak terlihat oleh
pengguna yang bertanggung jawab mengatur
komunikasi antara client-server dengan mesin
virtual Java.
4. Lapis Transport
Lapis TCP/IP-based yang bertanggung jawab
dalam mengadakan hubungan antara server
dan client.
Untuk mengetahui cara kerja RMI
ditunjukkan oleh Gambar 3.
2.2 Client-Server
Client-Server merupakan salah satu dari
jenis arsitektur sistem terdistribusi yang terdiri
atas 3 jenis arsitektur yaitu 2-tier, 3-tier dan ntier. Model client-server ini banyak dipilih
karena kejelasan peran dari komputer yang
terhubung dalam sistem jaringan tersebut.
Komputer server hanya bertugas memberikan
layanan kepada komputer client. Spesialisasi
layanan tersebut akan memudahkan dalam
permintaan layanan dan pengamanan. Gambar 1
merupakan arsitektur client-server.
Gambar 1 Arsitektur Model Client-Server
Gambar 3 Mekanisme kerja RMI
2
1. Dimulai saat RMI server akan mendaftarkan
(bind) nama objek ke RMI registry dengan
nama yang unik.
2. RMI registry dapat memberikan refeensi
pemanggilan terpisah objeknya ke RMI client
untuk melakukan pemanggilan .
3. RMI client dapat memanggil metode yang
berada di server.
4. RMI server mengirimkan respon setelah
dilakukan pemrosesan ke RMI client.
2.4 MySQL
MySQL adalah suatu pemrograman atau
sistem manajemen basisdata (kumpulan data
yang terstruktur) yang menggunakan dasar
bahasa SQL (Structured Query Language). SQL
merupakan bahasa query yang terstandardisasi
secara international untuk mengakses hubungan
basisdata. MySQL dirancang untuk menangani
basisdata yang besar dengan cepat, memiliki
tingkat keamanan, dan konektifitas yang tinggi.
Gambar 4 diagram use case admin
2.5 TOEFL
TOEFL merupakan tes bahasa Inggris yang
digunakan untuk megetahui tingkat kemampuan
seseorang dalam berbahasa Inggris. Nilai tes
TOEFL dapat menunjukkan sejauh mana
seseorang dalam menguasai bahasa Inggris. Tes
TOEFL dibagi dalam 3 (tiga) bagian, yaitu
1. Listening Comprehension yang terdiri atas
percakapan pendek, percakapan panjang Mini
Talks.
2. Structure and Written Expressionyang terdiri
atas Incomplete Sentence Error Recognition
3. Reading Comprehension terdiri atas bacaanbacaan pendek dan kemudian menjawab
pertanyaan yang berdasarkan pada bacaan
tersebut.
b. Diagram Urutan
Gambar 5 merupakan diagram checkServer2
urutan yang menunjukkan salah satu contoh
diagram urutan yang digunakan perancangan
implementasi ini.
Gambar 5 Diagram Urutan checkServer2
c. Diagram Kelas
Untuk membangun implementasi Java RMI
pada aplikasi tes TOEFL online ini digunakan
beberapa diagram kelas yang terdiri atas diagram
kelas toeflApi, toefl_server_2, toefl_server_3,
dan client. Gambar 6 menunjukkan diagram
kelas toeflApi.
III. PERANCANGAN SISTEM
1. Analisis dan Perancangan Implementasi
Java RMI pada Aplikasi Tes TOEFL
Online
Dalam perancangan perangkat lunak ini,
digunakan bahasa pemodelan Unified Modeling
Language (UML) yang terdiri atas diagram use
case, diagram urutan, diagram kelas, dan diagram
komponen.
a. Diagram Use Case
Dalam pengembangan perangkat lunak dalam
implementasi Java RMI ini dapat diidentifikasi
tiga buah aktor yaitu client, admin, dan server.
Gambar 4 menunjukkan salah satu diagram use
case.
Gambar 6 toeflApi
3
b. Server 2
Server 2 mempunyai antarmuka dan kelas
yang sama dengan Server 1, tetapi Server 2 ini
berfungsi sebagai bank soal berupa basisdata
Structure and Written Expression pada tes
TOEFL online.
2. Perancangan Topologi Sistem
Tugas Akhir ini dirancang untuk mengetahui
bagaimana
Java
RMI
dibangun
dan
diimplementasikan. Pada tahap perancangan
sistem ini berdasarkan komunikasi sistem
terdistribusi Java RMI yang dibangun untuk
memanfaatkan layanan model client-server
dalam suatu jaringan. Gambar 3 menunjukkan
arsitektur perancangan topologi Sistem RMI.
c. Server 3
Server 3 juga memiliki antarmuka dan kelas
yang sama dengan Server 1 dan 2, tetapi Server
3 ini berfungsi sebagai bank soal berupa
basisdata Reading Comprehension pada tes
TOEFL online.
IV. IMPLEMENTASI, PENGUJIAN, dan
ANALISIS
4.1 Implementasi Sistem
Untuk dapat membangun suatu aplikasi
sistem terdistribusi khususnya Java RMI yang
diimplementasikan dalam tes TOEFL online
dapat dilakukan dengan 7 langkah yaitu definisi
Remote Interface, definisi konstruktor untuk
objek yang dipanggil, implementasi pemanggilan
remote interface dan server, membuat
implementasi untuk setiap pemanggilan remote
method, membuat dan mengistalasi security
manager, membuat instansi objek untuk client,
mendaftarkan objek dengan Java RMI registry.
Gambar 7 Arsitektur Perancangan Topologi Sistem
RMI.
Setiap client di lingkungan sistem
melakukan permintaan kepada sever aplikasi,
serta server aplikasi memberikan respon berupa
layanan-layanan sesuai yang dipanggil oleh
client. Begitu juga jika ada pemanggilan
basisdata, aplikasi server melakukan permintaan
kepda server basisdata, kemudian server
database memberikan data sesuai permintaan
yang dipanggil. Perancangan arsitektur sistem
mengimplementasikan arsitektur three tier,
dimana terdapat dua buah server, yaitu server
basisdata dan server aplikasi. Client akan
memanggil metode ke server berdasarkan
referensi objek yang diperoleh dari RMI registry.
Komunikasi antara client dan server ini melalui
web
browser
yang
telah
disediakan.
Implementasi pada teknologi RMI ini
menggunakan 3 buah basisdata server yaitu:
a. Server 1
Server 1 pada RMI server ini berupa sebuah
antarmuka dan kelas. Antarmuka ini berupa
metode yang dipangil dari client yaitu
pemanggilan nama objek dan kelas pada server
yang menyediakan implementasinya. Server 1
ini merupakan server utama yang terdiri dari
bank soal Listening Comprhension, sebagai
penyimpan seluruh data aplikasi tes TOEFL
online, dan dapat menjadi bank soal untuk
mewakili Server 1 dan 2 apabila terjadi masalah
akses pada server tersebut.
4.2Pengujian Sistem dan Skenario Pengujian
1. Spesifikasi Perangkat Keras
Pada pengujian kali ini menggunakan dua
buah laptop dimana masing-masing laptop
mempunyai peran dan tugas sendiri-sendiri.
Laptop pertama digunakan sebagai server
utama dan basisdata Server 1 dengan spesifikasi
sebagai berikut.
a. Prosesor Intel Core i3 2,13Ghz
b. RAM 2 GB
c. Harddisk 320 GB
Laptop kedua akan digunakan sebagai Server
2 dan Server 3 dengan spesifikasi sebagai
berikut.
a. Prosesor Intel Core 2 D
b. uo 2 GHz
c. RAM 2 GB
d. Harddisk 160 GB
Laptop kedua akan digunakan sebagai client
dengan spesifikasi sebagai berikut.
a. Prosesor AMD
b. RAM 2 GB
c. Hardisk 320 GB
4
2. Kebutuhan Perangkat Lunak
Kebutuhan perangkat lunak untuk pengujian
sistem yang diperlukan untuk membangun suatu
teknologi RMI ini adalah:
a. Windows 7 Ultimate
b. MySQL
c. Apache Tomcat 7.0.14
d. Netbeans 7.0.1
e. J2EE
f. Framework JSF 2.0
kedua
yaitu
Structure
and
Written
Comprehension tanpa disadari Server 2 yang
menjadi server basisdata soal mati maka tes
TOEFL tersebut akan terus berlangsung, dan
terjadi perpindahan pembacaan basidata server
dari Server 2 ke Server 1 hal ini terjadi karena
Server 1 merupakan server utama yang dapat
menjadi server cadangan yang menyediakan
basisdata bagi kedua server yang lain bila terjadi
gangguan.
4.3 Pengujian Sistem
1. Pengujian RMI Server
Pengujian server ini dilakukan dengan
menggunakan host yang berbeda, dengan IP
yang berbeda bertujuan untuk mengecek apakah
kode program basisdata server dapat dibuka
dalam halaman web browser pada host berbeda.
4.4 Hasil Pengujian Keseluruhan Sistem
Hasil pengujian keseluruhan sistem dilakukan
dengan memberikan kuesioner kepada para
responden atas implementasi tekonologi java
yang diaplikasikan dalam tes TOEFL online
berbasis web. Pengujian tersebut dengan
memberi kesempatan kepada para responden
untuk mencoba menggunakan aplikasi tes
TOEFL online berbasis web yang dibangun
berdasarkan teknologi Java RMI, kemudian para
responden memberikan penilaian berdasarkan
kuesioner yang disediakan dan memberikan
kritik serta saran sesuai dengan pengamatan
mererka. Hal ini dilakukan untuk memberikan
penilaian terhadap kinerja sistem tes TOEFL
online berbasis web baik dari waktu tanggap
sistem, kelayakan sistem, tampilan antarmuka,
dan pengamatan terhadap kinerja teknologi Java
RMI tersebut.
Gambar 8 Pengujian Server 1
Gambar 9 Pengujian Server 2
V. PENUTUP
5.1 Kesimpulan
Dari perancangan,
implementasi,
dan
pengujian
tugas
akhir
yang
berjudul
“Implementasi Java RMI Pada Aplikasi Tes
TOEFL Online Berbasis Web”, maka dapat
diambil beberapa kesimpulan sebagai berikut.
1. Teknologi Java RMI ini dapat diaplikasikan
dalam Tes TOEFL online berbasis web.
2. Secara umum untuk membangun suatu
aplikasi sistem terdistribusi khusunya
teknologi Java RMI dapat dilakukan dengan
beberapa langkah yaitu mendefinisikan
remote interface, definisi konstruktor,
implementasi remote interface dan server,
membuat
implementasi
tiap
metode,
pengembangan
client,
membuat
dan
menginstal security manager, membuat
instansi objek untuk client, memulai RMI
registry, menjalankan server dan client.
3. Perlunya
sinkronisasi
metode
dalam
komunikasi implementasi RMI khususnya
Gambar 10 Pengujian Server 3
2. Pengujian Server Basisdata
Pengujian ini bertujuan untuk melihat status
dari basisdata server pada saat tes TOEFL
dilakukan. Sebelum tes TOEFL berlangsung
sistem melakukan cek server apakah semua
server RMI telah aktif, apabila server tersebut
aktif maka para member tes TOEFL dapat
melakukan tes tersebut. Tes TOEFL pertama
adalah Listening Comprehension, basisdata soal
ini berada pada Server 1, tes kedua adalah tes
Structure and Written Comprehension basisdata
soal ini berada pada Server 2, dan Listening
Comprehension berada pada Server 2. Misalnya
pada saat member melakukan tes TOEFL yang
5
dalam tes TOEFL online pada saat diakses
secara bersamaan oleh client.
4. Dari hasil implementasi teknologi java RMI
ini dapat diperoleh beberapa keuntungan
diantaranya beban kerja sistem menjadi
seimbang karena adanya pembagian fungsi
antara RMI server dan RMI client, dengan
teknologi RMI kemampuan akses data yang
cepat.
5. Teknologi Java RMI ini tidak hanya dapat
dibangun dalam satu komputer melaikan ke
banyak komputer.
6. Hasil penelitian berdasarkan hasil kuesioner
dari para responden dapat diketahui bahwa
sistem ini dapat dinyatakan bagus karena telah
memenuhi persentase kisaran penilaian yang
telah ditentukan.
[4]
[5]
[6]
[7]
5.2 Saran
Saran yang dapat digunakan sebagai bahan
untuk mengembangkan sistem ini menjadi lebih
baik dan untuk masa yang akan datang.
1. Perlu dilakukan penelitian lebih lanjut dengan
melakukan pengembangan aplikasi yang
kompleks dalam implementasi Java RMI.
2. Perlu dilakukan penelitian lebih lanjut
mengenai penggunaan jaringan internet untuk
teknologi Java RMI dan tidak hanya terbatas
pada jaringan lokal.
3. Perlu dilakukan apakah aplikasi dapat
diterapkan lintas sistem operasi, misalnya
antara Windows dengan Linux.
4. Perlu dilakukan penelitian lebih lanjut tentang
keamanan data untuk komunikasi clientserver pada teknologi Java RMI ini.
5. Perlu adanya penambahan kapasitas RAM
pada server karena hal ini sangat berpengaruh
pada kecepatan akes data antara server dan
client.
[8]
[9]
[10]
[11]
[12]
DAFTAR PUSTAKA
[1]
[2]
[3]
-----, “Java Remote Method Invocation
Specification”, Sun Microsystem, 2004.
Sun Microsystems. (2006). Java Remote
Method Invocation. Retrieved June 21,
2010, from 3 - RMI System Overview,
http://download.oracle.com/javase/6/docs/t
echnotes/guides/rmi/hello/helloworld.html#2, Maret 2011.
Eko Kurniawan Khannedy. “Membangun
Aplikasi Client-Server Dengan Java”,
[13]
[14]
[15]
6
http://eecchhoo.wordpress.com/2010/01/27
/video-tutorial membangun-aplikasi-clientserver-menggunakan-java/, Maret 2011.
----, “Java Remote Method Invocation”,
http://en.wikipedia.org/wiki/Java
remote_method_invocation, Agustus 2011.
Eko Kurniawan Khannedy. “MSQL dan
Java Database Connectivity”,
http://eecchhoo.wordpress.com,
Maret
2011
Eko Kurniawan Khannedy. “Mendeteksi
Terputusnya Koneksi dalam Remote
Method Invocation”,
http://eecchhoo.wordpress.com/2010/10/03
/mendeteksi_terputusnya_koneksi_dalam_
remote_method_invocation.htm,
September 2011.
--------, “The Java EE 6 Tutorial”. Oracle,
November 2010.
http://docs.jboss.org/hibernate/core/3.3/ref
erence/en/pdf/hibernate
reference.pdf,
Maret 2011
Christian Bauer and Gavin King. “Java
Persistence with Hibernate”. Second
Edition of Hibernate in Action. 1-93239488-5. Manning Publications Co. 2007.
http://www.manning.com/bauer2.
Optimus Prime. “Primfaces User’s Guide”.
Covers 2.2 and 2.2.1 Prime Teknoloji. 05
Februari. 2011.
R. Nurrohmah. “Client/Server dengan Java
Remote Method Invocation (Java RMI),
Sebuah Tutorial”, Jurnal Teknik Elektro
dan Komputer Emitor Vol. 3, No. 2,
September 2003.
Adrian Nathaniel Wikana, Joko Purwadi,
Restyandito. “Implementasi RMI Untuk
Tes Online Interaktif Multiuser Pada
LAN”, Jurnal Informatika Vol.3 No. 2,
April 2007.
Ed Burns and Chris Schalk. “The Complete
Reference Java Server Faces
2.0”, Mc. Graw Hill, 2010.
Deborah Philips. “Longman Complete
Course The TOEFL Test Preparation For
The Computer and Paper Test”, AddisonWesley Longman, 2001.
R. Ardianto. “Proyek Akhir Test TOEFL
Online Via Web”. Jurusan Teknologi
Informasi Politeknik Negeri Surabaya.
2006.
A. Wollrath, Roger Riggs, and Jim Waldo.
“A Distributed Object Model for the Java
System”. Proceedings of the USENIX
Conference
on
Object-Oriented
Technologies. Canada, June 1996.
BIODATA
Sri Lestari, saat ini sedang
menyelesaikan studi Strata-1 di
Jurusan Teknik Elektro, Fakultas
Teknik, Universitas Diponegoro
Semarang, konsentrasi Komputer
dan Informatika.
Menyetujui,
Dosen Pembimbing I
Maman Somantri, ST., MT.
NIP. 197406271999031002
Dosen Pembimbing II
R. Rizal Isnanto, ST., MM, MT.
NIP. 197007272000121001
7
Download