• centos 7 无痛安装 es


    安装

    1、装依赖

     yum install -y java-1.8.0-openjdk

    2、安装elasticsearch

    下载url:https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.6.3.tar.gz

    • #目录创建    mkdir -p /opt/{soft,conf,logs,scripts};mkdir -p /data0/elasticsearch
    • #文件解压缩    tar xzvf  elasticsearch-5.6.3.tar.gz -C /opt/soft/
    • #建立软连接  ln -s /opt/soft/elasticsearch-5.6.3 /opt/soft/elasticsearch
    • #添加elastic 用户 adduser elastic -d /opt/soft/elasticsearch -s /sbin/nologin
    • #权限赋予   chown -R elastic.elastic /opt/soft/elasticsearch; chown -R elastic.elastic  /data0/elasticsearch

    3、配置文件修改

      3.1  系统配置文件:

          3.1.1 #vi  /etc/security/limits.conf

     #追加如下内容

    elastic soft memlock unlimited
    elastic hard memlock unlimited

    # End of file
    * soft nproc unlimited
    * hard nproc unlimited
    * soft nofile 655350
    * hard nofile 655350

         3.1.2 # vi /etc/sysctl.conf  

    #追加如下内容:

    vm.max_map_count=262144

        3.1.3 #编辑init 文件

    #  vi /etc/init.d/elasticsearch 

    #根据自身情况,修改如下内容

    #具体内容

    #!/bin/bash
    #
    # elasticsearch <summary>
    #
    # chkconfig:   2345 80 20
    # description: Starts and stops a single elasticsearch instance on this system
    #
    
    
    ### BEGIN INIT INFO
    # Provides: Elasticsearch
    # Required-Start: $network $named
    # Required-Stop: $network $named
    # Default-Start: 2 3 4 5
    # Default-Stop: 0 1 6
    # Short-Description: This service manages the elasticsearch daemon
    # Description: Elasticsearch is a very scalable, schema-free and high-performance search solution supporting multi-tenancy and near realtime search.
    ### END INIT INFO
    
    #
    # init.d / servicectl compatibility (openSUSE)
    #
    if [ -f /etc/rc.status ]; then
        . /etc/rc.status
        rc_reset
    fi
    
    #
    # Source function library.
    #
    if [ -f /etc/rc.d/init.d/functions ]; then
        . /etc/rc.d/init.d/functions
    fi
    
    # Sets the default values for elasticsearch variables used in this script
    ES_USER="elastic"
    ES_GROUP="elastic"
    ES_HOME="/opt/soft/elasticsearch"
    MAX_OPEN_FILES=65535
    MAX_MAP_COUNT=262144
    LOG_DIR="/opt/log/elasticsearch"
    DATA_DIR="/data0/elasticsearch"
    CONF_DIR="/opt/conf/elasticsearch/config"
    
    PID_DIR="/opt/conf/elasticsearch"
    
    # Source the default env file
    ES_ENV_FILE="/etc/sysconfig/elasticsearch"
    if [ -f "$ES_ENV_FILE" ]; then
        . "$ES_ENV_FILE"
    fi
    
    if [ "$ES_USER" != "elasticsearch" ] || [ "$ES_GROUP" != "elasticsearch" ]; then
        echo "WARNING: ES_USER and ES_GROUP are deprecated and will be removed in the next major version of Elasticsearch, got: [$ES_USER:$ES_GROUP]"
    fi
    
    # CONF_FILE setting was removed
    if [ ! -z "$CONF_FILE" ]; then
        echo "CONF_FILE setting is no longer supported. elasticsearch.yml must be placed in the config directory and cannot be renamed."
        exit 1
    fi
    
    exec="$ES_HOME/bin/elasticsearch"
    prog="elasticsearch"
    pidfile="$PID_DIR/${prog}.pid"
    
    export ES_JAVA_OPTS
    export JAVA_HOME
    export ES_INCLUDE
    export ES_JVM_OPTIONS
    export ES_STARTUP_SLEEP_TIME
    
    # export unsupported variables so bin/elasticsearch can reject them and inform the user these are unsupported
    if test -n "$ES_MIN_MEM"; then export ES_MIN_MEM; fi
    if test -n "$ES_MAX_MEM"; then export ES_MAX_MEM; fi
    if test -n "$ES_HEAP_SIZE"; then export ES_HEAP_SIZE; fi
    if test -n "$ES_HEAP_NEWSIZE"; then export ES_HEAP_NEWSIZE; fi
    if test -n "$ES_DIRECT_SIZE"; then export ES_DIRECT_SIZE; fi
    if test -n "$ES_USE_IPV4"; then export ES_USE_IPV4; fi
    if test -n "$ES_GC_OPTS"; then export ES_GC_OPTS; fi
    if test -n "$ES_GC_LOG_FILE"; then export ES_GC_LOG_FILE; fi
    
    lockfile=/var/lock/subsys/$prog
    
    # backwards compatibility for old config sysconfig files, pre 0.90.1
    if [ -n $USER ] && [ -z $ES_USER ] ; then
       ES_USER=$USER
    fi
    
    if [ ! -x "$exec" ]; then
        echo "The elasticsearch startup script does not exists or it is not executable, tried: $exec"
        exit 1
    fi
    
    checkJava() {
        if [ -x "$JAVA_HOME/bin/java" ]; then
            JAVA="$JAVA_HOME/bin/java"
        else
            JAVA=`which java`
        fi
    
        if [ ! -x "$JAVA" ]; then
            echo "Could not find any executable java binary. Please install java in your PATH or set JAVA_HOME"
            exit 1
        fi
    }
    
    start() {
        checkJava
        [ -x $exec ] || exit 5
    
        if [ -n "$MAX_OPEN_FILES" ]; then
            ulimit -n $MAX_OPEN_FILES
        fi
        if [ -n "$MAX_LOCKED_MEMORY" ]; then
            ulimit -l $MAX_LOCKED_MEMORY
        fi
        if [ -n "$MAX_MAP_COUNT" -a -f /proc/sys/vm/max_map_count ]; then
            sysctl -q -w vm.max_map_count=$MAX_MAP_COUNT
        fi
    
        # Ensure that the PID_DIR exists (it is cleaned at OS startup time)
        if [ -n "$PID_DIR" ] && [ ! -e "$PID_DIR" ]; then
            mkdir -p "$PID_DIR" && chown "$ES_USER":"$ES_GROUP" "$PID_DIR"
        fi
        if [ -n "$pidfile" ] && [ ! -e "$pidfile" ]; then
            touch "$pidfile" && chown "$ES_USER":"$ES_GROUP" "$pidfile"
        fi
    
        cd $ES_HOME
        echo -n $"Starting $prog: "
        # if not running, start it up here, usually something like "daemon $exec"
        daemon --user $ES_USER --pidfile $pidfile $exec -p $pidfile -d -Edefault.path.logs=$LOG_DIR -Edefault.path.data=$DATA_DIR -Edefault.path.conf=$CONF_DIR
        retval=$?
        echo
        [ $retval -eq 0 ] && touch $lockfile
        return $retval
    }
    
    stop() {
        echo -n $"Stopping $prog: "
        # stop it here, often "killproc $prog"
        killproc -p $pidfile -d 86400 $prog
        retval=$?
        echo
        [ $retval -eq 0 ] && rm -f $lockfile
        return $retval
    }
    
    restart() {
        stop
        start
    }
    
    reload() {
        restart
    }
    
    force_reload() {
        restart
    }
    
    rh_status() {
        # run checks to determine if the service is running or use generic status
        status -p $pidfile $prog
    }
    
    rh_status_q() {
        rh_status >/dev/null 2>&1
    }
    
    
    case "$1" in
        start)
            rh_status_q && exit 0
            $1
            ;;
        stop)
            rh_status_q || exit 0
            $1
            ;;
        restart)
            $1
            ;;
        reload)
            rh_status_q || exit 7
            $1
            ;;
        force-reload)
            force_reload
            ;;
        status)
            rh_status
            ;;
        condrestart|try-restart)
            rh_status_q || exit 0
            restart
            ;;
        *)
            echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
            exit 2
    esac
    exit $?
    

         3.1.4 #编辑hosts文件添加如下内容

    echo "::1     localhost       localhost.localdomain   localhost6      localhost6.localdomain6
    127.0.0.1       localhost       localhost.localdomain   localhost4      localhost4.localdomain4
    127.0.0.1       es01    es01
    192.168.0.2 es2.hq
    192.168.0.3 es3.hq
    192.168.0.4 es4.hq" > /etc/hosts

       3.2 elasticsearch 相关配置文件修改

        3.2.1  #vi  /opt/conf/elasticsearch/config/elasticsearch.yml

    cluster.name: HQES
    node.name: es8.hq
    node.master: true
    node.data: true
    path.data: /data0/elasticsearch
    path.logs: /opt/log/elasticsearch/
    bootstrap.memory_lock: true
    network.publish_host: es8.hq         #根据/etc/hosts内容在不同主机中修改
    network.bind_host: 0.0.0.0
    discovery.zen.minimum_master_nodes: 3
    discovery.zen.ping.unicast.hosts: ["es8.hq", "es9.hq", "es10.hq", "es11.hq","es12.hq"]   #/etc/hosts内容修改
    discovery.zen.fd.ping_timeout: 120s
    discovery.zen.fd.ping_retries: 6
    discovery.zen.fd.ping_interval: 30s
    client.transport.ping_timeout: 60s
    discovery.zen.ping_timeout: 120s
    #xpack.security.enabled: false
    #http.cors.allow-origin: "/.*/"
    http.cors.allow-origin: "*"
    http.cors.enabled: true

    gateway.recover_after_nodes: 2
    gateway.recover_after_time: 5m
    gateway.expected_nodes: 2

    cluster.routing.allocation.node_initial_primaries_recoveries: 6
    cluster.routing.allocation.node_concurrent_recoveries: 3
    indices.recovery.max_bytes_per_sec: 50mb

        3.2.2  #vi /opt/soft/elasticsearch/bin/elasticsearch

    #查找ES_JAVA_OPTS修改如下:

    ES_JAVA_OPTS="-Xms8g -Xmx8g -Dlog4j2.disable.jmx=true"

     3.2.3 #vi /opt/conf/elasticsearch/config/log4j2.properties

    status = error
    
    # log action execution errors for easier debugging
    logger.action.name = org.elasticsearch.action
    logger.action.level = debug
    
    appender.console.type = Console
    appender.console.name = console
    appender.console.layout.type = PatternLayout
    appender.console.layout.pattern = [%d{ISO8601}][%-5p][%-25c{1.}] %marker%m%n
    
    appender.rolling.type = RollingFile
    appender.rolling.name = rolling
    appender.rolling.fileName = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}.log
    appender.rolling.layout.type = PatternLayout
    appender.rolling.layout.pattern = [%d{ISO8601}][%-5p][%-25c{1.}] %marker%.-10000m%n
    appender.rolling.filePattern = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}-%d{yyyy-MM-dd}-%i.log.gz
    appender.rolling.policies.type = Policies
    appender.rolling.policies.time.type = TimeBasedTriggeringPolicy
    appender.rolling.policies.time.interval = 1
    appender.rolling.policies.time.modulate = true
    appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
    appender.rolling.policies.size.size = 128MB
    appender.rolling.strategy.type = DefaultRolloverStrategy
    appender.rolling.strategy.fileIndex = nomax
    appender.rolling.strategy.action.type = Delete
    appender.rolling.strategy.action.basepath = ${sys:es.logs.base_path}
    appender.rolling.strategy.action.condition.type = IfFileName
    appender.rolling.strategy.action.condition.glob = ${sys:es.logs.cluster_name}-*
    appender.rolling.strategy.action.condition.nested_condition.type = IfAccumulatedFileSize
    appender.rolling.strategy.action.condition.nested_condition.exceeds = 2GB
    
    rootLogger.level = info
    rootLogger.appenderRef.console.ref = console
    rootLogger.appenderRef.rolling.ref = rolling
    
    appender.deprecation_rolling.type = RollingFile
    appender.deprecation_rolling.name = deprecation_rolling
    appender.deprecation_rolling.fileName = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_deprecation.log
    appender.deprecation_rolling.layout.type = PatternLayout
    appender.deprecation_rolling.layout.pattern = [%d{ISO8601}][%-5p][%-25c{1.}] %marker%.-10000m%n
    appender.deprecation_rolling.filePattern = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_deprecation-%i.log.gz
    appender.deprecation_rolling.policies.type = Policies
    appender.deprecation_rolling.policies.size.type = SizeBasedTriggeringPolicy
    appender.deprecation_rolling.policies.size.size = 1GB
    appender.deprecation_rolling.strategy.type = DefaultRolloverStrategy
    appender.deprecation_rolling.strategy.max = 4
    
    logger.deprecation.name = org.elasticsearch.deprecation
    logger.deprecation.level = warn
    logger.deprecation.appenderRef.deprecation_rolling.ref = deprecation_rolling
    logger.deprecation.additivity = false
    
    appender.index_search_slowlog_rolling.type = RollingFile
    appender.index_search_slowlog_rolling.name = index_search_slowlog_rolling
    appender.index_search_slowlog_rolling.fileName = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_index_search_slowlog.log
    appender.index_search_slowlog_rolling.layout.type = PatternLayout
    appender.index_search_slowlog_rolling.layout.pattern = [%d{ISO8601}][%-5p][%-25c] %marker%.-10000m%n
    appender.index_search_slowlog_rolling.filePattern = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_index_search_slowlog-%d{yyyy-MM-dd}.log
    appender.index_search_slowlog_rolling.policies.type = Policies
    appender.index_search_slowlog_rolling.policies.time.type = TimeBasedTriggeringPolicy
    appender.index_search_slowlog_rolling.policies.time.interval = 1
    appender.index_search_slowlog_rolling.policies.time.modulate = true
    
    logger.index_search_slowlog_rolling.name = index.search.slowlog
    logger.index_search_slowlog_rolling.level = trace
    logger.index_search_slowlog_rolling.appenderRef.index_search_slowlog_rolling.ref = index_search_slowlog_rolling
    logger.index_search_slowlog_rolling.additivity = false
    
    appender.index_indexing_slowlog_rolling.type = RollingFile
    appender.index_indexing_slowlog_rolling.name = index_indexing_slowlog_rolling
    appender.index_indexing_slowlog_rolling.fileName = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_index_indexing_slowlog.log
    appender.index_indexing_slowlog_rolling.layout.type = PatternLayout
    appender.index_indexing_slowlog_rolling.layout.pattern = [%d{ISO8601}][%-5p][%-25c] %marker%.-10000m%n
    appender.index_indexing_slowlog_rolling.filePattern = ${sys:es.logs.base_path}${sys:file.separator}${sys:es.logs.cluster_name}_index_indexing_slowlog-%d{yyyy-MM-dd}.log
    appender.index_indexing_slowlog_rolling.policies.type = Policies
    appender.index_indexing_slowlog_rolling.policies.time.type = TimeBasedTriggeringPolicy
    appender.index_indexing_slowlog_rolling.policies.time.interval = 1
    appender.index_indexing_slowlog_rolling.policies.time.modulate = true
    
    logger.index_indexing_slowlog.name = index.indexing.slowlog.index
    logger.index_indexing_slowlog.level = trace
    logger.index_indexing_slowlog.appenderRef.index_indexing_slowlog_rolling.ref = index_indexing_slowlog_rolling
    logger.index_indexing_slowlog.additivity = false
    

    3.2.4: mkdir -p /opt/log/elasticsearch

    chchown -R elastic.elastic /opt/log/elasticsearch

    4、#启动:

      service elasticsearch start 


    万水千山总是情, 领个红包行不行?

    觉得还可以的话记的打赏哦^.^..
  • 相关阅读:
    关于本人对javascript闭包的理解
    关于闭包内存泄露的处理方法
    javascript超时调用、间歇调用
    浏览器加载和渲染html的顺序
    CSS hack
    JS在操作IE与FF的一些区别
    javascript对select option操作
    jsp端使用ApplicationContext
    人生的35个经典好习惯
    2008个人总结
  • 原文地址:https://www.cnblogs.com/mafeng/p/15069970.html
Copyright © 2020-2023  润新知