{"id":1228,"date":"2019-03-23T02:39:39","date_gmt":"2019-03-23T02:39:39","guid":{"rendered":"http:\/\/www.ipcpu.com\/?p=1228"},"modified":"2019-11-11T08:02:26","modified_gmt":"2019-11-11T08:02:26","slug":"java-in-docker-and-kubernetes","status":"publish","type":"post","link":"https:\/\/c.ipcpu.com\/2019\/03\/java-in-docker-and-kubernetes\/","title":{"rendered":"Java in Docker and Kubernetes"},"content":{"rendered":"

\u8fd0\u884c\u5728Docker\u6216\u8005Kubernetes\u4e2d\u7684JAVA\u7a0b\u5e8f\u5982\u4f55\u6b63\u786e\u83b7\u53d6CPU\u548c\u5185\u5b58\u7684\u9650\u5236<\/p>\n

\"\"<\/p>\n

\u96f6\u3001\u6982\u8ff0<\/h2>\n

Docker\u5bb9\u5668\u5229\u7528CGroup\u5bf9\u8fdb\u7a0b\u4f7f\u7528\u7684\u8d44\u6e90\u8fdb\u884c\u9650\u5236\uff0c\u800c\u5728\u5bb9\u5668\u4e2d\u7684JVM\u4f9d\u7136\u4f1a\u5229\u7528\u5bbf\u4e3b\u673a\u73af\u5883\u7684\u5185\u5b58\u5927\u5c0f\u548cCPU\u6838\u6570\u8fdb\u884c\u7f3a\u7701\u8bbe\u7f6e\uff0c\u8fd9\u5bfc\u81f4\u4e86JVM Heap\u7684\u9519\u8bef\u8ba1\u7b97\u3002JVM\u7f3a\u7701\u7684GC\u3001JIT\u7f16\u8bd1\u7ebf\u7a0b\u6570\u91cf\u53d6\u51b3\u4e8e\u5bbf\u4e3b\u673aCPU\u6838\u6570\u3002\u5982\u679c\u6211\u4eec\u5728\u4e00\u4e2a\u8282\u70b9\u4e0a\u8fd0\u884c\u591a\u4e2aJava\u5e94\u7528\uff0c\u5373\u4f7f\u6211\u4eec\u8bbe\u7f6e\u4e86CPU\u7684\u9650\u5236\uff0c\u5e94\u7528\u4e4b\u95f4\u4f9d\u7136\u6709\u53ef\u80fd\u56e0\u4e3aGC\u7ebf\u7a0b\u62a2\u5360\u5207\u6362\uff0c\u5bfc\u81f4\u5e94\u7528\u6027\u80fd\u53d7\u5230\u5f71\u54cd\u3002<\/p>\n

\u90a3\u4e48\u6211\u4eec\u6765\u770b\u4e0b\u5404\u4e2a\u7248\u672cJDK\u5982\u4f55\u4f7f\u7528docker\u7684\u9650\u5236\u3002<\/p>\n

\u4e00\u3001JDK\u8001\u7248\u672c<\/h3>\n

1\u3001\u4f7f\u7528\u73af\u5883\u53d8\u91cf\uff0c\u76f4\u63a5\u6307\u5b9aJVM\u5806\u5927\u5c0f -e JAVA_OPTIONS='xMX300m'
\n2\u3001\u660e\u786eGC\u548cJIT\u5e76\u884c\u7ebf\u7a0b\u6570\u76ee\uff0c\u4ee5\u907f\u514d\u4e8c\u8005\u5360\u7528\u8fc7\u591a\u8d44\u6e90\u3002<\/p>\n

\n
-XX:ParallelGCTreads\r\n-XX:CICompilerCount<\/code><\/pre>\n<\/div>\n

\u6ce8\u610fParallelGCThreads\u7684\u8ba1\u7b97\u65b9\u6cd5\uff1a<\/p>\n

\n
ParallelGCThreads = (ncpus <= 8) ? ncpus : (8 + ((ncpus - 8) * 5) \/ 8);\r\n#cpu\u6838\u6570\u5c0f\u4e8e\u7b49\u4e8e8\uff0c\u53d6\u6838\u6570\uff1bcpu\u6838\u6570\u5927\u4e8e8\u6309\u540e\u9762\u516c\u5f0f\u8ba1\u7b97<\/code><\/pre>\n<\/div>\n

\u4e8c\u3001 JDK 8u131+(backported)<\/h3>\n

\u4f7f\u7528\u4ee5\u4e0bJVM\u53c2\u6570\uff0c\u9002\u914ddocker\u5bb9\u5668\u7684\u5185\u5b58\uff0cCPU\u53ef\u80fd\u65e0\u6cd5\u83b7\u53d6\u9650\u5236\uff0c\u9700\u8981\u624b\u52a8\u8bbe\u7f6e<\/p>\n

\n
-XX:+UnlockExperimentalVMOptions \r\n-XX:+UseCGroupMemoryLimitForHeap<\/code><\/pre>\n<\/div>\n

\u4e09\u3001 JDK 8u191+(backported)<\/h3>\n

\u9ed8\u8ba4\u5f00\u542f\u4e86UseContainerSupport\uff0c\u652f\u6301\u5bb9\u5668\u5185\u90e8\u83b7\u53d6CPU\u548c\u5185\u5b58\u9650\u5236\u3002<\/p>\n

\n
-XX:UseContainerSupport<\/code><\/pre>\n<\/div>\n

\u5e76\u589e\u52a0\u4e86ActiveProcessorCount\u53c2\u6570\u6307\u5b9aCPU\u6570\u91cf<\/p>\n

\n
-XX:ActiveProcessorCount=count\r\n<\/code><\/pre>\n<\/div>\n

\u56db\u3001 JDK9 \u3001JDK10<\/h3>\n

\u4e0d\u662fLTS(\u957f\u671f\u652f\u6301)\u7248\u672c<\/p>\n

\u4e94\u3001 JDK11+<\/h3>\n

\u9ed8\u8ba4\u5f00\u542f\u4e86UseContainerSupport\uff0c\u652f\u6301\u5bb9\u5668\u5185\u90e8\u83b7\u53d6CPU\u548c\u5185\u5b58\u9650\u5236\u3002<\/p>\n

\n
-XX:UseContainerSupport<\/code><\/pre>\n<\/div>\n

\u5e76\u589e\u52a0\u4e86ActiveProcessorCount\u53c2\u6570\u6307\u5b9aCPU\u6570\u91cf<\/p>\n

\n
-XX:ActiveProcessorCount=count\r\n<\/code><\/pre>\n<\/div>\n

\u53c2\u8003\u8d44\u6599<\/h2>\n

https:\/\/www.jishuwen.com\/d\/2K0J#tuit<\/a>
\n
https:\/\/segmentfault.com\/a\/1190000013945253<\/a>
\n
https:\/\/royvanrijn.com\/blog\/2018\/05\/java-and-docker-memory-limits\/<\/a>
\n
https:\/\/bufferings.hatenablog.com\/entry\/2018\/11\/11\/114534<\/a>
\n
https:\/\/www.oracle.com\/technetwork\/java\/javase\/8u191-relnotes-5032181.html#JDK-8146115<\/a><\/p>\n

 <\/p>\n

<\/div>\n
<\/div>\n
\n
<\/div>\n
<\/div>\n
<\/div>\n
<\/div>\n
<\/div>\n<\/div>\n
\n
<\/div>\n
<\/div>\n
<\/div>\n
<\/div>\n
<\/div>\n<\/div>\n

 <\/p>\n

\u8f6c\u8f7d\u8bf7\u6ce8\u660e\uff1aIPCPU-\u7f51\u7edc\u4e4b\u8def<\/a> » Java in Docker and Kubernetes<\/a><\/p>","protected":false},"excerpt":{"rendered":"

\u8fd0\u884c\u5728Docker\u6216\u8005Kubernetes\u4e2d\u7684JAVA\u7a0b\u5e8f\u5982\u4f55\u6b63\u786e\u83b7\u53d6CPU\u548c\u5185\u5b58\u7684\u9650\u5236 \u96f6\u3001\u6982\u8ff0 Docker\u5bb9\u5668\u5229\u7528CGroup\u5bf9\u8fdb\u7a0b\u4f7f\u7528\u7684\u8d44\u6e90\u8fdb\u884c\u9650\u5236\uff0c\u800c\u5728\u5bb9\u5668\u4e2d\u7684JVM\u4f9d\u7136\u4f1a\u5229\u7528\u5bbf\u4e3b\u673a\u73af\u5883\u7684\u5185\u5b58\u5927\u5c0f\u548cCPU\u6838\u6570\u8fdb\u884c\u7f3a\u7701\u8bbe\u7f6e\uff0c\u8fd9\u5bfc\u81f4\u4e86JVM Heap\u7684\u9519\u8bef\u8ba1\u7b97\u3002JVM\u7f3a\u7701\u7684GC\u3001JIT\u7f16\u8bd1\u7ebf\u7a0b\u6570\u91cf\u53d6\u51b3\u4e8e\u5bbf\u4e3b\u673aCPU\u6838\u6570\u3002\u5982\u679c\u6211\u4eec\u5728\u4e00\u4e2a\u8282\u70b9\u4e0a\u8fd0\u884c\u591a\u4e2aJava\u5e94\u7528\uff0c\u5373\u4f7f\u6211\u4eec\u8bbe\u7f6e\u4e86CPU\u7684\u9650\u5236\uff0c\u5e94\u7528\u4e4b\u95f4\u4f9d\u7136\u6709\u53ef\u80fd\u56e0\u4e3aGC\u7ebf\u7a0b\u62a2\u5360\u5207\u6362\uff0c\u5bfc\u81f4\u5e94\u7528\u6027\u80fd\u53d7\u5230\u5f71\u54cd\u3002 \u90a3\u4e48\u6211\u4eec\u6765\u770b\u4e0b\u5404\u4e2a\u7248\u672cJDK\u5982\u4f55\u4f7f\u7528docker\u7684\u9650\u5236\u3002 \u4e00\u3001JDK\u8001\u7248\u672c 1\u3001\u4f7f\u7528\u73af\u5883\u53d8\u91cf\uff0c\u76f4\u63a5\u6307\u5b9aJVM\u5806\u5927\u5c0f -e JAVA_OPTIONS=’xMX300m’ 2\u3001\u660e\u786eGC\u548cJIT\u5e76\u884c\u7ebf\u7a0b\u6570\u76ee\uff0c\u4ee5\u907f\u514d\u4e8c\u8005\u5360\u7528\u8fc7\u591a\u8d44\u6e90\u3002 -XX:ParallelGCTreads -XX:CICompilerCount \u6ce8\u610fParallelGCThreads\u7684\u8ba1\u7b97\u65b9\u6cd5\uff1a ParallelGCThreads = (ncpus <= 8) ? ncpus : (8 + ((ncpus – 8) * 5) \/ 8); #cpu\u6838\u6570\u5c0f\u4e8e\u7b49\u4e8e8\uff0c\u53d6\u6838\u6570\uff1bcpu\u6838\u6570\u5927\u4e8e8\u6309\u540e\u9762\u516c\u5f0f\u8ba1\u7b97 \u4e8c\u3001 JDK 8u131+(backported) \u4f7f\u7528\u4ee5\u4e0bJVM\u53c2\u6570\uff0c\u9002\u914ddocker\u5bb9\u5668\u7684\u5185\u5b58\uff0cCPU\u53ef\u80fd\u65e0\u6cd5\u83b7\u53d6\u9650\u5236\uff0c\u9700\u8981\u624b\u52a8\u8bbe\u7f6e -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap \u4e09\u3001 JDK 8u191+(backported) \u9ed8\u8ba4\u5f00\u542f\u4e86UseContainerSupport\uff0c\u652f\u6301\u5bb9\u5668\u5185\u90e8\u83b7\u53d6CPU\u548c\u5185\u5b58\u9650\u5236\u3002 -XX:UseContainerSupport \u5e76\u589e\u52a0\u4e86ActiveProcessorCount\u53c2\u6570\u6307\u5b9aCPU\u6570\u91cf -XX:ActiveProcessorCount=count \u56db\u3001 JDK9 \u3001JDK10 \u4e0d\u662fLTS(\u957f\u671f\u652f\u6301)\u7248\u672c \u4e94\u3001 JDK11+ \u9ed8\u8ba4\u5f00\u542f\u4e86UseContainerSupport\uff0c\u652f\u6301\u5bb9\u5668\u5185\u90e8\u83b7\u53d6CPU\u548c\u5185\u5b58\u9650\u5236\u3002 -XX:UseContainerSupport \u5e76\u589e\u52a0\u4e86ActiveProcessorCount\u53c2\u6570\u6307\u5b9aCPU\u6570\u91cf -XX:ActiveProcessorCount=count \u53c2\u8003\u8d44\u6599 […]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[13],"tags":[68,196,129],"_links":{"self":[{"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/posts\/1228"}],"collection":[{"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/comments?post=1228"}],"version-history":[{"count":3,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/posts\/1228\/revisions"}],"predecessor-version":[{"id":1262,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/posts\/1228\/revisions\/1262"}],"wp:attachment":[{"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/media?parent=1228"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/categories?post=1228"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/c.ipcpu.com\/wp-json\/wp\/v2\/tags?post=1228"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}