Perbandingan Server Web: Java lebih lambat dari Node.js

May 08 2023
Benar-benar? Mari kode dan bandingkan. Minggu lalu, di tengah libur panjang, Medium.

Benar-benar? Mari kode dan bandingkan.

Foto oleh Ralfs Blumbergs di Unsplash

Minggu lalu, di tengah libur panjang, Medium.com menyarankan saya artikel ini . Ini adalah perbandingan server HTTP asli Node.js vs Java.

Setelah itu, saya mengikuti tolok ukur Java vs Node.js lainnya dari penulis yang sama dan kemudian artikel Java fiasco ini . Pengalaman membaca secara keseluruhan membuat saya merasa Java lebih rendah dari Node.js. Itu mengingatkan saya pada pengembang muda. Dia masih muda, ambisius, dan ingin mengubah semua yang disentuhnya menjadi Javascript dan Typescript.

“Java lambat,” katanya.

Yah, saya bisa berdebat tentang itu di bagian komentar. Saya mungkin menjelaskan bagaimana aplikasi menggunakan utas, dan bagaimana utas Java terikat ke utas OS, dan bagaimana Springboot seperti truk besar dan Anda menyia-nyiakan kemampuannya. Saya juga dapat menyarankan untuk membandingkannya dengan kerangka kerja non-pemblokiran reaktif Java, menunjukkan beberapa situs web yang melakukan tolok ukur dan bla..bla..bla. Pada akhirnya, saya yakin, saya tidak akan meyakinkan siapa pun!

“Akan menyenangkan jika saya bisa menunjukkan betapa salahnya mereka dengan mengkodekan benchmark sendiri,” pikir saya.

Jadi, saya berkata pada diri sendiri, pegang Rendang saya , ayo kode dan cari tahu.

Mekanisme Pengujian

Saya mengikuti cara penulis dalam artikel tersebut melakukan benchmark:

  • Mengembalikan String sederhana.
  • Tes menggunakan Bombardier — Ini adalah utilitas Go untuk melakukan pengujian beban. Anda dapat menemukan informasinya di sini .
  • Dan menggunakan mesin yang sama untuk aplikasi (SUT) dan alat pengujian beban.

Aplikasi ini akan menggunakan perangkat keras dan perangkat lunak berikut:

  • CPU Intel i7 dengan 4 core
  • RAM : 16 GB
  • Windows 11 Pro, versi 22H2
  • Jawa 20
  • Node 18

Kami akan menguji 2 server web Node.js populer, 2 server web non-reaktif Java, dan 2 server web reaktif Java. Di sini mereka:

  • Express : server web Node.js yang sangat populer.
  • Fastify : diklaim sebagai server web Node.js tercepat.
  • Jetty : server web Java non-reaktif yang populer.
  • Undertow : server web Java non-reaktif tradisional lainnya yang digunakan oleh banyak framework Java, termasuk Springboot.
  • Reactor : server Java reaktif yang mendukung spring webflux.
  • Vert.x-Web : server Java reaktif populer lainnya
  • Ini bukan patokan ilmiah. Saya tertarik dengan kinerja — Permintaan Per Detik saja. Jika Anda memerlukan tolok ukur untuk proyek Anda yang menggunakan server di atas, Anda harus melakukan analisis untuk kasus penggunaan Anda. Anda mungkin perlu mengumpulkan matriks yang lebih komprehensif.
  • Semua kode sumber untuk pengujian ini dapat ditemukan di repositori GitHub saya. Ini tautannya:https://github.com/mailindra/webserver-comparison.
  • Jika menurut Anda ada yang bisa saya lakukan untuk meningkatkan kinerja, untuk Java atau Node.js, beri tahu saya di komentar. Atau lebih baik, tiru repositori saya, uji sendiri, dan beri saya Permintaan Tarik.

Node.js: Ekspres

Situs web Express mengklaim bahwa itu adalah kerangka kerja web minimalis. Seperti yang Anda lihat di bawah, kode Express sederhana dan sadar. Dalam tolok ukur ini, server hanya menampilkan "Halo, Orang" untuk setiap permintaan.

Setelah menjalankan aplikasi, kami mengujinya.

Pertama dengan koneksi kecil-permintaan kecil, kemudian menggunakan 500 koneksi dan 1 Juta permintaan. Untuk setiap tes, saya melakukan 1 putaran pemanasan sebelum tes. Inilah hasilnya:

A. Tes dengan 50 koneksi dan 1000 permintaan:

Ekspres diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes dengan 500 koneksi dan 1 Juta permintaan:

