目前项目的 G1 JVM参数

目前很多人还是使用 JDK8 ,cms

我认为应该 升级一下了。 因为大佬说一些JVM问题,升级JDK就可以解决的。

而我确实也遇到到 CMS的问题,升级到G1就解决了。

#!/bin/sh

ps -fe|grep bigdoor.jar |grep -v grep

if [ $? -ne 0 ]

then

echo "start process....."

else

echo " is runing....."

ps -ef | grep bigdoor.jar | grep -v grep | awk '{print $2}' | xargs kill -9

echo "shutdown !"

fi

nohup java \

-Xms10g -Xmx10g \

-XX:-UseConcMarkSweepGC -XX:-UseCMSInitiatingOccupancyOnly -XX:+UseG1GC \

-XX:InitiatingHeapOccupancyPercent=65 \

-XX:+AlwaysPreTouch \

-Djava.awt.headless=true \

-Dfile.encoding=UTF-8 \

-XX:SoftRefLRUPolicyMSPerMB=0 \

-XX:-OmitStackTraceInFastThrow \

-XX:+HeapDumpOnOutOfMemoryError \

-XX:HeapDumpPath=/home/log \

-XX:ErrorFile=/home/log/hs_err_pid%p.log \

-Xlog:gc*,gc+age=trace,safepoint:file=/home/log/gc/gc.log:utctime,pid,tags:filecount=32,filesize=64m \

-jar /home/application/bigdoor.jar \

--server.port=8889 --spring.profiles.active=prod > /home/log/bigdoor.log 2>&1 &

echo "启动成功"

tail -500f /home/log/bigdoor.log

永洪的 G1 Tomcat jvm 参数 参考

/home/yongh/bi/jdk-11.0.4/bin/java -Djava.util.logging.config.file=/home/yongh/8612_CMR/tomcat/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager

-Djdk.tls.ephemeralDHKeySize=2048

-Djava.protocol.handler.pkgs=org.apache.catalina.webresources

-Xmx32768m -Xms32768m

-XX:MetaspaceSize=256m

-XX:G1HeapRegionSize=32m -XX:InitiatingHeapOccupancyPercent=35 -XX:G1ReservePercent=15 -XX:ConcGCThreads=10 -XX:ParallelGCThreads=10 -XX:+ParallelRefProcEnabled -XX:SoftRefLRUPolicyMSPerMB=0 -Xlog:gc*:file=/home/yongh/8612_CMR/tomcat/../Yonghong/log/jvm.log:time:filecount=16 -Djava.awt.headless=true --add-exports java.base/jdk.internal.ref=ALL-UNNAMED --add-opens java.base/jdk.internal.ref=ALL-UNNAMED -XX:OnError=/home/yongh/bi/jdk-11.0.4/bin/jstack %p >/home/yongh/8612_CMR/tomcat/logs/thread_stack_%p.log -XX:ErrorFile=/home/yongh/8612_CMR/tomcat/logs/hs_err_%p.log -XX:OnOutOfMemoryError=/home/yongh/bi/jdk-11.0.4/bin/jmap -dump:format=b,file=/home/yongh/8612_CMR/tomcat/logs/jmap_%p.log %p -XX:+ExitOnOutOfMemoryError -Dignore.endorsed.dirs= -classpath :/home/yongh/8612_CMR/tomcat/webapps/bi/WEB-INF/classes:/home/yongh/8612_CMR/tomcat/../Yonghong/product/api-20200728.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/product/product-20200728.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/product/product-swf-20200728.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/product/thirds.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/lib/customer/customer.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/lib/customer/g5util-8.5-2.1.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/lib/customer.jar:/home/yongh/8612_CMR/tomcat/../Yonghong/lib/g5util-8.5-2.1.jar:/home/yongh/8612_CMR/tomcat/lib/servlet-api.jar:/home/yongh/8612_CMR/tomcat/bin/bootstrap.jar:/home/yongh/8612_CMR/tomcat/bin/tomcat-juli.jar -Dcatalina.base=/home/yongh/8612_CMR/tomcat -Dcatalina.home=/home/yongh/8612_CMR/tomcat -Djava.io.tmpdir=/home/yongh/8612_CMR/tomcat/temp org.apache.catalina.startup.Bootstrap start

ES 的JVM 参数 参考

ES就比较厉害了,发现他的JDK版本基本都是最新的版本的。

因此G1的参数优化 参考ES的即可。

## JVM configuration

################################################################

## IMPORTANT: JVM heap size

################################################################

##

## You should always set the min and max JVM heap

