Category Archives: Open-Source

GNU Queue

This is another of my so-much-to-try-so-litle-time stuff : GNU Queue: clustering made easy.

Since computing performance are still increasing tremendously, clustering is still not a run of the mill stuff at the moment. Most of your work can still be done by a single PC in an acceptable amount of time, so there’s little incentive to make clustering more pervasive into our daily life.
But for those who needs it, GNU Queue seems to be a God-sent for its transparency and ease-of-use.

Now, if only there’s a consulting work coming, asking me to setup a Linux cluster, then I’ll be able to get myself to play with this thing, he he..

maxq: Alat bantu testing web-application

Dengan semakin berpindahnya development ke platform web, maka kebutuhan akan alat bantu nya menjadi semakin terasa.

Jika Anda pernah merasakan berbagai kebutuhan berikut :
1. Regression testing: memastikan bahwa situs Anda tetap berjalan sebagaimana mestinya setelah di update
2. HTML validity: memastikan bahwa situs Anda menghasilkan kode HTML yang sesuai dengan standar
3. Automatically extract information / do some action on a website

Maka MaxQ adalah salah satu solusinya.

[ Situs MaxQ ]

Beberapa tips migrasi ke Open source

Pengalaman saya melakukan migrasi ke open source, potensi cost yang paling besar itu biasanya di re-training staff.

Tips:

1. Program migrasi HARUS mendapat dukungan penuh dari manajemen

2. Migrasi dilakukan paling tidak dengan 2 tahap di setiap departemen.
Tahap pertama (pilot) memigrasikan beberapa staf saja. Tahap kedua baru memigrasikan sisanya.
Pada tahap pertama, tech.support full dari kita. Pada tahap kedua, kita sudah mendapat bantuan dari staf yang terlibat di tahap pertama.
Dan yang paling penting, para staf yang terlibat di fase pilot ini akan sangat membantu menghilangkan kecemasan kawan-kawannya.

3. Migrasi harus diatur dengan strategi yang tidak mengganggu proses kerja perusahaan sehari-hari

4. Walaupun sudah mendapat dukungan penuh dari manajemen, pendekatan interpersonal ke setiap departemen tetap membantu untuk memuluskan proses migrasi. Tips: cari siapa “tokoh” karyawan di setiap departemen, lalu dekati / dilobi sehingga simpati dengan proyek migrasi. Ini akan sangat membantu melancarkan program kerja yang sudah ada.

Sekarang beberapa migrasi sudah selesai, baru terasa enaknya:

1. infrastruktur IT lebih reliable

2. staf IT jadi ada banyak waktu luangnya, dan bisa diberdayakan untuk pengembangan sistem/dll – tidak melulu cuma overload melakukan maintenance (virus, install ulang Windows, dst) seperti sebelumnya

3. Fasilitas IT yang ada kini sangat banyak membantu staf dalam mengerjakan pekerjaan mereka sehari-hari – tidak lagi sering menghalang-halangi.

4. kalau pakai LTSP, ada banyak tambahan bonusnya.

5. penghematan biaya yang cukup signifikan jika dibanding migrasi ke solusi Microsoft, dalam berbagai kasus yang saya tangani – sekitar 75% short-term saving, lebih besar lagi jika solusi Microsoft-nya berbasis Terminal Server. Potensi long-term saving cukup signifikan jika menggunakan solusi LTSP.

Seperti biasa, YMMV – tapi saya rasa untuk kebanyakan kasus, hal-hal seperti di atas kini adalah kelaziman / bisa dibuat strateginya supaya demikian.

Apakah Anda punya tips-tips praktis dalam proses migrasi ke open source ? Silahkan sharing kepada kita semua disini.

Linux diagnostic software

One of the server under my supervision has started to experience problems since a few weeks ago. It has experienced several kernel Oops-es (equivalent to Windows’ BSOD I think), but sometimes it just crashed hard – no message whatsoever in the logfiles. This has me baffled for a while – I thought Fedora needed to be upgraded to the latest version at first. But then it was clear that even after updated with the latest updates, it’s still experiencing problems.

