我已经使用TMP环境变量来控制gcc写入临时文件的地方,但我似乎找不到java的createTempFile API 的等价物.
这样的环境变量是否存在?
如何通过环境变量设置Java的最小和最大堆大小?
我知道在启动java时可以设置堆大小,但我希望在服务器上通过环境变量进行调整.
如何使用JAVA_OPTS变量配置Web服务器(Linux服务器)?
我该怎么设置-Djava.awt.headless=true使用JAVA_OPTS?
在shell脚本中,我设置了JAVA_OPTS环境变量(以启用远程调试并增加内存),然后执行jar文件,如下所示:
export JAVA_OPTS="-Xdebug -Xrunjdwp:transport=dt_socket,address=8001,server=y,suspend=n -Xms512m -Xmx512m"
java -jar analyse.jar $*
Run Code Online (Sandbox Code Playgroud)
但似乎没有JAVA_OPTS env变量的影响,因为我无法连接到远程调试,我看到JVM的内存没有变化.
可能是什么问题呢?
PS:我无法在java -jar analyse.jar $*命令中使用这些设置,因为我在应用程序中处理命令行参数.
我正在使用Gradle spring-boot插件,我需要为测试运行选择一个弹簧活动配置文件.
如何将spring.profiles.active系统属性传递给bootRun插件的任务?
什么已经失败:
task bootRunLocal {
systemProperty "spring.profiles.active", "local"
System.setProperty("spring.profiles.active", "local")
tasks.bootRun.execute() // I suspect that this task is executed in a separate JVM
}
Run Code Online (Sandbox Code Playgroud)
并且一些命令行魔法也失败了:
./gradle -Dspring.profiles.active=local bootRun
Run Code Online (Sandbox Code Playgroud)
有人可以帮助我解决我的烦恼吗?
从答案和评论中更新:
我可以设置systemProperty并通过执行以下操作将其传递给spring容器:
run {
systemProperty "spring.profiles.active", "local"
}
Run Code Online (Sandbox Code Playgroud)
但是,当我这样做时,正在为bootRun任务和bootRunLocal任务设置本地配置文件.我需要一种方法来为bootRunLocal任务和调用booRun任务设置此属性bootRunLocal.
这可能听起来很简单,但我来自Maven结构化世界的和平.
我正在使用_JAVA_OPTIONS为RHEL上的Java设置一些默认值.它工作正常,但现在每次我启动java我得到以下消息
拿起_JAVA_OPTIONS:-foo -bar -baz
是否可以保留选项但禁止显示此消息.
任何人都可以解释当_JAVA_OPTIONS环境变量定义时以及在Windows机器上启动应用程序时Java会做什么?