## size to the same value. For example, to set

## the heap to 4 GB, set:

##

## -Xms4g

## -Xmx4g

##

## See https://www.elastic.co/guide/en/elasticsearch/reference/current/heap-size.html

## for more information

##

################################################################

# Xms represents the initial size of total heap space

# Xmx represents the maximum size of total heap space

-Xms1g

-Xmx1g

################################################################

## Expert settings

################################################################

##

## All settings below this section are considered

## expert settings. Don't tamper with them unless

## you understand what you are doing

##

################################################################

## G1GC Configuration

# NOTE: G1GC is only supported on JDK version 10 or later.

# To use G1GC uncomment the lines below.

# 10-:-XX:-UseConcMarkSweepGC

# 10-:-XX:-UseCMSInitiatingOccupancyOnly

# 10-:-XX:+UseG1GC

# 10-:-XX:InitiatingHeapOccupancyPercent=75

## DNS cache policy

# cache ttl in seconds for positive DNS lookups noting that this overrides the

# JDK security property networkaddress.cache.ttl; set to -1 to cache forever

-Des.networkaddress.cache.ttl=60

# cache ttl in seconds for negative DNS lookups noting that this overrides the

# JDK security property networkaddress.cache.negative ttl; set to -1 to cache

# forever

-Des.networkaddress.cache.negative.ttl=10

## optimizations

# pre-touch memory pages used by the JVM during initialization

-XX:+AlwaysPreTouch

## basic

# explicitly set the stack size

-Xss1m

# set to headless, just in case

-Djava.awt.headless=true

# ensure UTF-8 encoding by default (e.g. filenames)

-Dfile.encoding=UTF-8

# use our provided JNA always versus the system one

-Djna.nosys=true

# turn off a JDK optimization that throws away stack traces for common

# exceptions because stack traces are important for debugging

-XX:-OmitStackTraceInFastThrow

# flags to configure Netty

-Dio.netty.noUnsafe=true

-Dio.netty.noKeySetOptimization=true

-Dio.netty.recycler.maxCapacityPerThread=0

# log4j 2

-Dlog4j.shutdownHookEnabled=false

-Dlog4j2.disable.jmx=true

-Djava.io.tmpdir=${ES_TMPDIR}

## heap dumps

# generate a heap dump when an allocation from the Java heap fails

# heap dumps are created in the working directory of the JVM

-XX:+HeapDumpOnOutOfMemoryError

# specify an alternative path for heap dumps; ensure the directory exists and

# has sufficient space

-XX:HeapDumpPath=data

# specify an alternative path for JVM fatal error logs

-XX:ErrorFile=logs/hs_err_pid%p.log

# JDK 9+ GC logging

9-:-Xlog:gc*,gc+age=trace,safepoint:file=logs/gc.log:utctime,pid,tags:filecount=32,filesize=64m

# due to internationalization enhancements in JDK 9 Elasticsearch need to set the provider to COMPAT otherwise

# time/date parsing will break in an incompatible way for some date patterns and locals

9-:-Djava.locale.providers=COMPAT

gc log 配置参考

gc log 配置 优化

-Xlog:gc*,gc+age=trace,safepoint:file=/home/log/gc/gc.log:utctime,pid,tags:filecount=32,filesize=64m 如果这样配置,

结果我将gc.log 放入 gcviewer 里面进行分析,就报错了,因为格式不对。 或者将其上传 到 http://gceasy.io/ 上面分析也是报错。

也就是上面的方式是不对的。不利于利用工具进行分析 gc

https://github.com/chewiebug/GCViewer/issues/245

需要下面的格式才可以分析 GC log

下面的就可以使用 gcviewer 和 gceasy 线上去分析了

-Xlog:gc*=info:file=/home/log/gc/gc.log:tags,time,uptime,level

https://segmentfault.com/a/1190000013475524

https://blog.csdn.net/zhxdick/article/details/104556869

