Install Server Message Queue RabbitMQ di Ubuntu 12.04


Sebagai programmer php yang mencoba jadi mahir, kita harus belajar dan terus belajar untuk mencapai mimpi. Selain dengan belajar, untuk mencapai mimpi kita harus tidur. Seseorang yang akan melakukan aktivitas tidur biasanya melakukan rangkaian aktivitas lain seperti cuci muka, sikat gigi dan ganti baju. Coba bayangkan kita menjadi pengasuh panti asuhan. Ketika mendekati jam tidur, kita dan pengasuh lain harus melakukan rangkaian aktivitas mencuci muka anak, membantu sikat gigi dan ganti baju. Misal kita mengawasi dan membantu seorang anak untuk tidur, kita harus menunggui dia cuci muka, kemudian menunggui ketika dia sikat gigi, kemudian menunggui ketika sang anak ganti baju. Untuk menunggui satu anak bisa dibutuhkan waktu 15 menit, gimana kalo banyak anak? Di situlah message queuing diperlukan, setiap pengasuh punya tugas masing-masing, ada yang menunggui cuci muka, sikat gigi, dan ganti baju.
Cukup tentang aktivitas tidurnya, sekarang kita implementasikan kisah tadi ke aplikasi php. Misal ada satu user yang upload gambar, kemudian gambar itu harus di-crop, kemudian datanya dimasukkan ke database. Dari ketiga proses itu, proses crop memakan waktu cukup lama sehingga user harus menunggu proses crop (disusul insert ke database) selesai untuk mendapatkan notifikasi bahwa gambarnya telah di-upload. Karena prosesnya lama, ada kemungkinan terjadi timeout. Ketika terjadi timeout di proses crop,  proses sluruhnya akan gagal seluruhnya. Dalam hal ini diperlukanlah suatu metode pemberian antrian tugas.
Salah satu cara lama yang too mainstream adalah dengan membuat database antrian tugas. Dalam kasus ini misal ada program php yang tugasnya ngecrop, dia akan cek di database antrian ada gak yang belum dicrop, kalo ada tugas dia proses, kalo gak ada tugas dia gak ngapa-ngapain. Masalah utama dari metode ini adalah looping-nya itu. Setiap saat si crop.php harus ngecek database padahal belum tentu ada tugas buat dia. Metode kaya gitu kan ngeborosin memori, akses io, dan prosesor. Mendingan si crop.php ini jalannya kalo ada antrian proses crop aja! Gimana dong solusinya? Karena judulnya tentang message queue, so pasti solusinya pake message queue dong. Kali ini saya mau ajak temen-temen tuk instalasi dan konfigurasi RabbitMQ. Website resmi si RabitMQ ada di http://www.rabbitmq.com. Sekarang mari install si RabbitMQ ini di Ubuntu 12.04.
Supaya terhubung dengan apt server RabbitMQ, mari kita tambahin sources-nya di Ubuntu. Buka terminal, ketik perintah sebagai berikut:
sudo gedit /etc/apt/sources.list
Abis itu tambahin “deb http://www.rabbitmq.com/debian/ testing main” di akhir baris. Ni tampilannya waktu saya tambahin:
sourcelist rabitmq
Tampilan sourcelist menggunakan gedit
Simpen terus tutup geditnya. Abis itu supaya gak ada warning public key, coba dari terminal pindahin aktif direktorinya ke documents, terus ketik perintah sebagai berikut:
wget http://www.rabbitmq.com/rabbitmq-signing-key-public.asc
sudo apt-key add rabbitmq-signing-key-public.asc
Sekarang jalanin perintah update apt, sebagai berikut:
sudo apt-get update
Setelah menyelesaikan proses di atas, baru deh sekarang kita install RabbiMQ:
sudo apt-get install rabbitmq-server
Buat ngatur pembatasan file yang di-handle, kita bisa edit ulimit di file /etc/default/rabbitmq-server.
Untuk menjalankan rabbitmq di php, dibutuhkan library. Web rabbitmq merefer kehttps://github.com/rabbitmq/rabbitmq-tutorials/tree/master/php untuk library php-nya. Kita harus pake minimal php 5.3 supaya bisa ngejalanin php-amqlib. Linux kita juga harus terinstall git untuk mendownload. Instalasi php-amqlib sebagai berikut:
git clone http://github.com/videlalvaro/php-amqplib.git lib/php-amqplib
Tampilan di monitor saya:

Cloning into 'lib/php-amqplib'...
remote: Counting objects: 1260, done.
remote: Compressing objects: 100% (582/582), done.
remote: Total 1260 (delta 717), reused 1161 (delta 627)
Receiving objects: 100% (1260/1260), 5.21 MiB | 212 KiB/s, done.
Resolving deltas: 100% (717/717), done.
Setelah dilakukan, nanti file-file dari php-amqlib akan masuk ke folder_aktif/lib/php-amqlib. Copy-in tuh folder lib ke website kita, terus copy juga file-file di https://github.com/rabbitmq/rabbitmq-tutorials/tree/master/php ke web kita. Abis itu coba deh jalanin php receive.php terus buka terminal baru, jalanin php send.php. Di terminal receive.php bakal muncul pesan:

[*] Waiting for messages. To exit press CTRL+C
[x] Received Hello World!
Kalau kita jalanin lagi di terminal lain php send.php maka si terminal receive bakal nampilin lagi[x] Received Hello World!, artinya pesan telah diterima dan setelah itu pesan dihilangkan dari queue.
Supaya makin mantap, silakan baca tutorial lengkap di website resminya, dijamin lebih joss daripada di sini. Demikian instalasi RabbitMQ, selanjutnya nanti kita bahas penggunaan RabbitMQ. (Arief Hidayatulloh)

PHP Mahir, Mahirin skill PHP lo!

Tidak ada komentar:

Posting Komentar

Jika Anda memiliki tanggapan dan pertanyaan silakan isi form komentar berikut, kami akan menjawabnya segera. :)