Your story may not have a happy beginning, but that doesn't make you who you are, it is restof your story, who you choose to be.
你或许没有一个幸福的开始,但是这并不能够代表你的所有,接下来你的生活取决于你的选择。——《功夫熊猫2》
既然决定去做一件事情,就好比把自己铺成一张稿纸,不论是信笔涂鸦还是书写酣畅,就尽情去享受和体验就好。每一进步一点,天道酬勤,谁都会是大赢家。尽管是在这个尴尬的二十几岁,正是应该丰富自己和提升自己的时候,去经历一些非议,成长才会更快。就像是缓存清零,重新启动,一切还是原来模样......在基础入门篇时候,简单概述了Micronaut配置操作。接下来,针对于这一方面做更近一步的学习。比如,在开发工具方面的配置,在Micronaut相关命令和API的运用,创建完Demo工程的项目结构解析以及项目构建等。
Micronaut开发工具有IntelliJ IDEA ,Eclipse,Visual Studio Code三种。
[1].增加Micronaut插件IntelliJ IDEA配置
[2].对于Maven 和Gradle工具的配置:
Command | Description | Options | Example |
---|---|---|---|
create-app | Creates a basic Micronaut application | -p Command Flags | mn create-app my-project --features mongo-reactive,security-jwt --build maven |
create-cli-app | Creates a command-line Micronaut application. | -p Command Flags | mn create-cli-app my-project --features http-client,jdbc-hikari --build maven --lang kotlin --test kotest |
create-function-app | Creates a Micronaut serverless function, using AWS by default. | -p Command Flags | mn create-function-app my-lambda-function --lang groovy --test spock |
create-messaging-app | Creates a Micronaut application that only communicates via a messaging protocol. Uses Kafka by default but can be switched to RabbitMQ with --features rabbitmq. | -p Command Flags | mn create-function-app my-lambda-function --lang groovy --test spock |
create-grpc-app | Creates a Micronaut application that uses gRPC. | -p Command Flags | mn create-grpc-app my-grpc-app --lang groovy --test spock |
[⚠️注意事项]: Micronaut创建工程支持的模板如下: create-app:创建Micronaut基础应用程序 create-cli-app:创建Micronaut命令行应用程序 create-function-app:创建Micronaut函数应用程序,默认使用AWS create-messaging-app:创建Micronaut消息队列应用程序,默认使用Kafka create-grpc-app:创建Micronaut分布式GRPC应用程序
Flag | Description | Example |
---|---|---|
-l, --lang | Language to use for the project (one of java, groovy, kotlin - default is java) | --lang groovy |
-t, --test | Test framework to use for the project (one of junit, spock - default is junit) | --test spock |
-b,--build | Build tool (one of gradle, gradle_kotlin, maven - default is gradle for the languages java and groovy; default is gradle_kotlin for language kotlin) | --build maven |
-f,--features | Features to use for the project, comma-separated | --features security-jwt,mongo-gorm |
-i,--inplace | If present, generates the project in the current directory (project name is optional if this flag is set) | --inplace |
[⚠️注意事项]: Micronaut创建工程支持的参数如下: --lang:支持java, groovy, kotlin语言 --test:支持junit, spock测试框架 --build:支持gradle, gradle_kotlin, maven构建工具 --features:支持众多第三方框架 --inplace:支持替换参数
在本地工程目录:/Users/Projects/GitlabCloud/pandora-cloud-platform中:
MacBook-Pro:pandora-cloud-platform root$ cd /Users/Projects/GitlabCloud/pandora-cloud-platform
MacBook-Pro:pandora-cloud-platform root$ ls
LICENSE pandora-cloud-gateway
README.en.md pandora-cloud-model
README.md pandora-cloud-platform.iml
pandora-cloud-console pandora-cloud-program
pandora-cloud-core pandora-cloud-schedule
pandora-cloud-dependencies pom.xml
pandora-cloud-framework
MacBook-Pro:pandora-cloud-platform root$
输入:mn create-app com.pandora-cloud-monitor --build maven --lang=java
MacBook-Pro:pandora-cloud-platform root$ mn create-app com.pandora-cloud-monitor --build maven --lang=java
| Generating Java project...
| Application created at /Users/Projects/GitlabCloud/pandora-cloud-platform/pandora-cloud-monitor
MacBook-Pro:pandora-cloud-platform root$
.gitignore:分布式版本控制系统git的配置文件,意思为忽略提交 在 .gitingore 文件中,遵循相应的语法,即在每一行指定一个忽略规则。 如:.log、/target/、.idea
mvnw:全名是maven wrapper的文件 它的作用是在maven-wrapper.properties文件中记录你要使用的maven版本,当用户执行mvnw clean 命令时,发现当前用户的maven版本和期望的版本不一致,那么就下载期望的版本,然后用期望的版本来执行mvn命令,比如mvn clean命令。
mvn文件夹:存放mvnw相关文件 存放着maven-wrapper.properties和相关jar包以及名为MavenWrapperDownloader的java文件
mvn.cmd:执行mvnw命令的cmd入口 注:mvnw文件适用于Linux(bash),mvnw.cmd适用于Windows 环境。
pom.xml:项目对象模型
4.0.0
pandora.cloud.generator
pandora-cloud-generator
0.1
1.2.6
1.8
${jdk.version}
${jdk.version}
UTF-8
UTF-8
pandora.cloud.generator.Application
2.22.2
2.22.2
jcenter.bintray.com
https://jcenter.bintray.com
io.micronaut
micronaut-bom
${micronaut.version}
pom
import
io.micronaut
micronaut-inject
compile
io.micronaut
micronaut-validation
compile
io.micronaut
micronaut-runtime
compile
io.micronaut
micronaut-http-server-netty
compile
io.micronaut
micronaut-http-client
compile
ch.qos.logback
logback-classic
1.2.3
runtime
org.junit.jupiter
junit-jupiter-api
test
org.junit.jupiter
junit-jupiter-engine
test
io.micronaut.test
micronaut-test-junit5
test
org.apache.maven.plugins
maven-shade-plugin
3.1.0
package
shade
${exec.mainClass}
org.codehaus.mojo
exec-maven-plugin
1.6.0
java
-classpath
-noverify
-XX:TieredStopAtLevel=1
-Dcom.sun.management.jmxremote
${exec.mainClass}
org.apache.maven.plugins
maven-surefire-plugin
${maven-surefire-plugin.version}
true
%regex[.*]
org.apache.maven.plugins
maven-failsafe-plugin
${maven-failsafe-plugin.version}
integration-test
verify
org.apache.maven.plugins
maven-compiler-plugin
3.7.0
-parameters
io.micronaut
micronaut-inject-java
1.2.6
io.micronaut
micronaut-validation
1.2.6
test-compile
testCompile
-parameters
io.micronaut
micronaut-inject-java
1.2.6
io.micronaut
micronaut-validation
1.2.6
pom.xml主要描述了项目的maven坐标,依赖关系,开发者需要遵循的规则,缺陷管理系统,组织和licenses,以及其他所有的项目相关因素,是项目级别的配置文件。
* src:存放开发代码和资源目录
![6cd941b828d50687.png](https://img-blog.csdnimg.cn/20210312171248738.png)
* Dockerfile :构建Docker镜像的配置文件
```yml
FROM adoptopenjdk/openjdk11-openj9:jdk-11.0.1.13-alpine-slim
COPY target/pandora-cloud-generator-*.jar pandora-cloud-generator.jar
EXPOSE 8080
CMD java -Dcom.sun.management.jmxremote -noverify ${JAVA_OPTS} -jar pandora-cloud-generator.jar
profile: service
defaultPackage: pandora.cloud.generator
testFramework: junit sourceLanguage: java
```
Micronaut应用程序的启动方式和Springboot应用启动一样,通过调用Micronaut.run来实现:
版权声明:本文为博主原创文章,遵循相关版权协议,如若转载或者分享请附上原文出处链接和链接来源。