mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-19 22:51:41 +08:00
a9ee27a9bf
sources/tech/20200311 Using the Quarkus Framework on Fedora Silverblue - Just a Quick Look.md
210 lines
10 KiB
Markdown
210 lines
10 KiB
Markdown
[#]: collector: (lujun9972)
|
||
[#]: translator: ( )
|
||
[#]: reviewer: ( )
|
||
[#]: publisher: ( )
|
||
[#]: url: ( )
|
||
[#]: subject: (Using the Quarkus Framework on Fedora Silverblue – Just a Quick Look)
|
||
[#]: via: (https://fedoramagazine.org/using-the-quarkus-framework-on-fedora-silverblue-just-a-quick-look/)
|
||
[#]: author: (Stephen Snow https://fedoramagazine.org/author/jakfrost/)
|
||
|
||
Using the Quarkus Framework on Fedora Silverblue – Just a Quick Look
|
||
======
|
||
|
||
![Using the Quarkus Framework on Fedora Silverblue – Just a Quick Look][1]
|
||
|
||
[Quarkus][2] is a framework for Java development that is described on their web site as:
|
||
|
||
> A Kubernetes Native Java stack tailored for OpenJDK HotSpot and GraalVM, crafted from the best of breed Java libraries and standards
|
||
>
|
||
> <https://quarkus.io/> – Feb. 5, 2020
|
||
|
||
Silverblue — a Fedora Workstation variant with a container based workflow central to its functionality — should be an ideal host system for the Quarkus framework.
|
||
|
||
There are currently two ways to use Quarkus with Silverblue. It can be run in a pet container such as Toolbox/Coretoolbox. Or it can be run directly in a terminal emulator. This article will focus on the latter method.
|
||
|
||
### Why Quarkus
|
||
|
||
[According to Quarkus.io][3]: “Quarkus has been designed around a containers first philosophy. What this means in real terms is that Quarkus is optimized for low memory usage and fast startup times.” To achieve this, they employ first class support for Graal/Substrate VM, build time Metadata processing, reduction in reflection usage, and native image preboot. For details about why this matters, read [Container First][3] at Quarkus.
|
||
|
||
### Prerequisites
|
||
|
||
A few prerequisites will need to configured before you can start using Quarkus. First, you need an IDE of your choice. Any of the popular ones will do. VIM or Emacs will work as well. The Quarkus site provides full details on how to set up the three major Java IDE’s (Eclipse, Intellij Idea, and Apache Netbeans). You will need a version of JDK installed. JDK 8, JDK 11 or any distribution of OpenJDK is fine. GrallVM 19.2.1 or 19.3.1 is needed for compiling down to native. You will also need Apache Maven 3.53+ or Gradle. This article will use Maven because that is what the author is more familiar with. Use the following command to layer Java 11 OpenJDK and Maven onto Silverblue:
|
||
|
||
```
|
||
$ rpm-ostree install java-11-openjdk* maven
|
||
```
|
||
|
||
Alternatively, you can download your favorite version of Java and install it directly in your home directory.
|
||
|
||
After rebooting, configure your _JAVA_HOME_ and _PATH_ environment variables to reference the new applications. Next, go to the [GraalVM download page][4], and get GraalVM version 19.2.1 or version 19.3.1 for Java 11 OpenJDK. Install Graal as per the instructions provided. Basically, copy and decompress the archive into a directory under your home directory, then modify the _PATH_ environment variable to include Graal. You use it as you would any JDK. So you can set it up as a platform in the IDE of your choice. Now is the time to setup the native image if you are going to use one. For more details on setting up your system to use Quarkus and the Quarkus native image, check out their [Getting Started tutorial][5]. With these parts installed and the environment setup, you can now try out Quarkus.
|
||
|
||
### Bootstrapping
|
||
|
||
Quarkus recommends you create a project using the bootstrapping method. Below are some example commands entered into a terminal emulator in the Gnome shell on Silverblue.
|
||
|
||
```
|
||
$ mvn io.quarkus:quarkus-maven-plugin:1.2.1.Final:create \
|
||
-DprojectGroupId=org.jakfrost \
|
||
-DprojectArtifactId=silverblue-logo \
|
||
-DclassName="org.jakfrost.quickstart.GreetingResource" \
|
||
-Dpath="/hello"
|
||
$ cd silverblue-logo
|
||
```
|
||
|
||
The bootstrapping process shown above will create a project under the current directory with the name _silverblue-logo_. After this completes, start the application in development mode:
|
||
|
||
```
|
||
$ ./mvnw compile quarkus:dev
|
||
```
|
||
|
||
With the application running, check whether it responds as expected by issuing the following command:
|
||
|
||
```
|
||
$ curl -w '\n' http://localhost:8080/hello
|
||
```
|
||
|
||
The above command should print _hello_ on the next line. Alternatively, test the application by browsing to _<http://localhost:8080/hello>_ with your web browser. You should see the same lonely _hello_ on an otherwise empty page. Leave the application running for the next section.
|
||
|
||
### Injection
|
||
|
||
Open the project in your favorite IDE. If you are using Netbeans, simply open the project directory where the _pom.xml_ file resides. Now would be a good time to have a look at the _pom.xml_ file.
|
||
|
||
Quarkus uses ArC for its dependency injection. ArC is a dependency of quarkus-resteasy, so it is already part of the core Quarkus installation. Add a companion bean to the project by creating a java class in your IDE called _GreetingService.java_. Then put the following code into it:
|
||
|
||
```
|
||
import javax.enterprise.context.ApplicationScoped;
|
||
|
||
@ApplicationScoped
|
||
public class GreetingService {
|
||
|
||
public String greeting(String name) {
|
||
return "hello " + name;
|
||
}
|
||
|
||
}
|
||
```
|
||
|
||
The above code is a verbatim copy of what is used in the injection example in the Quarkus Getting Started tutorial. Modify _GreetingResource.java_ by adding the following lines of code:
|
||
|
||
```
|
||
import javax.inject.Inject;
|
||
import org.jboss.resteasy.annotations.jaxrs.PathParam;
|
||
|
||
@Inject
|
||
GreetingService service;//inject the service
|
||
|
||
@GET //add a getter to use the injected service
|
||
@Produces(MediaType.TEXT_PLAIN)
|
||
@Path("/greeting/{name}")
|
||
public String greeting(@PathParam String name) {
|
||
return service.greeting(name);
|
||
}
|
||
```
|
||
|
||
If you haven’t stopped the application, it will be easy to see the effect of your changes. Just enter the following _curl_ command:
|
||
|
||
```
|
||
$ curl -w '\n' http://localhost:8080/hello/greeting/Silverblue
|
||
```
|
||
|
||
The above command should print _hello Silverblue_ on the following line. The URL should work similarly in a web browser. There are two important things to note:
|
||
|
||
1. The application was running and Quarkus detected the file changes on the fly.
|
||
2. The injection of code into the app was very easy to perform.
|
||
|
||
|
||
|
||
### The native image
|
||
|
||
Next, package your application as a native image that will work in a _podman_ container. Exit the application by pressing **CTRL-C**. Then use the following command to package it:
|
||
|
||
```
|
||
$ ./mvnw package -Pnative -Dquarkus.native.container-runtime=podman
|
||
```
|
||
|
||
Now, build the container:
|
||
|
||
```
|
||
$ podman build -f src/main/docker/Dockerfile.native -t silverblue-logo/silverblue-logo
|
||
```
|
||
|
||
Now run it with the following:
|
||
|
||
```
|
||
$ podman run -i --rm -p 8080:8080 localhost/silverblue-logo/silverblue-logo
|
||
```
|
||
|
||
To get the container build to successfully complete, it was necessary to copy the _/target_ directory and contents into the _src/main/docker/_ directory. Investigation as to the reason why is still required, and though the solution used was quick and easy, it is not an acceptable way to solve the problem.
|
||
|
||
Now that you have the container running with the application inside, you can use the same methods as before to verify that it is working.
|
||
|
||
Point your browser to the URL <http://localhost:8080/> and you should get a _index.html_ that is automatically generated by Quarkus every time you create or modify an application. It resides in the _src/main/resources/META-INF/resources/_ directory. Drop other HTML files in this _resources_ directory to have Quarkus serve them on request.
|
||
|
||
For example, create a file named _logo.html_ in the _resources_ directory containing the below markup:
|
||
|
||
```
|
||
<!DOCTYPE html>
|
||
<!--
|
||
To change this license header, choose License Headers in Project Properties.
|
||
To change this template file, choose Tools | Templates
|
||
and open the template in the editor.
|
||
-->
|
||
<html>
|
||
<head>
|
||
<title>Silverblue</title>
|
||
<meta charset="UTF-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
</head>
|
||
<body>
|
||
<div>
|
||
<img src="fedora-silverblue-logo.png" alt="Fedora Silverblue"/>
|
||
</div>
|
||
</body>
|
||
</html>
|
||
```
|
||
|
||
Next, save the below image alongside the _logo.html_ file with the name _fedora-silverblue-logo.png_:
|
||
|
||
![][6]
|
||
|
||
Now view the results at <http://localhost:8080/logo.html>.
|
||
|
||
#### Testing your application
|
||
|
||
Quarkus supports junit 5 tests. Look at your project’s _pom.xml_ file. In it you should see two test dependencies. The generated project will contain a simple test, named _GreetingResourceTest.java_. Testing for the native file is only supported in _prod_ mode. However, you can test the _jar_ file in _dev_ mode. These tests are RestAssured, but you can use whatever test library you wish with Quarkus. Use Maven to run the tests:
|
||
|
||
```
|
||
$ ./mvnw test
|
||
```
|
||
|
||
More details can be found in the Quarkus [Getting Started][7] tutorial.
|
||
|
||
#### Further reading and tutorials
|
||
|
||
Quarkus has an extensive collection of [tutorials and guides][8]. They are well worth the time to delve into the breadth of this microservices framework.
|
||
|
||
Quarkus also maintains a [publications][9] page that lists some very interesting articles on actual use cases of Quarkus. This article has only just scratched the surface of the topic. If what was presented here has piqued your interest, then follow the above links for more information.
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: https://fedoramagazine.org/using-the-quarkus-framework-on-fedora-silverblue-just-a-quick-look/
|
||
|
||
作者:[Stephen Snow][a]
|
||
选题:[lujun9972][b]
|
||
译者:[译者ID](https://github.com/译者ID)
|
||
校对:[校对者ID](https://github.com/校对者ID)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
||
[a]: https://fedoramagazine.org/author/jakfrost/
|
||
[b]: https://github.com/lujun9972
|
||
[1]: https://fedoramagazine.org/wp-content/uploads/2020/02/quarkus-816x345.jpg
|
||
[2]: https://quarkus.io/
|
||
[3]: https://quarkus.io/vision/container-first
|
||
[4]: https://www.graalvm.org/downloads/
|
||
[5]: https://quarkus.io/get-started/
|
||
[6]: https://fedoramagazine.org/wp-content/uploads/2020/02/fedora-silverblue-logo.png
|
||
[7]: https://quarkus.io/guides/getting-started
|
||
[8]: https://quarkus.io/guides/
|
||
[9]: https://quarkus.io/publications/
|