JeKa ialah alat binaan Java moden yang memfokuskan pada kesederhanaan.
Siaran ini adalah sebahagian daripada siri "Jeka: cara paling mudah untuk..." dan menunjukkan cara mencipta balang lemak (berlorek atau tidak) dengan mudah.
Cara biasa untuk membungkus aplikasi Java ialah dengan mencipta balang LEMAK. Balang lemak menggabungkan semua kelas daripada kebergantungan, jadi anda hanya memerlukan balang (bersama-sama Java Runtime) untuk menjalankan aplikasi.
Aplikasi anda mungkin memerlukan kebergantungan, yang boleh anda senaraikan dalam fail dependencies.txt seperti ditunjukkan dalam contoh di bawah:
== COMPILE == com.github.lalyos:jfiglet:0.0.9 com.google.guava:guava:33.4.0-jre com.fasterxml.jackson.core:jackson-core:2.18.2 == TEST == org.junit.jupiter:junit-jupiter:5.8.1
Untuk mengkonfigurasi penjanaan balang lemak, edit fail jeka.properties:
jeka.version=0.11.11 jeka.java.version=17 @project.pack.detectMainClass=true @project.pack.jarType=FAT
Sifat @project.pack.jarType menentukan jenis JAR untuk dijana. Ia boleh menjadi BIASA, GEMUK, atau SHADE.
Tetapan @project.pack.detectMainClass=true mengarahkan Jeka untuk mengesan kelas utama untuk disertakan dalam fail manifes.
Untuk menjana balang, jalankan arahan berikut:
jeka project: pack
Balang FAT akan dibuat dalam direktori jeka-output. Untuk menjalankannya, cuma jalankan: java -jar [jar-name].jar.
Untuk perpustakaan, amalan yang baik adalah dengan menyimpan Balang biasa dan menyediakan Balang Gemuk sebagai pilihan tambahan.
Sebaik-baiknya, kelas pergantungan juga harus dipindahkan ke pakej khusus untuk mengelakkan konflik laluan kelas untuk pengguna. Kami memanggil balang teduh, balang lemak di mana kelas dependencies telah diletakkan semula dalam pakej tertentu.
Untuk mencipta balang sedemikian, konfigurasikan JeKa seperti berikut:
jeka.version=0.11.11 jeka.java.version=17 @project.moduleId=org.examples:my-lib @project.version=1.0.0-SNAPSHOT @project.pack.shadeJarClassifier=all @maven.publication.extraArtifacts=all
Sekarang, menggunakan jeka prpject: pack juga akan membuat fail*org.examples.my-lib-all.jar*.
Dengan membuka fail jat, kita dapat melihat bahawa semua kelas pergantungan telah ditempatkan semula secara automatik.
. ├── org │ └── example │ └── mylib <- Base package for my-lib classes │ ├── MyLyb.class │ └── _shaded <- Base package for dependency classes │ ├── com.google... │ ├── com.fasterxml.jackson... │ └── com.github.lalyos.jfiglat... └── META-INF └── MANIFEST.MF
Selain itu, @maven.publication.extraArtifacts=all termasuk balang teduh dalam penerbitan maven yang dijana oleh jeka maven: publish command.
Seperti yang ditunjukkan di bawah, Maven memerlukan lebih banyak penaipan untuk mencapai matlamat yang sama.
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.examples</groupId> <artifactId>my-lib</artifactId> <version>0.1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>com.github.lalyos</groupId> <artifactId>jfiglet</artifactId> <version>0.0.9</version> </dependency> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>33.2.1-jre</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.17.2</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>2.3</version> <executions> <!-- Run shade goal on package phase --> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> </execution> </executions> </plugin> </plugins> <pluginManagement> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>2.1</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> </execution> </executions> <configuration> <minimizeJar>true</minimizeJar> <artifactSet> <includes> <include>com.google.guava:guava</include> <include>com.github.lalyos:jfiglet</include> <include>com.fasterxml.jackson.core:jackson-core</include> </includes> </artifactSet> <relocations> <relocation> <pattern>com.google.common</pattern> <shadedPattern>org.elasticsearch.common</shadedPattern> </relocation> <relocation> <pattern>com.fasterxml.jackson</pattern> <shadedPattern>org.elasticsearch.common.jackson</shadedPattern> </relocation> </relocations> <filters> <filter> <artifact>*:*</artifact> <excludes> <exclude>META-INF/license/**</exclude> <exclude>META-INF/*</exclude> <exclude>META-INF/maven/**</exclude> <exclude>LICENSE</exclude> <exclude>NOTICE</exclude> <exclude>/*.txt</exclude> <exclude>build.properties</exclude> </excludes> </filter> </filters> </configuration> </plugin> </plugins> </pluginManagement> </build> </project>
Jeka menjadikan pembinaan projek Java dengan ketara lebih mudah, dengan konfigurasi minimum berbanding dengan Maven atau Gradle.
Teroka lebih banyak contoh untuk mengetahui cara Jeka boleh menyesuaikan diri dengan keperluan projek anda!
Atas ialah kandungan terperinci JeKa: Cara Paling Mudah untuk Mencipta Uber dan Balang Teduh. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!