• docker启动,解决jenkins内存占用过高


     在下面模块添加参数,因为是docker启动,所以与其他博客解决方法不一致

    environment:

    JAVA_OPTS : "-server -Xms1024m -Xmx1024m -XX:PermSize=256m -XX:MaxPermSize=512m"
    

    JAVA_OPTS,顾名思义,是用来设置JVM相关运行参数的变量。

    JVM:JAVA_OPTS =“ - server -Xms2048m -Xmx2048m -Xss512k”

    -server:一定要作为第一个参数,在多个CPU时性能佳
    -Xms:初始堆大小,使用的最小内存,cpu性能高时此值应设的大一些
    -Xmx:Java? heap最大值,使用-XX:PermSize:设置内存的永久保存区域-XX:MaxPermSize:最大内存
    上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。设置最大内存的永久保存区域-XX:MaxNewSize:-Xss 15120这使得JBoss每增加一个线程(线程)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k。+ XX:AggressiveHeap会使得Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完了一个G物理内存,再吃尽一个G的swap。-Xss:每个线程的Stack大小–verbose :gc现实垃圾收集信息-Xloggc:gc.log指定垃圾收集日志文件-Xmn:young generation的堆大小,一般设置为Xmx的3,4分之一-XX:+ UseParNewGC:缩短minor收集的时间-XX:+ UseConcMarkSweepGC:缩短主要收集的时间提示:此选项在堆大小比较大而且主要收集时间较长的情况下使用更合适。

    PermGen space的全称是Permanent Generation space,是指内存的永久保存区域OutOfMemoryError:PermGen space从表面上看就是内存益出,解决方法也一定是加大内存。说说为什么会内存益出:这一部分用于存放Class和Meta的信息,Class在被加载的时候被放入PermGen空间区域,它和和存放实例的堆区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen空间进行清理,所以如果改变方法:-Xms256m -Xmx256m -XX:MaxNewSize = 256m -XX:MaxPermSize = 256m -XX:MaxPermSize = 256m -XX:MaxPermSize = 256m 2,在tomcat中重新部署时出现outofmemory的错误。可以有以下几个方面的原因:
    1,使用了proxool,因为proxool内部包含了一个老版本的cglib。
    2,log4j,最好不用,只用common-logging
    3,老版本的cglib,快点更新到最新版本
    。4,更新到最新的hibernate3.2 3,
     

  • 相关阅读:
    Redis 的大 Key 对持久化有什么影响?
    MySQL操作合集
    CMake教程-第 1 步:基本起点
    【Hello Go】Go语言文本文件处理
    ps -ef|grep test的意思
    Lens5 指南:专为Kubernetes人员设计的IDE
    QML布局管理之Layouts
    基于Java的驾校收支管理可视化平台设计与实现(源码+lw+部署文档+讲解等)
    混沌映射与动态学习的自适应樽海鞘群算法-附代码
    微信小程序注册指引
  • 原文地址:https://blog.csdn.net/weixin_43997319/article/details/126938893