为了账号安全,请及时绑定邮箱和手机立即绑定

Micronaut微服务 | 实战入门

标签:
Docker 微服务

da130d26e1cbe2c1.jpeg
> 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》

基本概述

92bf8877f200b467.png

既然决定去做一件事情,就好比把自己铺成一张稿纸,不论是信笔涂鸦还是书写酣畅,就尽情去享受和体验就好。每一进步一点,天道酬勤,谁都会是大赢家。尽管是在这个尴尬的二十几岁,正是应该丰富自己和提升自己的时候,去经历一些非议,成长才会更快。就像是缓存清零,重新启动,一切还是原来模样…在基础入门篇时候,简单概述了Micronaut配置操作。接下来,针对于这一方面做更近一步的学习。比如,在开发工具方面的配置,在Micronaut相关命令和API的运用,创建完Demo工程的项目结构解析以及项目构建等。

开发IDE配置

> Micronaut开发工具有IntelliJ IDEA ,Eclipse,Visual Studio Code三种。

IntelliJ IDEA配置

[1].增加Micronaut插件IntelliJ IDEA配置
5684cfa51596fa7d.png

[2].对于Maven 和Gradle工具的配置:

f30f526def0533f6.png

创建项目工程

  • Micronaut CLI Project Creation Commands:
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应用程序

  • Create Command Flags:
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$

工程结构

项目工程机构如下:
ca83664c6a831016.png

  • .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:项目对象模型

<?xml version="1.0" encoding="UTF-8"?>4.0.0pandora.cloud.generatorpandora-cloud-generator0.11.2.61.8${jdk.version}${jdk.version}UTF-8UTF-8pandora.cloud.generator.Application2.22.22.22.2jcenter.bintray.comhttps://jcenter.bintray.comio.micronautmicronaut-bom${micronaut.version}pomimportio.micronautmicronaut-injectcompileio.micronautmicronaut-validationcompileio.micronautmicronaut-runtimecompileio.micronautmicronaut-http-server-nettycompileio.micronautmicronaut-http-clientcompilech.qos.logbacklogback-classic1.2.3runtimeorg.junit.jupiterjunit-jupiter-apitestorg.junit.jupiterjunit-jupiter-enginetestio.micronaut.testmicronaut-test-junit5testorg.apache.maven.pluginsmaven-shade-plugin3.1.0packageshade${exec.mainClass}org.codehaus.mojoexec-maven-plugin1.6.0java-classpath-noverify-XX:TieredStopAtLevel=1-Dcom.sun.management.jmxremote${exec.mainClass}org.apache.maven.pluginsmaven-surefire-plugin${maven-surefire-plugin.version}true%regex[.*]org.apache.maven.pluginsmaven-failsafe-plugin${maven-failsafe-plugin.version}integration-testverifyorg.apache.maven.pluginsmaven-compiler-plugin3.7.0-parametersio.micronautmicronaut-inject-java1.2.6io.micronautmicronaut-validation1.2.6test-compiletestCompile-parametersio.micronautmicronaut-inject-java1.2.6io.micronautmicronaut-validation1.2.6

pom.xml主要描述了项目的maven坐标,依赖关系,开发者需要遵循的规则,缺陷管理系统,组织和licenses,以及其他所有的项目相关因素,是项目级别的配置文件。

  • src:存放开发代码和资源目录
    6cd941b828d50687.png

  • Dockerfile :构建Docker镜像的配置文件

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
  • micronaut-cli.yml:micronaut 应用的配置文件
profile: service
defaultPackage: pandora.cloud.generator
---
testFramework: junit
sourceLanguage: java

项目启动

Micronaut应用程序的启动方式和Springboot应用启动一样,通过调用Micronaut.run来实现:
e400cd0f0ef1d7f6.png

3d59552697bf8857.png

> 版权声明:本文为博主原创文章,遵循相关版权协议,如若转载或者分享请附上原文出处链接和链接来源。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消