Scala adalah bahasa pemrograman general purpose yang dirancang untuk mengungkapkan pola pemrograman umum secara cara ringkas, elegan, dan aman. Scala dapat dengan baik mengintegrasikan fitur bahasa berorientasi obyek dan fungsional, memungkinkan Programmer Java dan lainnya lebih produktif. Kode ukuran biasanya berkurang dengan faktor dua sampai tiga bila dibandingkan dengan aplikasi Java yang setara.
Banyak perusahaan yang telah bergantung pada Java untuk aplikasi bisnis penting meraka beralih ke Scala untuk meningkatkan produktivitas pengembangan mereka, skalabilitas dan kehandalan aplikasi secara keseluruhan.
Read more…
Hampir semua universitas atau perguruan tinggi di Indonesia mempunyai situs, baik untuk level universitas, unit/fakultas, jurusan/program studi sampai dengan laboratorium, dosen, unit kegiatan mahasiswa bahwa blog. Begitu pula pada Universitas Trunojoyo. Makin lama makin banyak informasi yang tersedia pada website-website di bawah domain trunojoyo.ac.id, bukan hanya www.trunojoyo.ac.id.
Sayangnya, ada beberapa hal yang sangat menyusahkan pengunjung mendapatkan informasi secara lengkap dan terpadu dari website-website tersebut. Pertama, situs web utama, www.trunojoyo.ac.id tidak menyediakan akses ke berbagai situs lain yang berada di bawah domain yang sama. Pengunjung harus mengetahui setiap alamat (URL) yang perlu dikunjungi. Kedua, pengunjung tidak dapat mengetahui dimana saja informasi terkait tersedia. Misalnya beasiswa, jika pada situs web Fakultas Teknik terdapat pengumuman beasiswa XYZ, dimana informasi lebih detail atau terkait tersedia? di Fakultas lain atau di Universitas?
Read more…
Categories: Arsitektur Komputer, Data Mining & IR, Jaringan Komputer, Pemrograman Java, Pemrograman Web, Sistem Operasi, Sistem Terdistribusi
Tags: crawler, information retrieval, search engine, text mining, web
Pada dasarnya, stream atau aliran data di jaringan dibaca byte demi byte (karakter demi karakter, satu karakter memerlukan 1 byte memory, 8 bit).
Berikut ini adalah kode program yang dapat digunakan untuk membaca halaman web byte demi byte menggunakan kelas URLConnection:
//Download halaman web menggunakan URL & URLConnection
import java.io.BufferedInputStream;
import java.net.URL;
import java.net.URLConnection;
public class URLConnectionPage {
public static void main(String[] args) throws Exception {
URLConnection urlc = new URL("http://localhost").openConnection();
BufferedInputStream buffer = new BufferedInputStream(urlc.getInputStream());
int byteRead;
while ((byteRead = buffer.read()) != -1){
System.out.print((char) byteRead);
}
buffer.close();
}
}
Jika anda tetap ingin membaca stream data web yang diterima baris demi baris, kode program di bawah ini dapat digunakan. Yang terjadi dibelakang layar tetap, yaitu membaca byte demi byte, perbedaan hanya dari sisi programan:
import java.net.*;
import java.io.*;
public class URLConnectionReader {
public static void main(String[] args) throws Exception {
URL unijoyo = new URL("http://www.trunojoyo.ac.id/");
URLConnection yc = unijoyo.openConnection();
BufferedReader in = new BufferedReader(new InputStreamReader(yc.getInputStream()));
String inputLine;
while ((inputLine = in.readLine()) != null)
System.out.println(inputLine);
in.close();
}
}
Halaman web, pada sisi client berupa tag HTML dan pendukungnya, menyediakan beberapa properti yang sangat berguna bagi suatu web crawler. Informasi seperti URL, tanggal modifikasi terakhir, jumlah karakter (termasuk white space), jenis content dan Expirenya disediakan oleh Web server.
Kode program berikut memperlihatkan cara mengakses beberapa informasi penting tersebut. Detail dari apa yang disediakan oleh oleh URLConnection untuk keperluan ini dapat dilihat pada dokumentasi Java (J2SE):
//URLConnection.
import java.net.*;
import java.io.*;
import java.util.Date;
class URLConnectionInfo {
public static void main(String args[]) throws Exception {
int c;
URL hp = new URL("http://localhost");
URLConnection hpCon = hp.openConnection();
System.out.println("Date: " + new Date(hpCon.getDate()));
System.out.println("Content-Type: " + hpCon.getContentType());
System.out.println("Expires: " + hpCon.getExpiration());
System.out.println("Last-Modified: " + new Date(hpCon.getLastModified()));
int len = hpCon.getContentLength();
System.out.println("Content-Length: " + len);
if (len > 0) {
System.out.println("=== Content ===");
InputStream input = hpCon.getInputStream();
int i = len;
while (((c = input.read()) != -1) && (--i > 0)) {
System.out.print((char) c);
}
input.close();
} else {
System.out.println("No Content Available");
}
}
}
Contoh di bawah ini mengakses web server menggunakan kelas URL dari paket .net. Sama sebagaimana contoh pemanfaatan kelas socket, kode ini menampilkan isi (dari sisi client) dari halaman HTML yang diakses:
import java.net.*;
import java.io.*;
public class GetURLPage {
public static void main(String args[]) {
try {
URL url = new URL("http://localhost/");
BufferedReader dis = new BufferedReader(new InputStreamReader(url.openStream()));
String line;
while ((line = dis.readLine()) != null) {
System.out.println(line);
}
dis.close();
} catch (Exception e) {
System.out.println(e);
}
}
} // akhir dari GetURLPage.java
Kode program singkat di bawah ini memperlihatkan cara mengakses suatu web site dan mengambil contentnya:
import java.io.*;
import java.net.*;
public class GetSocketPage {
public static void main(String args[]) throws IOException {
//bangun koneksi ke server web, port 80
Socket sock = new Socket("trunojoyo.ac.id", 80);
//siapkan saluran input & output
BufferedReader dis = new BufferedReader(new InputStreamReader(sock.getInputStream()));
PrintStream ps = new PrintStream(sock.getOutputStream());
//kirim pesan GET ke server web
ps.println("GET /index.html");
String line;
//baca baris demi baris file index.html, cetak ke screen
while ((line = dis.readLine()) != null) {
System.out.println(line);
}
//tutup koneksi ke server
sock.close();
}
} // akhir dari GetSocketPage.java
Hasil eksekusinya akan menampilkan halaman HTML dari web site yang disebutkan, termasuk kode javascript dan CSS yang terdapat dalam halaman HTML tersebut.
Bagaimana mendapatkan MAC addres dari suatu interface jaringan, Ethernet card misalnya? Java (1.6 ke atas) menghadirkan metode bernama getHardwareAddress() yang disediakan oleh kelas NetworkInterface dalam paket java.net. MAC Address yang dihasilkan masih dalam bentuk array BYTE, sehingga harus dikonversi ke bentuk HEXA agar sesuai dengan standard yang selama ini berlaku.
Silakan tulis dan coba kelas MACAddress di bawah ini:
/*
* Program kecil untuk mendapatkan alamat hardware
* dari suatu interface ber-IP address.
* untuk mencoba program ini, pastikan interface aktif.
*/
package netprog2010;
import java.net.InetAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.net.UnknownHostException;
public class MACAddress {
public static void main(String[] args) {
try {
InetAddress address = InetAddress.getLocalHost();
//InetAddress address = InetAddress.getByName("172.16.1.8");
//Ambil NetworkInterface dari host dan baca alamat hardware (MAC)nya
NetworkInterface ni = NetworkInterface.getByInetAddress(address);
if (ni != null) {
byte[] mac = ni.getHardwareAddress();
if (mac != null) {
//Ekstrak setiap array dari mac dan konversi ke hexa
//mengikuti format 08-00-27-DC-4A-9E.
System.out.print("MAC Address dari interface " + address + " adalah ");
for (int i = 0; i < mac.length; i++) {
System.out.format("%02X%s", mac[i], (i < mac.length - 1) ? "-" : "");
}
System.out.println();
} else {
System.out.println("Address tidak ada atau tidak dapat diakses.");
}
} else {
System.out.println("Network Interface untuk alamat tersebut tidak ditemukan.");
}
} catch (UnknownHostException e) {
//e.printStackTrace();
} catch (SocketException e) {
//e.printStackTrace();
}
}
}
Contoh hasil eksekusi adalah:
MAC Address dari interface d3tmj-PC/172.16.1.8 adalah 00-21-CC-4C-E3-9F
OK, semoga bermanfaat
Pervasive DataRush merupakan suatu pustaka Java untuk mengembangkan aplikasi highly-parallel data-intensive yang dapat berjalan dan berkembang pada perangkat keras multicore tanpa harus menguasai teknik-teknik pemrograman concurrent yang dirasakan sulit oleh banyak pemrogram.
DataRush memungkinkan pengembang mendayagunakan suatu pustaka komponen yang extensive dan customizable mulai dari yang sederhana sampai sangat kompleks menggunakan prinsip-prinsip dataflow. Komponen dapat bersifat “self-composing”, dengan fasilitas late-binding agar secara dinamis mampu mengatur strategi eksekusi paralel. Menggunakan Pervasive DataRush, pengembang dapat membangun dataflow yang “simple” dan disusun ke dalam graf eksekusi dataflow yang scalable, sangat parallezid, sehingga secara penuh siap untuk mengeksplrasi hardware multicore yang menjadi pijakan pengembangan aplikasi. Banyak hambatan klasik di sekitar concurrent programming seperti synchronization, dan thread management ditangani oleh framework Pervasive DataRush.
Library ini dapat diambil di http://www.pervasivedatarush.com/.
Komputasi terdistribusi atau tersebar berhadapan dengan sistem hardware dan software yang mengandung lebih dari satu elemen pemroses atau storage, proses-proses yang konkuren, atau banyak program yang berjalan dalam suatu domain yang dikendalikan secara longgar atau ketat.
Read more…
Bagian ini menjelaskan pembangunan thread pooled server sederhana dalam Java. Daripada memulai suatu thread baru per koneksi yang masuk, koneksi dibungkus di dalam suatu Runnable dan ditangani oleh suatu thread pool dengan jumlah thread tetap. Runnable dipelihara pada suatu antrian di dalam thread pool tersebut. Ketika suatu thread di dalam thread pool menjadi idle maka akan diambil suatu Runnable dari antrian dan mengeksekusinya.
Read more…
Komentar Terakhir