mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
Merge pull request #21770 from lujun9972/add-MjAyMTA0MjkgTGludXggdGlwcyBmb3IgdXNpbmcgR05VIFNjcmVlbi5tZAo=
自动选题[tech]: 20210429 Linux tips for using GNU Screen
This commit is contained in:
commit
82b93b6e62
@ -0,0 +1,99 @@
|
||||
[#]: subject: (How to create your first Quarkus application)
|
||||
[#]: via: (https://opensource.com/article/21/4/quarkus-tutorial)
|
||||
[#]: author: (Saumya Singh https://opensource.com/users/saumyasingh)
|
||||
[#]: collector: (lujun9972)
|
||||
[#]: translator: ( )
|
||||
[#]: reviewer: ( )
|
||||
[#]: publisher: ( )
|
||||
[#]: url: ( )
|
||||
|
||||
How to create your first Quarkus application
|
||||
======
|
||||
The Quarkus framework is considered the rising star for
|
||||
Kubernetes-native Java.
|
||||
![woman on laptop sitting at the window][1]
|
||||
|
||||
Programming languages and frameworks continuously evolve to help developers who want to develop and deploy applications with even faster speeds, better performance, and lower footprint. Engineers push themselves to develop the "next big thing" to satisfy developers' demands for faster deployments.
|
||||
|
||||
[Quarkus][2] is the latest addition to the Java world and considered the rising star for Kubernetes-native Java. It came into the picture in 2019 to optimize Java and commonly used open source frameworks for cloud-native environments. With the Quarkus framework, you can easily go serverless with Java. This article explains why this open source framework is grabbing lots of attention these days and how to create your first Quarkus app.
|
||||
|
||||
## What is Quarkus?
|
||||
|
||||
Quarkus reimagines the Java stack to give the performance characteristics and developer experience needed to create efficient, high-speed applications. It is a container-first and cloud-native framework for writing Java apps.
|
||||
|
||||
You can use your existing skills to code in new ways with Quarkus. It also helps reduce the technical burden in moving to a Kubernetes-centric environment. High-density deployment platforms like Kubernetes need apps with a faster boot time and lower memory usage. Java is still a popular language for developing software but suffers from its focus on productivity at the cost of RAM and CPU.
|
||||
|
||||
In the world of virtualization, serverless, and cloud, many developers find Java is not the best fit for developing cloud-native apps. However, the introduction of Quarkus (also known as "Supersonic and Subatomic Java") helps to resolve these issues.
|
||||
|
||||
## What are the benefits of Quarkus?
|
||||
|
||||
![Quarkus benefits][3]
|
||||
|
||||
(Saumya Singh, [CC BY-SA 4.0][4])
|
||||
|
||||
Quarkus improves start-up times, execution costs, and productivity. Its main objective is to reduce applications' startup time and memory footprint while providing "developer joy." It fulfills these objectives with native compilation and hot reload features.
|
||||
|
||||
### Runtime benefits
|
||||
|
||||
![How Quarkus uses memory][5]
|
||||
|
||||
(Saumya Singh, [CC BY-SA 4.0][4])
|
||||
|
||||
* Lowers memory footprint
|
||||
* Reduces RSS memory, using 10% of the memory needed for a traditional cloud-native stack
|
||||
* Offers very fast startup
|
||||
* Provides a container-first framework, as it is designed to run in a container + Kubernetes environment.
|
||||
* Focuses heavily on making things work in Kubernetes
|
||||
|
||||
|
||||
|
||||
### Development benefits
|
||||
|
||||
![Developers love Quarkus][6]
|
||||
|
||||
(Saumya Singh, [CC BY-SA 4.0][4])
|
||||
|
||||
* Provides very fast, live reload during development and coding
|
||||
* Uses "best of breed" libraries and standards
|
||||
* Brings specifications and great support
|
||||
* Unifies and supports imperative and reactive (non-blocking) styles
|
||||
|
||||
|
||||
|
||||
## Create a Quarkus application in 10 minutes
|
||||
|
||||
Now that you have an idea about why you may want to try Quarkus, I'll show you how to use it.
|
||||
|
||||
First, ensure you have the prerequisites for creating a Quarkus application
|
||||
|
||||
* An IDE like Eclipse, IntelliJ IDEA, VS Code, or Vim
|
||||
* JDK 8 or 11+ installed with JAVA_HOME configured correctly
|
||||
* Apache Maven 3.6.2+
|
||||
|
||||
|
||||
|
||||
You can create a project with either a Maven command or by using code.quarkus.io.
|
||||
|
||||
### Use a Maven command:
|
||||
|
||||
One of the easiest ways to create a new Quarkus project is to open a terminal and run the following commands, as outlined in the [getting started guide][7].
|
||||
|
||||
**Linux and macOS users:**
|
||||
|
||||
|
||||
```
|
||||
mvn io.quarkus:quarkus-maven-plugin:1.13.2.Final:create \
|
||||
-DprojectGroupId=org.acme \
|
||||
-DprojectArtifactId=getting-started \
|
||||
-DclassName="org.acme.getting.started.GreetingResource" \
|
||||
-Dpath="/hello"
|
||||
cd getting-started
|
||||
```
|
||||
|
||||
**Windows users:**
|
||||
|
||||
* If you are using `cmd`, don't use the backward slash (`\`): [code]`mvn io.quarkus:quarkus-maven-plugin:1.13.2.Final:create -DprojectGroupId=org.acme -DprojectArtifactId=getting-started -DclassName="org.acme.getting.started.GreetingResource" -Dpath="/hello"`
|
||||
```
|
||||
* If you are using PowerShell, wrap `-D` parameters in double-quotes:
|
||||
```
|
||||
`mvn io.quarkus:quarkus-maven-plugin:1.13.2.Final:create "
|
97
sources/tech/20210429 Linux tips for using GNU Screen.md
Normal file
97
sources/tech/20210429 Linux tips for using GNU Screen.md
Normal file
@ -0,0 +1,97 @@
|
||||
[#]: subject: (Linux tips for using GNU Screen)
|
||||
[#]: via: (https://opensource.com/article/21/4/gnu-screen-cheat-sheet)
|
||||
[#]: author: (Seth Kenlon https://opensource.com/users/seth)
|
||||
[#]: collector: (lujun9972)
|
||||
[#]: translator: ( )
|
||||
[#]: reviewer: ( )
|
||||
[#]: publisher: ( )
|
||||
[#]: url: ( )
|
||||
|
||||
Linux tips for using GNU Screen
|
||||
======
|
||||
Learn the basics of terminal multiplexing with GNU Screen, then download
|
||||
our cheat sheet so you always have the essential shortcuts at hand.
|
||||
![Terminal command prompt on orange background][1]
|
||||
|
||||
To the average user, a terminal window can be baffling and cryptic. But as you learn more about the Linux terminal, it doesn't take long before you realize how efficient and powerful it is. It also doesn't take long for you to want it to be even _more_ efficient, though, and what better way to make your terminal better than to put more terminals into your terminal?
|
||||
|
||||
### Terminal multiplexing
|
||||
|
||||
One of the many advantages to the terminal is that it's a centralized interface with centralized controls. It's one window that affords you access to hundreds of applications, and all you need to interact with each one of them is a keyboard. But modern computers almost always have processing power to spare, and modern computerists love to multitask, so one window for hundreds of applications can be pretty limiting.
|
||||
|
||||
A common answer for this flaw is terminal multiplexing: the ability to layer virtual terminal windows on top of one another and then move between them all. With a multiplexer, you retain your centralized control, but you gain the ability to swap out the interface as you multitask. Better yet, you can split your virtual screens within your terminal so you can have multiple screens up at the same time.
|
||||
|
||||
### Choose the right multiplexer
|
||||
|
||||
Some terminals offer similar features, with tabbed interfaces and split views, but there are subtle differences. First of all, these terminals' features depend on a graphical desktop environment. Second, many graphical terminal features require mouse interaction or use inconvenient keyboard shortcuts. A terminal multiplexer's features work just as well in a text console as on a graphical desktop, and the keybindings are conveniently designed around common terminal sequences.
|
||||
|
||||
There are two popular multiplexers: [tmux][2] and [GNU Screen][3]. They do the same thing and mostly have the same features, although the way you interact with each is slightly different. This article is a getting-started guide for GNU Screen. For information about tmux, read Kevin Sonney's [introduction to tmux][4].
|
||||
|
||||
### Using GNU Screen
|
||||
|
||||
GNU Screen's basic usage is simple. Launch it with the `screen` command, and you're placed into the zeroeth window in a Screen session. You may hardly notice anything's changed until you decide you need a new prompt.
|
||||
|
||||
When one terminal window is occupied with an activity (for instance, you've launched a text editor like [Vim][5] or [Jove][6], or you're processing video or audio, or running a batch job), you can just open a new one. To open a new window, press **Ctrl+A**, release, and then press **c**. This creates a new window on top of your existing window.
|
||||
|
||||
You'll know you're in a new window because your terminal appears to be clear of anything aside from its default prompt. Your other terminal still exists, of course; it's just hiding behind the new one. To traverse through your open windows, press **Ctrl+A**, release, and then **n** for _next_ or **p** for _previous_. With just two windows open, **n** and **p** functionally do the same thing, but you can always open more windows (**Ctrl+A** then **c**) and walk through them.
|
||||
|
||||
### Split screen
|
||||
|
||||
GNU Screen's default behavior is more like a mobile device screen than a desktop: you can only see one window at a time. If you're using GNU Screen because you love to multitask, being able to focus on only one window may seem like a step backward. Luckily, GNU Screen lets you split your terminal into windows within windows.
|
||||
|
||||
To create a horizontal split, press **Ctrl+A** and then **s**. This places one window above another, just like window panes. The split space is, however, left unpurposed until you tell it what to display. So after creating a split, you can move into the split pane with **Ctrl+A** and then **Tab**. Once there, use **Ctrl+A** then **n** to navigate through all your available windows until the content you want to be displayed is in the split pane.
|
||||
|
||||
You can also create vertical splits with **Ctrl+A** then **|** (that's a pipe character, or the **Shift** option of the **\** key on most keyboards).
|
||||
|
||||
### Make GNU Screen your own
|
||||
|
||||
GNU Screen uses shortcuts based around **Ctrl+A**. Depending on your habits, this can either feel very natural or be supremely inconvenient because you use **Ctrl+A** to move to the beginning of a line anyway. Either way, GNU Screen permits all manner of customization through the `.screenrc` configuration file. You can change the trigger keybinding (called the "escape" keybinding) with this:
|
||||
|
||||
|
||||
```
|
||||
`escape ^jJ`
|
||||
```
|
||||
|
||||
You can also add a status line to help you keep yourself oriented during a Screen session:
|
||||
|
||||
|
||||
```
|
||||
# status bar, with current window highlighted
|
||||
hardstatus alwayslastline
|
||||
hardstatus string '%{= kG}[%{G}%H%? %1`%?%{g}][%= %{= kw}%-w%{+b yk} %n*%t%?(%u)%? %{-}%+w %=%{g}][%{B}%m/%d %{W}%C%A%{g}]'
|
||||
|
||||
# enable 256 colors
|
||||
attrcolor b ".I"
|
||||
termcapinfo xterm 'Co#256:AB=\E[48;5;%dm:AF=\E[38;5;%dm'
|
||||
defbce on
|
||||
```
|
||||
|
||||
Having an always-on reminder of what window has focus activity and which windows have background activity is especially useful during a session with multiple windows open. It's a sort of task manager for your terminal.
|
||||
|
||||
### Download the cheat sheet
|
||||
|
||||
When you're learning GNU Screen, you'll have a lot of new keyboard commands to remember. Some you'll remember right away, but the ones you use less often might be difficult to keep track of. You can always access a Help screen within GNU Screen with **Ctrl+A** then **?**, but if you prefer something you can print out and keep by your keyboard, **[download our GNU Screen cheat sheet][7]**.
|
||||
|
||||
Learning GNU Screen is a great way to increase your efficiency and alacrity with your favorite [terminal emulator][8]. Give it a try!
|
||||
|
||||
--------------------------------------------------------------------------------
|
||||
|
||||
via: https://opensource.com/article/21/4/gnu-screen-cheat-sheet
|
||||
|
||||
作者:[Seth Kenlon][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://opensource.com/users/seth
|
||||
[b]: https://github.com/lujun9972
|
||||
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/terminal_command_linux_desktop_code.jpg?itok=p5sQ6ODE (Terminal command prompt on orange background)
|
||||
[2]: https://github.com/tmux/tmux/wiki
|
||||
[3]: https://www.gnu.org/software/screen/
|
||||
[4]: https://opensource.com/article/20/1/tmux-console
|
||||
[5]: https://opensource.com/tags/vim
|
||||
[6]: https://opensource.com/article/17/1/jove-lightweight-alternative-vim
|
||||
[7]: https://opensource.com/downloads/gnu-screen-cheat-sheet
|
||||
[8]: https://opensource.com/article/21/2/linux-terminals
|
Loading…
Reference in New Issue
Block a user