Somebody pointed out that memory should be the prime suspect at this case. So I ran memtest86, and true enough; it found hundreds of bad bits in the first 512MB.
Unfortunately, it is NOT possible to print out the error messages from memtest86, which will cause problem for me when I tried to return the memory module to the supplier. So I started to look around.
(note to self: recheck that these errors are not caused by wrong memory timing in BIOS)

Thankfully there’s memtester. I’ll give it a try probably tomorrow.

Along the way, I found several other relevant links:

[ An excellent guide on troubleshooting hardware problems on Linux ]
[ List of many diagnostic tools on Linux ]
[ Comprehensive list of tools and procedures for testing hardware on Linux ]

Hope you’ll find it useful.

GAIM: solusi komunikasi internal perusahaan

1. Sebuah perusahaan membutuhkan chatroom untuk komunikasi internalnya. Terutama akan sangat berguna untuk virtual meeting dengan kantor-kantor cabang.
Tetapi, fasilitas chatroom di berbagai pemberi layanan IM (Instant Messenger) di non-aktifkan. Chatroom public tidak bisa digunakan, karena bisa menyebabkan kebocoran rahasia perusahaan.

2. Selain itu, perusahaan ini menggunakan berbagai layanan IM untuk berkomunikasi baik internal maupun external (customer); ICQ, Yahoo Messenger, dll. Ada komplain bahwa ini menyebabkan terlalu banyak software yang terpasang di komputer user.

Solusi: Gaim.

1. Dibuat sebuah chatroom di irc.freenode.org, yang kemudian di set sehingga secret (tidak terlihat di channel list) dan kemudian di proteksi lagi dengan password. Kemudian dibuatkan sebuah account untuk setiap user, yang masing-masingnya diproteksi dengan password.

Namun pemakaian di user sangat mudah, cukup dengan dobel-klik di icon chat yang telah di setup.
Maka otomatis Gaim akan meng otentikasi user di jaringan Freenode, dan setelahnya meng otentikasi user di chatroom perusahaan.

Nilai plus; user bisa saling mentransfer file di chatroom tersebut (karena Gaim mendukung protokol transfer file dari IRC)

2. Gaim bisa berantar muka (interfacing) dengan berbagai layanan IM tersebut. Sehingga berbagai software client dari IM tersebut bisa dihapus, dan diganti dengan sebuah instalasi Gaim saja.

3. Nilai plus; karena Gaim tersedia baik di Linux maupun Windows, maka bisa dilakukan standarisasi IM client di perusahaan ini.
Tech.support hanya perlu berurusan dengan satu software IM – bukan banyak seperti sebelumnya.

