ubuntu14.04安裝Elasticsearch

(原文: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

e1.png

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

e2.png

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

e3.png

如無意外應該可以安裝成功。

接下來就是運行了,這是關(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 ...

見圖:

e4.png

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

這個時候就可以起來了,來看看效果:

e5.png

在瀏覽器查看:

e6.png

到這里為止,ubuntu安裝elasticsearch就完成了,接下來怎么玩耍就看各位看官的心情啦!

文章錯漏之處或有其他建議歡迎評論交流,大家共同進步,謝謝!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容