Thread WebAssembly siap dicoba di Chrome 70

Dukungan thread WebAssembly telah dikirimkan di Chrome 70 dalam percobaan origin.

Alex Danilo

WebAssembly (Wasm) memungkinkan kompilasi kode yang ditulis dalam C++ dan bahasa lainnya untuk dijalankan di web. Salah satu fitur aplikasi native yang sangat berguna adalah kemampuan untuk menggunakan thread - primitif untuk komputasi paralel. Sebagian besar developer C dan C++ akan memahami pthreads yang merupakan API standar untuk pengelolaan thread dalam aplikasi.

Grup Komunitas WebAssembly telah bekerja untuk menghadirkan thread ke web guna mengaktifkan aplikasi multi-thread yang sebenarnya. Sebagai bagian dari upaya ini, V8 telah menerapkan dukungan yang diperlukan untuk thread di mesin WebAssembly, yang tersedia melalui Uji Coba Origin. Uji Coba Origin memungkinkan developer bereksperimen dengan fitur web baru sebelum sepenuhnya diseragamkan. Hal ini memungkinkan kami mengumpulkan masukan dari developer yang berani, yang sangat penting untuk memvalidasi dan meningkatkan kualitas fitur baru.

Rilis Chrome 70 mendukung thread untuk WebAssembly dan sebaiknya developer yang tertarik mulai menggunakannya dan memberikan masukan kepada kami.

Rangkaian pesan? Bagaimana dengan Pekerja?

Browser telah mendukung paralelisme melalui Web Worker sejak 2012 di Chrome 4; sebenarnya hal yang wajar untuk mendengar istilah seperti 'di thread utama', dll. Namun, Web Worker tidak berbagi data yang dapat diubah di antara mereka, melainkan mengandalkan pengiriman pesan untuk komunikasi. Faktanya, Chrome mengalokasikan mesin V8 baru untuk setiap proses tersebut (disebut isolasi). Isolat tidak berbagi kode yang dikompilasi atau objek JavaScript, sehingga tidak dapat berbagi data yang dapat diubah seperti pthread.

Di sisi lain, thread WebAssembly adalah thread yang dapat berbagi memori Wasm yang sama. Penyimpanan dasar memori bersama dilakukan dengan SharedArrayBuffer, primitive JavaScript yang memungkinkan berbagi konten ArrayBuffer tunggal secara serentak di antara pekerja. Setiap thread WebAssembly berjalan di Web Worker, tetapi memori Wasm bersama memungkinkannya berfungsi seperti yang dilakukan di platform native. Artinya, aplikasi yang menggunakan thread Wasm bertanggung jawab untuk mengelola akses ke memori bersama seperti pada aplikasi berthread tradisional. Ada banyak library kode yang ada yang ditulis dalam C atau C++ yang menggunakan pthreads, dan library tersebut dapat dikompilasi ke Wasm dan dijalankan dalam mode threaded yang sebenarnya, sehingga lebih banyak core dapat bekerja pada data yang sama secara bersamaan.

Contoh sederhana

Berikut adalah contoh program 'C' sederhana yang menggunakan thread.

#include <pthread.h>
#include <stdio.h>

// Calculate Fibonacci numbers shared function
int fibonacci(int iterations) {
    int     val = 1;
    int     last = 0;

    if (iterations == 0) {
        return 0;
    }
    for (int i = 1; i < iterations; i++) {
        int     seq;

        seq = val + last;
        last = val;
        val = seq;
    }
    return val;
}
// Start function for the background thread
void *bg_func(void *arg) {
    int     *iter = (void *)arg;

    *iter = fibonacci(*iter);
    return arg;
}
// Foreground thread and main entry point
int main(int argc, char *argv[]) {
    int         fg_val = 54;
    int         bg_val = 42;
    pthread_t   bg_thread;

    // Create the background thread
    if (pthread_create(&bg_thread, NULL, bg_func, &bg_val)) {
        perror("Thread create failed");
        return 1;
    }
    // Calculate on the foreground thread
    fg_val = fibonacci(fg_val);
    // Wait for background thread to finish
    if (pthread_join(bg_thread, NULL)) {
        perror("Thread join failed");
        return 2;
    }
    // Show the result from background and foreground threads
    printf("Fib(42) is %d, Fib(6 * 9) is %d\n", bg_val, fg_val);

    return 0;
}

Kode tersebut dimulai dengan fungsi main() yang mendeklarasikan 2 variabel fg_val dan bg_val. Ada juga fungsi yang disebut fibonacci(), yang akan dipanggil oleh kedua thread dalam contoh ini. Fungsi main() membuat thread latar belakang menggunakan pthread_create() yang tugasnya adalah menghitung nilai urutan angka fibonacci yang sesuai dengan nilai variabel bg_val. Sementara itu, fungsi main() yang berjalan di thread latar depan menghitungnya untuk variabel fg_val. Setelah thread latar belakang selesai berjalan, hasilnya akan dicetak.

Mengompilasi untuk dukungan thread

