


pengenalan
Dalam bahagian 1 siri kami memberikan pengenalan kepada GraalVM dan terutamanya keupayaan Imej Aslinya. Kami juga menerangkan faedahnya untuk aplikasi Tanpa Pelayan. Dalam bahagian siri ini, kami akan menerangkan cara untuk membangunkan dan menggunakan fungsi AWS Lambda dengan masa jalan tersuai yang mengandungi Imej Asli GraalVM.
Contoh Permohonan
Demi penjelasan kami akan menggunakan aplikasi sampel kami. Dalam aplikasi ini kami akan mencipta dan mendapatkan semula produk dan menggunakan DynamoDB sebagai pangkalan data NoSQL. Kami akan menggunakan semula aplikasi yang diperkenalkan dalam artikel Measuring Java 21 Lambda cold starts dan melaraskannya untuk digunakan sebagai Lambda Custom Runtime yang mengandungi GraalVM Native Image.
Persediaan Umum
Untuk membina Imej Asli GraalVM, kami perlu melakukan perkara berikut:
- Sediakan instance AWS Cloud9 EC2 m5.large. Anda sudah tentu boleh menggunakan persekitaran Linux (tempatan) anda sendiri.
- Pasang SDKMAN
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
- Pasang versi GraalVM terkini. Saya menggunakan versi 22 dalam contoh saya (tetapi anda boleh menggunakan yang terbaru):
sdk install java 22.0.1-graal (or use the newest GraalVM version)
- Pasang Imej Asli
sudo yum install gcc glibc-devel zlib-devel sudo dnf install gcc glibc-devel zlib-devel libstdc++-static
- Pasang Maven yang mampu membina dengan versi GraalVM yang dipasang. Kami memerlukan versi Maven yang mampu menangani Java 21 dan versi kod sumber yang lebih tinggi. Contohnya:
wget https://mirrors.estointernet.in/apache/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz tar -xvf apache-maven-3.8.5-bin.tar.gz sudo mv apache-maven-3.8.5 /opt/ M2_HOME='/opt/apache-maven-3.8.5' PATH="$M2_HOME/bin:$PATH" export PATH
Jika cermin ini tidak tersedia, sila gunakan cermin lain yang tersedia untuk sistem pengendalian anda.
Membuat aplikasi sampel GraalVM Native Image mampu
Untuk membolehkan aplikasi sampel kami dijalankan sebagai Imej Asli GraalVM, kami perlu mengisytiharkan semua kelas objek yang akan dijadikan instantiated setiap refleksi. Kelas-kelas ini perlu diketahui oleh pengkompil AOT pada masa penyusunan. Ini berlaku dalam reflect.json. Seperti yang kita lihat kita perlu mengisytiharkan di sana
- semua fungsi Lambda kami seperti GetProductByIdHandler dan CreateProductHandler
- entiti seperti Produk dan Produk yang akan ditukar daripada muatan JSON dan kembali
- APIGatewayProxyRequestEvent dan semua kelas dalamannya kerana kami mengisytiharkan jenis acara ini sebagai acara permintaan dalam fungsi Lambda kami seperti GetProductByIdHandler dan CreateProductHandler
- org.joda.time.DateTime yang akan digunakan untuk menukar cap waktu daripada String dan belakang yang merupakan sebahagian daripada permintaan proksi APIGateway dan peristiwa respons
Untuk mengelakkan ralat dengan Loggers semasa pemulaan yang diterangkan dalam artikel Permulaan Kelas dalam Imej Asli kita perlu menambah argumen binaan Imej Asli GraalVM dalam native-image.properties.
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
Native-image.properties hendaklah diletakkan dalam META-INF/native-image/${MavenGroupIid}/${MavenArtifactId}
Semasa kita menggunakan slf4j-simple Logger dalam pom.xml, kita perlu meletakkan native-image.properties dalam laluan META-INF/native-image/org.slf4j/slf4j-simple.
Masa Jalan Tersuai Lambda
Untuk menggunakan fungsi Lambda sebagai masa jalan tersuai, kami perlu membungkus segala-galanya ke dalam fail dengan sambungan .zip yang merangkumi fail dengan nama bootstrap. Fail ini sama ada boleh menjadi Imej Asli GraalVM dalam kes kami atau mengandungi arahan cara menggunakan Imej Asli GraalVM diletakkan dalam fail lain. Mari kita terokainya.
Membina Imej Asli GraalVM
Kami akan membina imej Asli GraalVM secara automatik dalam fasa pakej yang ditakrifkan dalam pom.xml. Bahagian yang berkaitan ditakrifkan dalam pemalam berikut:
sdk install java 22.0.1-graal (or use the newest GraalVM version)
Kami menggunakan native-image-maven-plugin daripada alat org.graalvm.nativeimage dan melaksanakan imej asli dalam fasa pakej. Pemalam ini memerlukan takrifan kelas utama yang tidak ada pada fungsi Lambda. Itulah sebabnya kami menggunakan Lambda Runtime GraalVM dan mentakrifkan kelas utamanya com.formkiq.lambda.runtime.graalvm.LambdaRuntime. Lambda Runtime GraalVM ialah perpustakaan Java yang memudahkan untuk menukar AWS Lambda yang ditulis dalam bahasa pengaturcaraan Java kepada GraalVM. Kami mentakrifkannya sebelum ini dalam pom.xml sebagai kebergantungan
sudo yum install gcc glibc-devel zlib-devel sudo dnf install gcc glibc-devel zlib-devel libstdc++-static
Kami kemudian memberikan nama imej asli aws-pure-lambda-java21-graalvm-native-image dan menyertakan beberapa hujah Imej Asli GraalVM dan sebelum ini ditakrifkan reflect.json.
wget https://mirrors.estointernet.in/apache/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz tar -xvf apache-maven-3.8.5-bin.tar.gz sudo mv apache-maven-3.8.5 /opt/ M2_HOME='/opt/apache-maven-3.8.5' PATH="$M2_HOME/bin:$PATH" export PATH
Untuk mengezip Imej Asli GraalVM yang dibina sebagai function.zip yang diperlukan oleh Lambda Custom Runtime kami menggunakan pemalam pemasangan maven:
Args=--allow-incomplete-classpath \ --initialize-at-build-time=org.slf4j.simple.SimpleLogger,\ org.slf4j.LoggerFactory -- --trace-class-initialization=org.slf4j.simple.SimpleLogger,\ org.slf4j.LoggerFactory
Nama akhir yang kami takrifkan sebagai fungsi dan id sebagai native-zip Kami juga menyertakan pemasangan native.xml. Himpunan ini mentakrifkan format fail sebagai zip (nama fail lengkap ialah ${finalName}-${id}.zip, dalam kes kami function-native-zip.zip), menambah Imej Asli GraalVM yang dibina sebelum ini dengan nama aws-pure-lambda-java21-graalvm-native-image dan menambah bootstrap yang telah ditetapkan yang pada asasnya menggunakan GraalVM Native Image :
<plugin> <groupid>org.graalvm.nativeimage</groupid> <artifactid>native-image-maven-plugin</artifactid> <version>21.2.0</version> <executions> <execution> <goals> <goal>native-image</goal> </goals> <phase>package</phase> </execution> </executions> <configuration> <skip>false</skip> <mainclass>com.formkiq.lambda.runtime.graalvm.LambdaRuntime</mainclass> <imagename>aws-pure-lambda-java21-graalvm-native-image</imagename> <buildargs> --no-fallback --enable-http -H:ReflectionConfigurationFiles=../src/main/reflect.json </buildargs> </configuration> </plugin>
Akhirnya kita perlu membina Imej Asli GraalVM yang dibungkus sebagai fail zip yang boleh digunakan sebagai Lambda Custom Runtime dengan :
<dependency> <groupid>com.formkiq</groupid> <artifactid>lambda-runtime-graalvm</artifactid> <version>2.3.1</version> </dependency>
Menggunakan Imej Asli GraalVM sebagai Masa Jalan Tersuai Lambda
Dalam templat AWS SAM kami menyediakan masa jalan Lambda sebagai provided.al2023, iaitu versi terbaru masa jalan tersuai) dan menyediakan laluan ke fungsi-native-zip Imej Asli GraalVM yang dibina sebelum ini. zip.
<buildargs> --no-fallback --enable-http -H:ReflectionConfigurationFiles=../src/main/reflect.json </buildargs>
Kini kami bersedia untuk menggunakan aplikasi kami dengan
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
Kesimpulan
Dalam bahagian siri ini, kami menerangkan cara membangunkan dan menggunakan fungsi AWS Lambda dengan masa jalan tersuai yang mengandungi Imej Asli GraalVM. Dalam bahagian seterusnya siri kami akan mengukur masa mula sejuk dan hangat fungsi Lambda untuk senario sedemikian untuk tetapan memori yang berbeza bagi fungsi Lambda.
Atas ialah kandungan terperinci Fungsi Lambda dengan Imej Asli GraalVM - Bahagian perlu membangunkan dan menggunakan fungsi Lambda dengan masa jalan tersuai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa