Ошибка Elasticsearch: не удалось подключиться к локальному порту 9200: отказано в подключении - PullRequest
2 голосов
/ 07 марта 2019

Я пытаюсь создать образ Docker с установленным Elasticsearch. Я знаю, что Elasticsearch уже имеет свой собственный образ Docker, но мне нужно использовать ту же среду AWS Lambda Function с установленным Python 3.6.5. Поэтому мне пришлось расширить образ AWS Docker, и мне пришлось установить службу Elasticsearch.

Здесь вы можете найти мой Dockerfile:

FROM lambci/lambda-base:build

ENV PATH=/var/lang/bin:$PATH \
    LD_LIBRARY_PATH=/var/lang/lib:$LD_LIBRARY_PATH \
    AWS_EXECUTION_ENV=AWS_Lambda_python3.6 \
    PYTHONPATH=/var/runtime \
    PKG_CONFIG_PATH=/var/lang/lib/pkgconfig:/usr/lib64/pkgconfig:/usr/share/pkgconfig

RUN rm -rf /var/runtime /var/lang && \
  curl https://lambci.s3.amazonaws.com/fs/python3.6.tgz | tar -xz -C / && \
  sed -i '/^prefix=/c\prefix=/var/lang' /var/lang/lib/pkgconfig/python-3.6.pc && \
  curl https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tar.xz | tar -xJ && \
  cd Python-3.6.8 && \
  LIBS="$LIBS -lutil -lrt" ./configure --prefix=/var/lang && \
  make -j$(getconf _NPROCESSORS_ONLN) libinstall libainstall inclinstall && \
  cd .. && \
  rm -rf Python-3.6.8

EXPOSE 9200 9300

# Add these as a separate layer as they get updated frequently
RUN pip install -U pip setuptools --no-cache-dir && \
    pip install -U virtualenv pipenv --no-cache-dir && \
    pip install -U awscli boto3 aws-sam-cli==0.10.0 aws-lambda-builders==0.1.0 --no-cache-dir && \
    yum install wget -y && \
    echo "vm.max_map_count=262144" >> /etc/sysctl.conf && \
    # I try to install elasticsearch manually
    wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.6.1.rpm && \
    rpm --install elasticsearch-6.6.1.rpm && \
    service elasticsearch start && \
    chkconfig --add elasticsearch && \
    sed -i -e "s/#network.host: 192.168.0.1/network.host: 127.0.0.1/g" /etc/elasticsearch/elasticsearch.yml && \
    sed -i -e "s/#http.port: 9200/http.port: 9200/g" /etc/elasticsearch/elasticsearch.yml && \
    sed -i -e "s/# Elasticsearch performs poorly when the system is swapping the memory./network.bind_host: 127.0.0.1\nnetwork.publish_host: localhost/g" /etc/elasticsearch/elasticsearch.yml

RUN service elasticsearch start && \
    service elasticsearch status && \
    service elasticsearch status

Когда я собираю образ, образ строится правильно, и служба эластичного поиска работает. Я вижу журнал: elasticsearch (pid 87) is running.... Проблема в том, что я не могу сделать вызов API на http://localhost:9200, потому что он говорит: Failed to connect to localhost port 9200: Connection refused

Мне нужно воспользоваться службой эластичного поиска внутри контейнера, а не снаружи. Что я делаю не так?

Ответы [ 2 ]

0 голосов
/ 14 мая 2019

Что вы хотите сделать, это использовать внутренний IP-адрес вашего приложения. Вот как вы это получаете

dokku elasticsearch:info <Your elasticsearch container name here>

Тогда теперь вы можете сделать

curl http://172.75.0.7:9200

Предполагая, что ваш внутренний IP-адрес 172.75.0.7

0 голосов
/ 07 марта 2019

Вы не указываете, как вы на самом деле запускаете Docker-контейнер.Просто разоблачить порт в файле Docker недостаточно.Вы также должны работать с опцией -p.Например:

docker run -p 9200:9200 <image name here>

Подробнее см. https://docs.docker.com/engine/reference/commandline/run/.

...