elasticsearch-5.0.0和vagrant

时间:2016-11-04 09:31:04

标签: elasticsearch vagrant elasticsearch-5

我在Vagrant中有弹性搜索安装的代码,我想在vagrant up之后运行elasticsearch,但是我得到的错误如下所示

  

当vagrant运行elasticsearch-5.0.0

时,我得到错误
default: max file descriptors [4096] for elasticsearch process likely too low, increase to at least [65536]
  

安装弹性的install.sh文件

# ELASTICSEARCH

# install openjdk-8
apt-get purge openjdk*
add-apt-repository ppa:webupd8team/java -y
apt-get update -y
echo "oracle-java8-installer shared/accepted-oracle-license-v1-1 select true" | sudo debconf-set-selections
apt-get install oracle-java8-installer -y

# install ES
curl -L -O https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-5.0.0.tar.gz

tar -xvf elasticsearch-5.0.0.tar.gz

sudo sysctl -w vm.max_map_count=262144
echo "vagrant soft     nofile         65536" | sudo tee --append /etc/security/limits.conf
echo "vagrant hard     nofile         65536" | sudo tee --append /etc/security/limits.conf
echo "session required pam_limits.so" | sudo tee --append /etc/pam.d/common-session
sudo -H -u vagrant bash -c 'ulimit -n'

# either of the next two lines is needed to be able to access "localhost:9200" from the host os
echo "network.bind_host: 0" >> elasticsearch-5.0.0/config/elasticsearch.yml
echo "network.host: 0.0.0.0" >> elasticsearch-5.0.0/config/elasticsearch.yml
# enable dynamic scripting
echo "script.inline: on" >> elasticsearch-5.0.0/config/elasticsearch.yml
# enable cors (to be able to use Sense)
echo "http.cors.enabled: true" >> elasticsearch-5.0.0/config/elasticsearch.yml
echo "http.cors.allow-origin: /https?:\/\/.*/" >> elasticsearch-5.0.0/config/elasticsearch.yml

sudo chown -R vagrant:vagrant elasticsearch-5.0.0
  

startup.sh,vagrant provisioner运行:“always”

# elasticsearch settings and run
sudo sysctl -w vm.max_mapy_count=262144
su vagrant --shell /bin/bash --command "ulimit -n 65536"
sudo -H -u vagrant bash -c 'elasticsearch-5.0.0/bin/elasticsearch'

1 个答案:

答案 0 :(得分:1)

我很快尝试使用ubuntu16.04框,但没有遇到这个问题。

我改变了你的启动脚本,因为有vm.max_mapy_count

的拼写错误 来自Vagrantfile的

config.vm.provision :shell, :path => "startup.sh", :run => 'always', :privileged => false

startup.sh

# elasticsearch settings and run
sudo sysctl -w vm.max_map_count=262144
ulimit -n 65536
nohup elasticsearch-5.0.0/bin/elasticsearch &> /home/vagrant/nohup.es.out&

Elasticsearch正确启动,输出在nohup文件中捕获。