java g1 配置_项目G1 jvm 常规参数配置相关推荐

  1. java heap最大最小参数_闲谈JVM(一):浅析JVM Heap参数配置

    文章目录 前言 JVM内存模型 堆(Heap)配置 Xms与InitialHeapSize Xmx与MaxHeapSize Heap的缺省配置 Default Heap Size Client JVM ...

  2. JVM启动参数配置详解

    JVM启动参数配置详解 1. JDK8的JVM启动参数默认配置 2. JDK8的JVM启动参数说明 2.1 基本参数 2.2 G1相关参数 2.3 辅助信息 1. JDK8的JVM启动参数默认配置 - ...

  3. JVM:JVM常见参数配置

    JVM常见参数配置 JVM的参数类型: 1.标配参数:-version,-help,-showversion 2.x参数(了解):-Xint:解释执行:-Xcomp:第一次使用就编译成本地代码:-Xm ...

  4. jvm内存参数配置_“步步精心”-常用JVM配置参数

    本文主要内容: Trace跟踪参数 堆的分配参数 栈的分配参数 零.在IDE的后台打印GC日志: 既然学习JVM,阅读GC日志是处理Java虚拟机内存问题的基础技能,它只是一些人为确定的规则,没有太多 ...

  5. 修改java启动参数_如何修改jvm启动参数

    用java命令查看. 用java -option进行修改参数. 还有tomcat,eclipse启动时通过配置文件加载的. 详细如下: 安装Java开发软件时,默认安装包含两个文件夹,一个JDK(Ja ...

  6. centos配置java环境变量_【开发笔记】-CentOS配置Java环境变量

    如果开发java应用,经常需要配置JAVA_HOME路径,如果是通过yum安装的jdk(一般系统会自带open-jdk),下面讲述配置过程: A 定位JDK安装路径 1. 终端输入: which ja ...

  7. jvm内存参数配置_JVM内存结构和Java内存模型

    一.JVM 首先看一张JVM结构图(某度找的) 主要看运行时数据区,里边有方法区,堆,java虚拟机栈,本地方法栈,程序计数器.其中方法区和堆是线程共享的,也是JVM进行垃圾收集的区域,java虚拟机 ...

  8. java后端概述_项目概述

    一.项目简介 一个简单的前后端分离的web项目,后端语言为java ,着重记录项目环境搭建,发布到服务器中遇到的一些问题.项目代码会上传github,但是不会讲解太多后端代码的内容.项目会涉及vsft ...

  9. Java JVM虚拟机参数配置 - GC

    1.堆内存 Java中的堆是JVM所管理的内存中最大的一块内存空间,主要用于存放各种类的实例对象. 在Java中堆被划分成两个不同的区域:新生代(Young).老年代(Old).而新生代又被划分为三个 ...

  10. jvm对于java的意义_谈谈对JVM的理解

    JVM可谓是学习JAVA基础中的基础了,但仍有不少同学对JVM概念还是比较模糊,甚至没有听说过,对java的理解也只是在基础语法 层面,本文就将对JVM进行初步介绍,因篇幅所限,只能介绍JVM基础,如 ...

最新文章

  1. MR-CNN网络结构
  2. Android总结之链式调用(方法链)
  3. “在使用GCC时,同意Xcode / iOS许可证需要管理员权限,请通过sudo以root身份重新运行。”
  4. Office EXCEL 如何为宏命令指定快捷键或者重新设置快捷键
  5. ajax get时不能更新页面的解决方法
  6. mysql同步row模式_ROW模式的SQL无法正常同步的问题总结
  7. nginx搭建静态服务器(127.0.0.1/localhost访问)
  8. 关于h5中背景音乐的自动播放
  9. getbook netty实战_Netty 入门教程
  10. raspberry pi_我如何使用Raspberry Pi与孙辈联系
  11. 物联网感知-分布式光纤振动传感主机实现基本原理
  12. 4个老司机常用的黑科技资源网站
  13. 98.android 全国城市区号,座机号区号匹配对应城市
  14. Java后台集成融云即时通讯IM
  15. 虚拟服务器防病毒,windows 2008 Hyper-v虚拟化防病毒
  16. IntelliJ IDEA 创建普通 JavaSE 项目
  17. 【假期学习计划】深度强化学习算法与应用培训班
  18. 袋鼠过河问题(Java)
  19. iphone手机设置自定义歌曲为铃声教程
  20. 【Android】ListView、RecyclerView、ScrollView里嵌套ListView 相对优雅的解决方案:NestFullListView

热门文章

  1. 使用Edge的Markdown Viewer插件查看md文件
  2. 计算机6005是开机时间,怎么查电脑的开机,和关机时间·,同学们
  3. 当前地震预测研究的状况报告
  4. gmap 支持python吗_在gmap中使用bokeh的python为for circle添加工具提示
  5. JS基础——多张图片循环切换
  6. linux logo程序,制作自己的linux启动LOGO
  7. bzoj 3375: [Usaco2004 Mar]Paranoid Cows 发疯的奶牛
  8. 20190328-几种数据清洗的方法
  9. 纯css画三角形/梯形(兼容ie6)
  10. 基于Spring Boot的健身房管理系统设计与实现