Pertama, Anda harus menginstal emscripten SDK, sebaiknya versi 1.38.11 atau yang lebih baru. Untuk mem-build kode contoh dengan thread yang diaktifkan untuk dijalankan di browser, kita perlu meneruskan beberapa flag tambahan ke compiler emcc emscripten. Baris perintah kita akan terlihat seperti ini:

emcc -O2 -s USE_PTHREADS=1 -s PTHREAD_POOL_SIZE=2 -o test.js test.c

Argumen command line '-s USE_PTHREADS=1' mengaktifkan dukungan threading untuk modul WebAssembly yang dikompilasi dan argumen '-s PTHREAD_POOL_SIZE=2' memberi tahu compiler untuk membuat kumpulan dua (2) thread.

Saat program dijalankan, di balik layar, program akan memuat modul WebAssembly, membuat Web Worker untuk setiap thread dalam kumpulan thread, membagikan modul ke setiap pekerja, dalam hal ini ada 2, dan modul tersebut akan digunakan setiap kali panggilan ke pthread_create() dilakukan. Setiap pekerja membuat instance modul Wasm dengan memori yang sama, sehingga memungkinkan mereka untuk bekerja sama. Perubahan terbaru V8 di 7.0 berbagi kode native yang dikompilasi dari modul Wasm yang diteruskan di antara pekerja, yang memungkinkan aplikasi yang sangat besar untuk diskalakan ke banyak pekerja. Perhatikan, sebaiknya pastikan ukuran kumpulan thread sama dengan jumlah maksimum thread yang diperlukan aplikasi Anda, atau pembuatan thread dapat gagal. Pada saat yang sama, jika ukuran kumpulan thread terlalu besar, Anda akan membuat Web Worker yang tidak perlu yang hanya akan menggunakan memori tanpa melakukan apa pun.

Cara mencobanya

Cara tercepat untuk menguji modul WebAssembly adalah dengan mengaktifkan dukungan thread WebAssembly eksperimental di Chrome 70 dan yang lebih baru. Buka URL about://flags di browser Anda seperti yang ditunjukkan di bawah:

Halaman tanda Chrome

Selanjutnya, temukan setelan thread WebAssembly eksperimental yang terlihat seperti ini:

Setelan thread WebAssembly

Ubah setelan ke Enabled seperti yang ditunjukkan di bawah, lalu mulai ulang browser Anda.

Setelan thread WebAssembly diaktifkan

Setelah browser dimulai ulang, kita dapat mencoba memuat modul WebAssembly threaded dengan halaman HTML minimal, yang hanya berisi konten ini:

<!DOCTYPE html>
<html>
  <title>Threads test</title>
  <body>
    <script src="test.js"></script>
  </body>
</html>

Untuk mencoba halaman ini, Anda harus menjalankan beberapa bentuk server web dan memuatkannya dari browser. Tindakan ini akan menyebabkan modul WebAssembly dimuat dan dijalankan. Membuka DevTools akan menampilkan output dari operasi, dan Anda akan melihat sesuatu seperti gambar output di bawah di konsol:

Output konsol dari program fibonacci

Program WebAssembly kami dengan thread telah berhasil dieksekusi. Sebaiknya Anda mencoba aplikasi dengan rangkaian pesan Anda sendiri menggunakan langkah-langkah yang diuraikan di atas.

Menguji di lapangan dengan Uji Coba Origin

Mencoba thread dengan mengaktifkan flag eksperimental di browser tidak masalah untuk tujuan pengembangan, tetapi jika ingin menguji aplikasi di lapangan, Anda dapat melakukannya dengan yang dikenal sebagai uji coba origin.

Uji coba origin memungkinkan Anda mencoba fitur eksperimental dengan pengguna dengan mendapatkan token pengujian yang terikat dengan domain Anda. Selanjutnya, Anda dapat men-deploy aplikasi dan mengharapkannya berfungsi di browser yang dapat mendukung fitur yang Anda uji (dalam hal ini Chrome 70 dan yang lebih baru). Untuk mendapatkan token Anda sendiri guna menjalankan uji coba origin, gunakan formulir permohonan di sini.

Kami telah menghosting contoh sederhana di atas menggunakan token uji coba origin, sehingga Anda dapat mencobanya sendiri tanpa perlu mem-build apa pun.

Jika ingin melihat apa yang dapat dilakukan 4 thread yang berjalan secara paralel untuk ASCII art, Anda juga harus melihat demo ini.

Berikan masukan Anda

Thread WebAssembly adalah primitif baru yang sangat berguna untuk mem-porting aplikasi ke web. Kini Anda dapat menjalankan aplikasi dan library C dan C++ yang memerlukan dukungan pthreads di lingkungan WebAssembly.

Kami mencari masukan dari developer yang mencoba fitur ini karena akan membantu memberi informasi tentang proses standardisasi serta memvalidasi kegunaannya. Cara terbaik untuk mengirimkan masukan adalah dengan melaporkan masalah dan/atau ikut serta dalam proses standardisasi di Grup Komunitas WebAssembly.