k8s部署elasticsearch提示OOMkilled

因電腦內存只有16G,部署的虛擬機內存不夠,致使k8s的elasticsearch集羣提示OOMKilled。因爲ES是運行在JVM上,JVM自己除了分配的heap內存之外,還會用到一些堆外(off heap)內存。 在小內存的機器上跑ES,若是heap劃分過多,累加上堆外內存後,總的JVM使用內存量可能超過物理內存限制。 若是swap又是關閉的狀況下,就會被操做系統oom killer殺掉。

[root@master1 default]# kubectl -n component get pod 
NAME                READY   STATUS      RESTARTS   AGE
es-data-default-0   0/1     OOMKilled   1          58s
es-data-default-1   0/1     OOMKilled   1          58s
es-data-default-2   0/1     OOMKilled   1          58s

能夠修改elasticsearch的配置文件/elasticsearch/config/jvm.option解決

vim es-config-jv.yaml        #建立configmap的yaml文件
apiVersion: v1
kind: ConfigMap
metadata:
  name: elasticsearch-config-jv
  namespace: component
data:
  jvm.options: |
    ## 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:
    ###
    -Xms512m                             #原爲### -Xms4g,去掉#號,修改成512m
    -Xmx512m                               #原爲### -Xmx4g,去掉#號,修改成512m
    ###
    ### 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
    #
    ## Commented out since these are supplied as env vars in the command-line
    ## for the service.
    #
    -Xms512m
    -Xmx512m
    #
    #################################################################
    ### Expert settings
    #################################################################
    ###
    ### All settings below this section are considered
    ### expert settings. Don't tamper with them unless
    ### you understand what you are doing
    ###
    #################################################################
    #
    ### GC configuration
    #-XX:+UseConcMarkSweepGC
    #-XX:CMSInitiatingOccupancyFraction=75
    #-XX:+UseCMSInitiatingOccupancyOnly
    #
    ### optimizations
    #
    ## disable calls to System#gc
    #-XX:+DisableExplicitGC
    #
    ## pre-touch memory pages used by the JVM during initialization
    #-XX:+AlwaysPreTouch
    #
    ### basic
    #
    ## force the server VM (remove on 32-bit client JVMs)
    #-server
    #
    ## explicitly set the stack size (reduce to 320k on 32-bit client JVMs)
    #-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
    #
    ## use old-style file permissions on JDK9
    #-Djdk.io.permissionsUseCanonicalPath=true
    #
    ## flags to keep Netty from being unsafe
    #-Dio.netty.noUnsafe=true
    #-Dio.netty.noKeySetOptimization=true
    #
    ## log4j 2
    #-Dlog4j.shutdownHookEnabled=false
    #-Dlog4j2.disable.jmx=true
    #-Dlog4j.skipJansi=true
    #
    ### 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=${heap.dump.path}
    #
    ### GC logging
    #
    ##-XX:+PrintGCDetails
    ##-XX:+PrintGCTimeStamps
    ##-XX:+PrintGCDateStamps
    ##-XX:+PrintClassHistogram
    ##-XX:+PrintTenuringDistribution
    ##-XX:+PrintGCApplicationStoppedTime
    #
    ## log GC status to a file with time stamps
    ## ensure the directory exists
    ##-Xloggc:${loggc}
    #
    ## Elasticsearch 5.0.0 will throw an exception on unquoted field names in JSON.
    ## If documents were already indexed with unquoted fields in a previous version
    ## of Elasticsearch, some operations may throw errors.
    ##
    ## WARNING: This option will be removed in Elasticsearch 6.0.0 and is provided
    ## only for migration purposes.
    ##-Delasticsearch.json.allow_unquoted_field_names=true

修改statefulset的配置,增長configmap的文件掛載

- name: elasticsearch-config-jv
          mountPath: /elasticsearch/config/jvm.options
          subPath: jvm.options
      volumes:
      - name: elasticsearch-config-jv
        configMap:
          name: elasticsearch-config-jv
sysctl -w vm.max_map_count=262144       #es須要vm.max_map_count爲262144
sysctl -a|grep vm.max_map_count
vim /etc/sysctl.conf              #文件最後添加一行,持久配置

vm.max_map_count=262144
kubectl -n component get pod         #已經開啓正常了
NAME                READY   STATUS    RESTARTS   AGE
es-data-default-0   1/1     Running   0          10m
es-data-default-1   1/1     Running   0          10m
es-data-default-2   1/1     Running   0          10m
相關文章
相關標籤/搜索