[ Gaim : http://gaim.sourceforge.net ]

Membobol Firewall dengan OpenSSH & PuTTY

Bayangkan skenario berikut ini:

Kantor pusat dan kantor cabang bisa mengakses Internet. Namun, kedua-duanya tidak bisa diakses dari Internet – karena berada di balik NAT gateway

Divisi IT kemudian diminta untuk membuat kantor cabang bisa mengakses aplikasi web-based yang ada di kantor pusat, melalui koneksi Internet yang sudah ada. Aplikasi tersebut diakses di server 192.168.0.31 port 80.

Bagaimana caranya ?

Solusi:
head office ---> NAT1 ---> internet ---> serverkantor.com < --- internet <--- NAT2 <--- branch office

  • Sewa sebuah server di Internet.
    Contoh; Linode.com harganya sangat ekonomis untuk keperluan ini, dan layanan tech.supportnya sangat bagus.
  • Di kantor pusat, ketikkan:
    putty -ssh -C -2 -R 8001:192.168.0.31:80 -l username -pw password -N serverkantor.com
  • Di kantor cabang, ketikkan:
    putty -ssh -C -2 -L 81:localhost:8001 -l username -pw password -N serverkantor.com
  • Maka kini kantor cabang bisa mengakses aplikasi tersebut, dengan membuka browser dan lalu mengetikkan:
    http://localhost:81

note:

  • Ya, tutorial ini untuk di Windows. Saya yakin para pengguna *nix sudah tahu caranya di Linux/BSD/dll 🙂
  • -C : kompresi, akses ke aplikasi web-based tersebut menjadi kencang (serasa seperti di LAN) karena adanya fitur kompresi dari SSH ini.
  • -2 : menggunakan protokol SSH2; selain lebih aman, juga memungkinkan -N
  • -N : No shell; kita hanya menggunakan fitur port forwarding dari OpenSSH
  • -pw : hati-hati, karena tentu saja password jadi terlihat. Tapi di lain pihak, kadang otomatisasi ini diperlukan.
    Solusinya? Tergantung kebutuhan Anda, tapi kalau Anda terpaksa menggunakan switch -pw ini:

    1. Gunakan username yang non-priviledged / bukan root di serverkantor.com
    2. Lalu set agar user tersebut menggunakan shell /bin/false (alias tidak mempunyai akses shell)

Selamat mencoba.

note: Di sebelah mana "membobol firewall"-nya ...?
Jawab: Ganti "NAT gateway" di posting ini dengan "firewall", atau "firewall+NAT", atau "firewall+proxy", dst.

Referensi:
[ Breaking firewalls with OpenSSH and PuTTY ]
[ PuTTY User Manual ]

LVM notes

I’ve been using LVM, which is the default for Fedora Code installations. FC developers have managed to make it to “just work” in all of my installations. I understand that this is being pushed aggressively by RedHat, and I think it’s the right thing to do.
It’s another initiative which makes another enterprise computing feature to be available on ordinary / off-the-shelf hardware; which is always appreciated.

In case the “autopilot” doesn’t work, here’s a few notes on LVM. You just may find it useful.

BPPT Tawarkan Software Gratis (lisensi GPL)

Wow… saya speechless, kecuali untuk mengucapkan: well done BPPT.


Republika, Kamis, 23 Juni 2005 9:09:00

BPPT Tawarkan Software Gratis

JAKARTA –Software gratis BPPT itu adalah Komura,
Kantaya, Kasipena, dan Kutahu. Badan Pengkajian dan
Penerapan Teknologi (BPPT) kembali menawarkan software
alternatif. Beberapa di antaranya sudah pernah
diperkenalkan empat tahun silam.

”Ada empat aplikasi yang tersedia untuk beragam
kepentingan,” ujar Sulistyo Suhrowardi, direktur
Pusat Pengkajian dan Penerapan Teknologi Informasi dan
Elektronika, BPPT, kepada wartawan, Rabu (22/6).
Keempat software tersebut adalah Komura, Kantaya,
Kasipena, dan Kutahu. Aplikasi tersebut diluncurkan
sebagai software alternatif bagi mereka yang ingin
menggunakan peranti lunak berlisensi. ”Keempat
software yang dibuat BPPT ini merupakan software
General Public License (GPL),” jelas Sulistyo.

Kendati merupakan software GPL yang semestinya bisa
memungut biaya atas pendistribusian program komputer,
BPPT menggratiskan keempat software tadi. Dengan
sendirinya, keempat software tadi bisa dimanfaatkan
secara luas oleh masyarakat tanpa perlu membayar
sepeser pun. ”Pihak lain diperbolehkan menyalin,
mendistribusikan, dan bahkan modifikasinya,” ucap
Sulistyo.

Peluncuran Komura, Kantaya, Kasipena, dan Kutahu,
lanjut Sulistyo, dilakukan untuk menjawab kebutuhan
software berlisensi di masyarakat. Keempat software
itu diyakini bisa menggantikan posisi program-program
komputer bajakan yang marak dipergunakan masyarakat.
”Apalagi, cara penggunaannya tidak jauh berbeda
dengan software komersial,” katanya.

Sulistyo belum dapat memastikan apakah software yang
dikembangkan BPPT akan dijadikan sebagai software
resmi di kalangan institusi pemerintahan. Sejauh ini,
belum ada komitmen yang tegas soal hal tersebut.
”Pemerintah daerah Ponorogo (Jawa Timur), Bali, dan
Binjai (Sumatera Utara) malah sudah lebih dulu
memanfaatkannya,” ungkapnya.

Perangkat lunak yang disediakan untuk perkantoran itu
bertajuk Kantaya. Ini merupakan web-based groupwave.
”Kantaya bisa dijalankan di sistem operasi manapun.
Programnya mirip dengan Microsoft Exchange ataupun
Lotus Domino,” cetus Sulistyo.

Sementara itu, untuk pengelola warung internet
tersedia Komura. Komura adalah sistem jaringan
komputer murah. Software ini sangat cocok untuk warung
internet yang beroperasi sebagai game center. Sistem
jaringan komputernya terdiri dari server Linux WinBI
dan sejumlah terminal berupa komputer sederhana tanpa
hard-disk. ”Sayangnya, belum semua multiplayer game
bisa dimainkan di Komura,” sesal Sulistyo.

Dari segi skala ekonomi, Sulistyo memaparkan Komura
akan lebih ekonomis ketimbang pembelian komputer
secara terpisah. Kesimpulan ini berlaku untuk
pembelian komputer di atas empat unit. ”Komura
tersedia dalam CD bootable yang bisa langsung dipasang
untuk membangun jaringan komputer yang murah.
Peminatnya juga dapat men-download-nya di
www.software-ri.or.id.”

BPPT juga memperkenalkan Kasipena. Perangkat lunak ini
merupakan Kantaya untuk dunia pendidikan. ”Sedangkan
Kutahu adalah contoh e-learning sederhana,” ujar
Sulistyo. Keempat open source software tersebut
dipastikan Sulistyo kompatibel dengan
aplikasi-aplikasi desktop dari software komersial.
Format file-nya sudah standar. ”Penggunanya bisa
menyimpan file dalam format rtf ataupun pdf.”

Berdasarkan hasil riset, Kementerian Riset dan
Teknologi memantau hal-hal yang menjadi penghambat
penguasaan komputer di masyarakat. Riset ini
melibatkan kalangan pemerintah daerah, usaha kecil
menengah, serta dunia pendidikan. ”Biaya komunikasi
dan perangkat keras masih mahal, terbatasnya
pelatihan, dan kendala bahasa adalah penyebabnya,”
ungkap Sulistyo.

BPPT berharap ketersediaan software gratis dengan
kinerja yang dapat diandalkan akan membuat penguasaan
komputer di Indonesia meningkat. Terlebih, software
tersebut tersedia dalam tampilan bahasa Indonesia.
”Kami tidak memiliki target khusus dalam hal jumlah
pengguna.
(rei )

UPS di Linux

Sebuah UPS jelas sangat vital bagi sebuah server, tapi UPS itu sendiri tidak bisa banyak berguna jika mati lampu saat sedang tidak ada orang. Harus ada cara agar UPS bisa memberitahu server, sehingga server bisa mematikan dirinya sendiri dengan baik.

Sudah ada banyak UPS yang menyertakan software versi Windows untuk keperluan ini, tapi tidak terlalu banyak yang menyediakan versi Linux-nya. Jadi kemudian saya mulai mencari-cari solusi untuk ini:

[ PowerD ] – Kelihatannya sudah lama tidak di update, tapi mungkin ada gunanya bagi pengguna UPS yang sudah tua umurnya.
[ Network UPS Tools ] – Yang ini kelihatannya up to date, saya akan mencoba ini.
[ Linux UPS HOWTO ] – Berbagai panduan seputar penggunaan UPS di komputer Linux
[ Automatic UPS shutdown in Linux ]

Semoga bermanfaat.

Razia software : solusinya yang tepat & terjangkau

Razia dengan mengatasnamakan UU HAKI kini makin sering saja terjadi. Diawali oleh berbagai oknum aparat, yang biasanya menyita peralatan komputer dan meminta tebusan puluhan juta rupiah. Kini BSA juga kelihatannya sudah mulai mengambil ancang-ancang, bisa dilihat misalnya dengan iklannya yang berukuran besar di media massa ternama Indonesia.

Kebetulan beberapa waktu yang lalu saya baru selesai memigrasikan sebuah warnet ke solusi open-source, yaitu memanfaatkan Fedora Core 3 (FC) dan LTSP (Linux Terminal Server Project). Yang tercapai adalah :

  • Hemat puluhan juta rupiah (karena tidak usah membeli lisensi software)
  • Workstation bisa menggunakan komputer bekas / murah (Pentium II / III)
  • Maintenance bisa difokuskan di server saja
  • Tidak cemas lagi soal virus / spyware
  • dll

Kebetulan saya sedang memiliki sedikit waktu, maka saya telah tuliskan panduan instalasinya di posting ini. Semoga dapat bermanfaat bagi yang membutuhkannya.


Continue reading Razia software : solusinya yang tepat & terjangkau

Oracle versus MySQL

There have been a quite good discussions regarding Oracle and MySQL in [ this ] particular Slashdot post.

Clearly, in terms of high-end features, MySQL is FAR from matching Oracle.
Example, this is the shortest paragraph that quite nicely explains what Oracle really is. It’s just too mind-boggingly different.

Howeever, MySQL is more popular due to being available for free and good enough for most people. Which I have no problem with, in fact I’m using MySQL myself.

If you’re interested in more comparisons, then click here.

A note on database portability (since I was involved heavily on this topic for months) – even though this poster said that moving from Oracle is the hardest, in reality, I suspect that pretty much all database migration is painful. I’ve migrated a few apps which uses MySQL to Oracle, one of them actually already used ADODB – yet there were still problems that made me pull my hair.
MySQL broke quite a few ANSI-SQL standards – although to be fair, I imagine that Oracle extended quite a lot of them instead; so that if you have apps optimized for Oracle, then you’ll experience hell if you want to migrate it.

Back to the topic – the right way to compare Oracle / MySQL / whatever is not just strictly from performance / feature-set. If you do it this way, be prepared to be nastily surprised.

For example, the potential problem of going with Oracle are quite a lot as well.
First, you may encounter problems with its complex licensing scheme. Second, you need a highly skilled Oracle DBA specialist to be able to fully utilise it – jack-of-all-trade like me just won’t cut it. Third, if you think Oracle is expensive, the support cost may deter you from actually purchasing it (not buying support contract is plain suicide). Etc.

If those still doesn’t stop you from buying Oracle, then here’s a tip to make it easier on your budget.

In the end, the right way to compare (database) software is by comparing it against your own criterias / needs / requirements. Any other way, and you may be disappointed later in the future.

Apache versus IIS

I post this because I remember when I was in a meeting with several managers and other techies regarding a requirement to host an IIS-based web-application. The corporate standards for 5 years have dictated no use of IIS for external-facing web-services.
However, this particular application is specifically coded to run on IIS, and it’s meant to be publicly available over the Internet.

I started the meeting saying that, contrary to popular belief, IIS can actually be hardened to be secure enough to serve on Internet now. I can see rather shocked faces of people in the room, seeing this statement coming from an Apache “specialist” and open source advocate.
But that’s the truth as I know it, and I think nobody would benefit by hiding it.

However, the problem with IIS nowadays lies somewhere else :

  • Cost: Another popular belief is that IIS, being bundled by Windows server, is free. This can be very untrue. So far I’ve found 2 scenarios where using IIS may cost you dearly; for commercial webhosting, and when used to authenticate Internet users against Active Directory. And this may change (God knows for better or worse) in the future if Microsoft feels like it.
    Apache doesn’t and won’t cause you to suffer from these things.
  • Dependencies: I must admit that Microsoft is doing such an excellent job on getting their developers happy and make most of them uses Microsoft products. This is because Microsoft has made it easy to do so, and hard to do otherwise. However, this means that an IIS-application will be, most of the time, dependent to other Microsoft products – Active Directory for authentication, MS-SQL for database server, Exchange for email, and so on. So if one day you’re offered an IIS-application at a bargain price, examine again – it may require you to deploy a plethora of other products, that may cost you an arm and a leg.
  • Support: The dependency issue (see above) brings another issue – support. When you buy IIS and got Active Directory/MS-SQL/Exchange/etc as well; you need to ask yourself, do you have the staff to provide support to those products in case of problem ? If you don’t, then when a problem occured, then it will be you that’ll be under fire from the users – not Microsoft.
    (technical support ? obviously, you still think that paying thousand of dollars for silver level support will enable you to solve all problems in your mission critical apps in minutes – sorry, that’s not the case. Not even in hours in many cases. Yes, I’m being grim, or should I say realistic instead)
  • Security : Hey, didn’t I said that IIS6 is secure now ? OK, so IIS6 isn’t so full of holes like IIS4/5. However, when a hole is found, can you expect Microsoft to promptly patch it ? Unfortunately, this is not always the case. It’s already known that it may take even years sometimes for Microsoft to close a severe security hole. It doesn’t really give you a peace of mind, especially when you know that there are tools available in the underground communities that exploits this.
    Apache, and other open source software, on the other hand have been known to patch their security hole very quickly, sometimes in hours.
  • Lock-in : Miguel de Icaza and his Mono team does a stellar job making sure .NET is available on other platforms – not just Windows. However, the Windows lock is still there – a few months ago I was evaluating a .NET application, and found that it won’t run on Mono because it depends on an ActiveX component. So do be careful.
  • Security : Hey, again ?! Yes, I’ve seen cases where the security administrator wants to significantly secure the IT infrastructure by replacing the browser with alternatives (such as Firefox) – but can’t, because some critical IIS-applications tend to require, guess what, Internet Explorer.

I think there are a few more problems with IIS, but I’m very tired at the moment so that’s it for now. Hope it helps enlighten someone else out there.

MySQL tuning

I’ve been notified of “Too many connections” errors lately (thanks to logcheck), and I just realized that I think I’ve missed a few emails from Yahoogroups.

So looking around, I found out that MySQL’s table_cache was set to 64, and max_connections at 100. While table_cache really should be (max_connections * N), where N is the max number of tables that may be in a JOIN operation at anytime.

No wonder that, when checked with mysqladmin -p status, table_cache always peaked at its maximum.
O-u-c-h.

table_cache has been raised to 512, and the server is running happily now.

For those who suspect that they need to tune their MySQL installation, here are 2 good links :
[ Tuning MySQL ]
[ Tuning MySQL 4 ]

Enjoy.

Firefox is supporting Windows domination ?

Aaron said that making OpenOffice, Firefox, etc available on Windows is a mistake, because it helps people to stay on (using) Windows.

He missed one thing though – whether Joe Home User uses Windows or Linux is (in most cases) not his decision; it’s Dell/HP/Walmart/etc’s decision.

So, to gain the home user market, opensource community need to make Linux an offer that those company can’t refuse. We need to make them make Linux as their main OS in their computer – instead of Windows.

I think Linspire is doing a pretty good job in this regard. I hope others (Mandrake, RedHat, Ubuntu, etc) can follow their lead. Only then we’ll start seeing Linux making it to our homes.

In the meantime, do please keep making Firefox et al available for Windows users – let’s help enable them to use their own computer, without fear of problems due to sloppiness in Microsoft’s part.

Also I love seeing OpenOffice available on Windows – I can picture Ballmer screaming from the pain of losing the US$300+ per seat on Office license 😀 ho ho ho

Have a great holiday everyone !

pkg-get untuk Solaris

pkg-get adalah software untuk memudahkan manajemen software di Solaris. Secara singkat, pkg-get mirip dengan apt-nya Debian.

Contoh:
Jika Anda mengetikkan “pkg-get install apache”, maka pkg-get akan mengambil paket Apache dari salah satu mirror Blastwave, dan memasangnya – dan jika paket SSL belum terpasang, maka akan diambil dan dipasang juga; karena paket Apache membutuhkan paket SSL.

Sangat menarik karena sangat memudahkan kita untuk memasang suatu software di Solaris, lagipula memasang software open-source di Solaris terkadang bermasalah karena kadang perlu diubah-ubah settingnya agar cocok. (untuk salah satu contoh kasusnya klik disini)

Jika Anda tidak ingin selalu download paket-paket softwarenya langsung dari Internet, berikut ini adalah solusi yang bisa Anda coba:

  1. Pesan sebuah Blastwave DVD (atau bisa juga berlangganan selama satu tahun)
  2. Taruh di sebuah server di perusahaan Anda, untuk menjadi Blastwave server internal
  3. Lalu secara rutin update Blastwave server Anda dari salah satu mirror yang ada dengan menggunakan rsync.
  4. Atur agar semua server Sun mengambil paket dari situ

Selamat mencoba.