Ekspres diuji untuk menangani 500 koneksi dan 1 juta permintaan

Node.js: Percepat

Kode Fastify terlihat mirip dengan Express. Situs web mengklaim bahwa Fastify sangat berkinerja dan ramah pengembang. Ini kodenya:

A. Tes 50 koneksi dan 1000 permintaan:

Fastify diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes 500 koneksi dan 1 Juta permintaan:

Fastify diuji untuk menangani 500 koneksi dan 1 juta permintaan

Hasil Fastify menunjukkan ini jauh lebih cepat daripada Express. Klaim situs Fastify tampaknya benar .

Jawa: Dermaga

Jetty adalah server web Java dan wadah servlet. Ini non-reaktif tetapi mendukung asinkron. Ini kodenya:

A. Tes dengan 50 koneksi dan 1000 permintaan:

Jetty diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes dengan 500 koneksi dan 1 Juta permintaan:

Jetty diuji untuk menangani 500 koneksi dan 1 juta permintaan

Seperti yang Anda lihat pada hasilnya, kinerja Jetty cukup baik. Ini jauh lebih cepat daripada Fastify node.js.

Jawa: arus

Seperti Jetty, Undertow adalah server web Java non-reaktif. Ini dirancang agar dapat disematkan. Seperti yang Anda lihat di bawah, kodenya lancar dan mudah diikuti:

A. Tes dengan 50 koneksi dan 1000 permintaan:

Undertow diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes dengan 500 koneksi dan 1 Juta permintaan:

Undertow diuji untuk menangani 500 koneksi dan 1 juta permintaan

Anda dapat melihat dari hasilnya, Undertow jauh lebih cepat daripada kedua server Node.js. Itu bahkan lebih cepat dari Jetty.

Jawa: Reaktor

Reactor, tepatnya Reactor-Netty, adalah server web reaktif yang mendukung Spring Webflux. Seperti yang Anda lihat, kodenya lebih sederhana daripada Jetty dan Undertow. Ini terlihat sangat mirip dengan Node.js:

A. Tes dengan 50 koneksi dan 1000 permintaan:

Reaktor diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes dengan 500 koneksi dan 1 Juta permintaan:

Reaktor diuji untuk menangani 500 koneksi dan 1 juta permintaan

Sekali lagi, Java Reactor bekerja jauh lebih cepat daripada kedua server web Node.js.

Java: Vertx-Web

Sebagaimana dinyatakan dalam dokumentasinya , Vert.x-Web adalah Java Swiss Army Knife untuk membangun aplikasi web modern. Ini adalah kerangka kerja reaktif. Mirip dengan Reactor, kodenya juga lancar dan mudah diikuti.

A. Tes dengan 50 koneksi dan 1000 permintaan:

Vertx-Web diuji untuk menangani 50 koneksi dan 1000 permintaan

B. Tes dengan 500 koneksi dan 1 Juta permintaan:

Vertx-web diuji untuk menangani 500 koneksi dan 1 juta permintaan

Seperti yang Anda lihat, kinerja Vertx cukup baik. Lebih baik dari server Node.js, dan bahkan lebih baik dari Java Reactor.

Hasil

Agar kita memiliki visualisasi yang baik, saya membuat grafik batang dari benchmark ini:

  1. Tes pertama, 50 koneksi bersamaan dan 1000 permintaan hasil pengujian:
  2. 50 Concurrent Connections dan 1K request (oleh: Ronny Mailindra)
Tolok Ukur Hasil Akhir (Oleh: Ronny Mailindra)

Kesimpulan

  1. Tidak, Java tidak lebih lambat dari Node.js dan Javascript. Hal yang baik tentang melakukan benchmark sendiri adalah Anda dapat meyakinkan diri sendiri. Anda tidak dapat meyakinkan orang lain tentang hal yang tidak Anda percayai.
  2. Server Java Reaktif dan Non-Reaktif berkinerja lebih baik daripada server Node.js.
  3. Saya terkejut bahwa server Java Non-blocking bekerja dengan baik dalam koneksi konkuren rendah dan tinggi dan dapat bersaing dengan server reaktif seperti Reactor dan Vert.x.
  • Mengungkapkan :https://expressjs.com/
  • Percepat :https://www.fastify.io/
  • Dermaga :https://www.eclipse.org/jetty/
  • Arus bawah :https://undertow.io/
  • Reaktor :https://projectreactor.io/
  • Vert.x-Web :https://vertx.io/docs/vertx-web/java/
  • Repositori tolok ukur :https://github.com/mailindra/webserver-comparison