草庐IT

jvm-bytecode

全部标签

java - 在 JVM 上禁用本地 JMX 连接

我们正在编写一个将密码保存在内存中的java程序。不幸的是,用户可以轻松地使用jconsole或jmap来创建堆转储文件并打开它以查找密码。我认为jconsole使用本地套接字连接jvm。我想知道,即使对于本地用户,有什么方法可以禁用jmx吗?有没有办法完全禁用堆转储?由于用户可以访问内存段,因此无论如何都可以访问密码。但是,我想禁用执行此操作的标准方法,以使操作尽可能昂贵。 最佳答案 最后,我找到了禁用jconsole连接的解决方案。它还阻止jmap创建转储文件。我找到了解决方案here.我也在这里引用答案:Youcanpreve

java - 在 JVM 上禁用本地 JMX 连接

我们正在编写一个将密码保存在内存中的java程序。不幸的是,用户可以轻松地使用jconsole或jmap来创建堆转储文件并打开它以查找密码。我认为jconsole使用本地套接字连接jvm。我想知道,即使对于本地用户,有什么方法可以禁用jmx吗?有没有办法完全禁用堆转储?由于用户可以访问内存段,因此无论如何都可以访问密码。但是,我想禁用执行此操作的标准方法,以使操作尽可能昂贵。 最佳答案 最后,我找到了禁用jconsole连接的解决方案。它还阻止jmap创建转储文件。我找到了解决方案here.我也在这里引用答案:Youcanpreve

java - JVM 是否有最坏的情况实现?

Javamemorymodel明确了关于线程如何通过内存进行交互的可以假设和不可以假设的内容。例如,如果一个线程在没有适当同步的情况下将新值写入字段,则不能保证其他线程可以观察到新值。然而,在实践中,尽管同步不充分,其他线程仍可能读取新值,具体取决于写入和读取之间的时间、硬件架构等。这可能会导致难以发现且难以重现的错误。因此,在最坏情况下的JVM上运行Java应用程序可能很有用,该JVM绝对没有线程之间的内存同步,超出Javamemorymodel中的保证。.这种最坏情况的JVM实现是否存在? 最佳答案 您可以尝试使用Terraco

java - JVM 是否有最坏的情况实现?

Javamemorymodel明确了关于线程如何通过内存进行交互的可以假设和不可以假设的内容。例如,如果一个线程在没有适当同步的情况下将新值写入字段,则不能保证其他线程可以观察到新值。然而,在实践中,尽管同步不充分,其他线程仍可能读取新值,具体取决于写入和读取之间的时间、硬件架构等。这可能会导致难以发现且难以重现的错误。因此,在最坏情况下的JVM上运行Java应用程序可能很有用,该JVM绝对没有线程之间的内存同步,超出Javamemorymodel中的保证。.这种最坏情况的JVM实现是否存在? 最佳答案 您可以尝试使用Terraco

java - JVM 分析器与 Mac OS X Activity 监视器中的内存使用情况

我一直在分析我的java应用程序,并且对我的应用程序报告的内存使用情况感到困惑(通过eclipse运行)。它与分析器报告的内存使用情况总是非常不同,甚至与自身都不匹配。应用程序的JVM标志是:-Xmx1G-Xms1G -XX:MaxMetaspaceSize=256M-XX:CompressedClassSpaceSize=256M此图显示进程“java”的报告内存为1.67GB。当我双击该进程时,分割显示1.15GB的“实际内存大小”和其他各种内存指标。飞行记录器显示应用程序遵守其1GB堆大小。我进行的测试表明它也遵守其元空间限制。我的问题有两个:1)知道为什么报告的内存使用情况在进

java - JVM 分析器与 Mac OS X Activity 监视器中的内存使用情况

我一直在分析我的java应用程序,并且对我的应用程序报告的内存使用情况感到困惑(通过eclipse运行)。它与分析器报告的内存使用情况总是非常不同,甚至与自身都不匹配。应用程序的JVM标志是:-Xmx1G-Xms1G -XX:MaxMetaspaceSize=256M-XX:CompressedClassSpaceSize=256M此图显示进程“java”的报告内存为1.67GB。当我双击该进程时,分割显示1.15GB的“实际内存大小”和其他各种内存指标。飞行记录器显示应用程序遵守其1GB堆大小。我进行的测试表明它也遵守其元空间限制。我的问题有两个:1)知道为什么报告的内存使用情况在进

java - -XX :NewRatio and -XX:OldSize JVM flags? 是什么意思

我正在使用以下命令行启动我的java应用程序:java-XX:+PrintCommandLineFlags-verbose:gc-XX:+PrintGCDetails\-XX:+UseConcMarkSweepGC-jarstart.jarJVM启用以下选项:-XX:MaxNewSize=87244800-XX:MaxTenuringThreshold=4-XX:NewRatio=7-XX:NewSize=21811200-XX:OldPLABSize=16-XX:OldSize=65433600-XX:+PrintCommandLineFlags-XX:+PrintGC-XX:+Pr

java - -XX :NewRatio and -XX:OldSize JVM flags? 是什么意思

我正在使用以下命令行启动我的java应用程序:java-XX:+PrintCommandLineFlags-verbose:gc-XX:+PrintGCDetails\-XX:+UseConcMarkSweepGC-jarstart.jarJVM启用以下选项:-XX:MaxNewSize=87244800-XX:MaxTenuringThreshold=4-XX:NewRatio=7-XX:NewSize=21811200-XX:OldPLABSize=16-XX:OldSize=65433600-XX:+PrintCommandLineFlags-XX:+PrintGC-XX:+Pr

java - JVM 信号链 SIGPIPE

我们有一个带有嵌入式JVM(Sun的)的C++应用程序。因为我们注册了自己的信号处理程序,所以建议我们在初始化JVM之前这样做,因为它会安装自己的处理程序(seehere)。据我了解,JVM在内部知道信号是否来自它自己的代码,如果不是,它会沿着链将信号传递给我们的处理程序。我们开始看到的是我们正在获取SIGPIPE,其调用堆栈大致如下所示(顶部条目是我们的信号处理程序):/.../libos_independent_utilities.so(_ZN2os32smart_synchronous_signal_handlerEiP7siginfoPv+0x9)[0x2b124f7a3989

java - JVM 信号链 SIGPIPE

我们有一个带有嵌入式JVM(Sun的)的C++应用程序。因为我们注册了自己的信号处理程序,所以建议我们在初始化JVM之前这样做,因为它会安装自己的处理程序(seehere)。据我了解,JVM在内部知道信号是否来自它自己的代码,如果不是,它会沿着链将信号传递给我们的处理程序。我们开始看到的是我们正在获取SIGPIPE,其调用堆栈大致如下所示(顶部条目是我们的信号处理程序):/.../libos_independent_utilities.so(_ZN2os32smart_synchronous_signal_handlerEiP7siginfoPv+0x9)[0x2b124f7a3989