- Source: Fork bomb
Dalam komputasi, fork bomb, (juga disebut virus kelinci atau wabbit) adalah denial-of-service attack dimana proses terus bereplikasi sendiri untuk menguras sumber daya sistem yang tersedia, memperlambat atau membekukan sistem karena kekurangan sumber daya.
Sejarah
Sekitar tahun 1978, varian awal dari sebuah bom garpu yang disebut wabbit dilaporkan berjalan pada sebuah System/360. Serangan itu mungkin telah diturunkan dari serangan serupa yang sering disebut RABBITS. Serangan ini dilaporkan dari tahun 1969 pada sebuah Burroughs 5500 di University of Washington.
Implementasi
Bom garpu beroperasi baik dengan memakan waktu CPU dalam proses forking, dan dengan menjenuhkan proses table sistem operasi. dasar pengoperasian bom garpu adalah infinite loop yang berulang kali meluncurkan proses yang sama.
Pada sistem operasi serupa-Unix bom garpu umumnya ditulis menggunakan fork system call. Sebagai proses bercabang yang juga merupakan salinan dari program pertama, setelah mereka melanjutkan eksekusi dari alamat berikutnya di frame pointer, mereka juga berusaha untuk membuat salinan dari diri mereka sendiri; ini memiliki efek yang menyebabkan pertumbuhan eksponensial dalam proses. Sistem Unix modern umumnya menggunakan copy-on-write ketika melakukan forking proses-proses baru, sebuah bom garpu umumnya tidak akan membuat jenuh sistem memori.
Sistem operasi Microsoft Windows tidak memiliki fungsi setara dengan Unix fork system call; oleh karena itu bom garpu pada suatu sistem operasi harus membuat sebuah proses baru bukan forking dari yang sudah ada.
Contoh bom garpu
= Bash
=Triknya adalah bahwa : adalah sebuah nama fungsi — oleh karena itu serupa juga dengan bomb() { bomb | bomb & }; bomb.
Sama seperti diatas tetapi di encode dengan shell script:
= Windows batch
=Sama dengan diatas, tetapi lebih singkat:
Kombinasi dari dua perintah diatas(untuk mencocokan konsep):
Sama dengan diatas, tetapi dilakukan di command line menggunakan ^ untuk menghindari:
= Perl
=Contoh inline shell menggunakan Perl interpreter:
= Python
=Kode dibawah dibuat menjadi file Python (.py). Contoh kode Python interpreter:
= Java
== C
== Assembly (Linux berjalan pada sistem IA-32)
=Kode di bawah ini dapat dijalankan di KolibriOS, karena KolibriOS dibuat menggunakan bahasa Assembly. Contoh kode Assembly interpreter:
= PowerShell
=Kode dibawah dibuat menjadi file PowerShell Script (.ps1). Contoh kode PowerShell interpreter:
Pencegahan
Karena modus operasi bom garpu sepenuhnya dikemas dengan menciptakan proses-proses baru, salah satu cara untuk mencegah bom garpu dari kerusakan parah yang mempengaruhi seluruh sistem yaitu dengan membatasi jumlah maksimum dari proses yang dapat dilakukan 1 pengguna. Di Linux, hal ini dapat dicapai dengan menggunakan utilitas ulimit; sebagai contoh, perintah ulimit -u 30 akan membatasi pengguna yang terkena dampak maksimum tiga puluh proses yang dimiliki. Pada PAM-enabled system, batas ini juga bisa di set di /etc/security/limits.conf, dan pada FreeBSD, administrator sistem dapat menempatkan batas dalam /etc/login.conf.
Lihat juga
Serangan DoS
Kebuntuan
Bom waktu (perangkat lunak)
Bom logika
Referensi
Kata Kunci Pencarian:
- Fork bomb
- Keanekaragaman hayati
- Rhythm Heaven Fever
- Daftar julukan kota di Amerika Serikat
- Anjlokan kereta api Ohio 2023
- Daftar operasi militer Perang Dunia II
- Fork bomb
- Zip bomb
- Fork (system call)
- Logic bomb
- Time bomb (software)
- Billion laughs attack
- Starvation (computer science)
- Denial-of-service attack
- Morris worm
- Low Orbit Ion Cannon