(原文:http://codejust.top/ubuntu14-04-install-elasticsearch.html)
最近想要為自己寫的一個小型服務端搭建個日志管理,服務端使用的是OpenResty框架構(gòu)建的,主要用來學習和練手(有興趣的可以看看,適合入門看:https://github.com/huchangwei/orskycloud-openresty.)
做的比較簡單,日志管理主要是為了方便查看error日志,ELK是個非常不錯的工具,擴展性非常的強,雖然我沒有什么實踐經(jīng)驗,當然我的服務端其實也沒必要用elk,只不過為了體驗體驗,所以就大材小用了一把。
ubuntu安裝ELK網(wǎng)上有很多相關(guān)的博客,我這里就不在重復寫了,我這里主要記錄下安裝過程中出現(xiàn)的一些問題,這篇文章記錄的是ubuntu14.04安裝elasticsearch。
ubuntu安裝elasticsearch也有很多種方法,這里主要介紹我安裝成功的,其他方法或許更簡潔,但是若是讀者安裝也是跟我一樣的或許會遇到同樣的錯誤,這篇文章也許能給你提供些參考。
首先,我們從官網(wǎng)下載deb包:
(官網(wǎng):https://www.elastic.co/downloads/elasticsearch)

直接使用瀏覽器下載可能會很慢,我一般會copy下載鏈接,然后wget下來:

然后使用dpkg命令安裝(注意:安裝之前確保ubuntu已經(jīng)安裝好了java環(huán)境,否則會報錯):

如無意外應該可以安裝成功。
接下來就是運行了,這是關(guān)鍵所在,首先我們前往安裝目錄elasticsearch的安裝目錄,一般會在:
cd /usr/share/elasticsearch
這個時候如果你直接運行elasticsearch會報以下錯誤:
執(zhí)行: bin/elasticsearch
錯誤信息:
Exception in thread "main" org.elasticsearch.bootstrap.BootstrapException: java.nio.file.NoSuchFileException: /usr/share/elasticsearch/config
Likely root cause: java.nio.file.NoSuchFileException: /usr/share/elasticsearch/config ...
見圖:

elasticsearch github上有這個錯誤的issue(https://github.com/elastic/ansible-elasticsearch/issues/58)
感興趣的可以看看這個錯誤的具體原因,我這里主要提供解決方法。
這個錯誤我覺得主要是因為找不到配置文件,deb包安裝好之后配置文件默認在: /etc/elasticsearch
,但是如果你直接在安裝目錄里去啟動elasticsearch的話,elasticsearch是不會去/etc找配置文件的,elasticsearch只會在當前目錄找config文件夾,如果安裝成service的形式應該是可以找到配置文件,但我沒去嘗試,后面試試。
問題知道了,我們可以直接把/etc目錄下的elasticsearch配置文件copy過來:
cp -r /etc/elasticsearch /usr/share/elasticsearch/config
這個時候我們再啟動就不會報剛才的錯誤了,我們再試一遍:
bin/elasticsearch
意料之中,這時候會提示以下錯誤:
[2017-01-17T21:54:48,798][WARN ][o.e.b.ElasticsearchUncaughtExceptionHandler] [] uncaught exception in thread [main]
org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException: can not run elasticsearch as root
at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:125) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Elasticsearch.execute(Elasticsearch.java:112) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.cli.SettingCommand.execute(SettingCommand.java:54) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.cli.Command.mainWithoutErrorHandling(Command.java:122) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.cli.Command.main(Command.java:88) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:89) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:82) ~[elasticsearch-5.1.2.jar:5.1.2]
Caused by: java.lang.RuntimeException: can not run elasticsearch as root
at org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.java:100) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:176) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:306) ~[elasticsearch-5.1.2.jar:5.1.2]
at org.elasticsearch.bootstrap.Elasticsearch.init(Elasticsearch.java:121) ~[elasticsearch-5.1.2.jar:5.1.2]
... 6 more
這個錯誤的原因是elasticsearch不允許使用root啟動,因此我們要解決這個問題需要新建一個用戶來啟動elasticsearch(參考:https://my.oschina.net/topeagle/blog/591451?fromerr=mzOr2qzZ)
具體操作如下:
? ~ groupadd elsearch
? ~ useradd elsearch -g elsearch -p elsearch
? ~ cd /usr/share
? chown -R elsearch:elsearch elasticsearch
? su elsearch
這個時候在這個用戶去啟動elasticsearch,一般情況下這個時候就能成功起來了,可能還會出現(xiàn)一些錯誤,如:
hcw-X450VC% ./elasticsearch
2017-01-17 21:03:31,158 main ERROR Could not register mbeans java.security.AccessControlException: access denied ("javax.management.MBeanTrustPermission" "register")
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:472)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:585)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.checkMBeanTrustPermission(DefaultMBeanServerInterceptor.java:1848)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:322)
at com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:522)
at org.apache.logging.log4j.core.jmx.Server.register(Server.java:389)
at org.apache.logging.log4j.core.jmx.Server.reregisterMBeansAfterReconfigure(Server.java:167)
at org.apache.logging.log4j.core.jmx.Server.reregisterMBeansAfterReconfigure(Server.java:140)
at org.apache.logging.log4j.core.LoggerContext.setConfiguration(LoggerContext.java:541)
at org.apache.logging.log4j.core.LoggerContext.start(LoggerContext.java:258)
at org.apache.logging.log4j.core.impl.Log4jContextFactory.getContext(Log4jContextFactory.java:206)
at org.apache.logging.log4j.core.config.Configurator.initialize(Configurator.java:220)
at org.apache.logging.log4j.core.config.Configurator.initialize(Configurator.java:197)
at org.elasticsearch.common.logging.LogConfigurator.configureStatusLogger(LogConfigurator.java:125)
at org.elasticsearch.common.logging.LogConfigurator.configureWithoutConfig(LogConfigurator.java:67)
at org.elasticsearch.cli.Command.main(Command.java:85)
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:89)
at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:82)
這是因為elasticsearch需要讀寫配置文件,我們需要給予config文件夾權(quán)限,上面新建了elsearch用戶,elsearch用戶不具備讀寫權(quán)限,因此還是會報錯,解決方法是切換到管理員賬戶,賦予權(quán)限即可:
sudo -i
chmod -R 775 config
這個時候就可以起來了,來看看效果:

在瀏覽器查看:

到這里為止,ubuntu安裝elasticsearch就完成了,接下來怎么玩耍就看各位看官的心情啦!
文章錯漏之處或有其他建議歡迎評論交流,大家共同進步,謝謝!