前言: 在命令行中输入可以输入各类参数,本文将针对这些参数做一个小结。
基于命令行输入参数
测试程序如下:
import java.util.Arrays; public class Main { public static void main(String[] args) { System.out.println("System Property, abc:" + System.getenv("feature.flag") + "," + System.getProperty("feature")); System.out.println("args:" + Arrays.toString(args)); } }
基于命令行的输入:
java -Dfeature=module1 -Xms128M -Xmx256M org.spb.data.Main first second third
输出为:
System Property, abc:null,module1
args:[first, second, third]
从上述示例中可知 -Dfeature=module1,设置了系统属性信息,被正确地解析出来。系统属性的设置位于Java程序之前。
first second third作为Java程序的args参数,需要放在程序之后才可以正确被解析。
-Xms128 -Xmx256M: 为设置JVM的参数,这里设置了其对内存的大小。
如果是Spring Boot应用的话,则可以在命令行设置:
– server.port=9091
通过两个‘- - '作为命令行参数的前缀。
基于Run Configuration界面设置Java程序的入口参数:
设置环境变量:
程序运行的结果信息:
从运行结果中可知: 环境变量被正确设置读取,但是系统属性却未正确设置。
基于命令行输入系统属性
java -Dfeature=module1 org.spb.data.Main
-D 表示其为系统属性
JVM参数设置
java -Xms128M -Xmx256M org.spb.data.Main
JVM参数是设置JVM的设置,其遵守JVM设置的参数类型。
环境变量 vs 系统属性
当程序中需要使用与操作系统相关的变量(例如:文件分隔符、换行符)时,Java提供了System类的静态方法getenv()和getProperty()用于返回系统相关的变量与属性,getenv方法返回的变量大多于系统相关,getProperty方法返回的变量大多与java程序有关。
系统属性和环境变量都是名称与值之间的映射。两种机制都能用来将用户定义的信息传递给 Java进程。环境变量产生更多的全局效应,因为它们不仅对Java子进程可见,而且对于定义它们的进程的所有子进程都是可见的。在不同的操作系统上,它们的语义有细微的差别,比如,不区分大小写。因此环境变量更可能有意料不到的副作用。程序中尽可能使用系统属性。环境变量应该在需要全局效应的时候使用,或者在外部系统接口要求使用环境变量时使用(比如 PATH)
从上述示例可知,系统属性由于其与程序紧密相关,则可以基于命令行进行设置。但是,环境变量则无法通过程序进行设置,需要基于IDE和环境变量进行设置。
Java命令行的帮助信息:
图中标示出来的就是系统属性信息。
基于Maven命令运行Spring Boot应用
程序代码如下:
@Slf4j @SpringBootApplication public class AppRunnerApplication { public static void main(String[] args) throws InterruptedException { SpringApplication.run(AppRunnerApplication.class, args); //Thread.currentThread().join(); log.info("args:{}", Arrays.toString(args)); log.info("feature:" + System.getProperty("feature")); log.info("feature.flag:" + System.getenv("feature.flag")); } }
mvn spring-boot:run -Dmaven.test.skip=true -Pdev -Dspring-boot.run.arguments=“first seond third” -Dspring-boot.run.jvmArguments="-Dfeature=module11"
-Dfeature=module11设置系统属性信息
arguments: 设置Java 程序main的入口参数
对于环境变量,则需要设置pom.xml文件中的plugin配置项:
org.springframework.boot spring-boot-maven-plugin moduleXXX true
运行结果为:
2019-11-11 23:08:22.764 INFO 18717 --- [ restartedMain] o.s.d.apprunner.cmdline.AppLineRunner1 : App LineRunner1:first seond third
2019-11-11 23:08:22.765 INFO 18717 --- [ restartedMain] o.s.d.apprunner.cmdline.AppLineRunner2 : App LineRunner2:[first seond third]
2019-11-11 23:08:22.766 INFO 18717 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : args:[first seond third]
2019-11-11 23:08:22.766 INFO 18717 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : feature:module11
2019-11-11 23:08:22.766 INFO 18717 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : feature.flag:true
如果在命令行不进行jvmArguments的参数设置:
mvn spring-boot:run -Dmaven.test.skip=true -Pdev -Dspring-boot.run.arguments=“first seond third”
输出结果信息如下:
2019-11-11 23:11:55.399 INFO 18757 --- [ restartedMain] o.s.d.apprunner.cmdline.AppLineRunner2 : App LineRunner2:[first seond third]
2019-11-11 23:11:55.400 INFO 18757 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : args:[first seond third]
2019-11-11 23:11:55.400 INFO 18757 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : feature:moduleXXX
2019-11-11 23:11:55.400 INFO 18757 --- [ restartedMain] o.s.data.apprunner.AppRunnerApplication : feature.flag:true
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。