從docker hub下載了一個es的鏡像,版本為6.4.2,詳細信息如下:
![](/d/20211016/d44362d71ec78ce3e4dbd43bf41a53c3.gif)
比較重要的就是這兩條,第一個是工作目錄,掛載目錄也需要和這里對應;第二個是啟動命令,這里是指定了一個預先寫好的啟動腳本。所以我啟動了一個空容器去查看了下容器內(nèi)的情況:
![](/d/20211016/1cb1a9bb8fe2f67c097f3fc2b296818d.gif)
容器內(nèi)部目錄結(jié)構(gòu)如上圖,data是用來存放數(shù)據(jù),logs用來存放日志。
接著查看下啟動腳本
/usr/local/bin/docker-entrypoint.sh
![](/d/20211016/f7819e2003c13dfc8c6e9c53103055f7.gif)
前半部分我也是看的一知半解,不過真正和掛載目錄相關(guān)的是最后這部分,這里處理了掛載目錄后的操作,大致意思是:
如果是root用戶(docker啟動容器,默認是以root用戶身份),并且 TAKE_FILE_OWNERSHIP 變量存在,則將/usr/share/elasticsearch/{data,logs},這兩個目錄都改變?yōu)?000用戶所屬(這里也可以看到最終存儲數(shù)據(jù)的路徑為data,所以掛載時應該掛載到data下)。
id為1000的用戶:
![](/d/20211016/caf20dc8b1e027427edac1f4e6c84a47.gif)
正是elasticsearch用戶,所以如果不掛載任何目錄直接啟動容器即可,如果掛載,那么就添加一個變量,任意賦值,es可以正常啟動。
docker run -itd -v /root/es-data/:/usr/share/elasticsearch/data -e TAKE_FILE_OWNERSHIP=111 -p 9200:9200 --name es elasticsearch:6.4.2
補充知識:記一次docker安裝elasticsearch及遇到的坑
先給一行命令
docker run -d -p 9200:9200 -p 9300:9300 -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" --name=<your es name> elasticsearch:<es version>
使用該命令可直接安裝并運行es的docker 鏡像容器
問題
使用命令docker run -d -p 9200:9200 -p 9300:9300 --name=<your es name> elasticsearch:<es version>啟動, 然后想看是否啟動起來了,于是使用docker ps命令發(fā)現(xiàn):
![](/d/20211016/e5eb8d1e7bd3b1c1d916a5f5485df573.gif)
es并未啟動起來。
于是又用docker ps -a命令:
![](/d/20211016/6169d58b2884b56f2333009c69e171cf.gif)
發(fā)現(xiàn)啟動終止了。
然后用docker logs -f <container id>命令查看es的啟動日志:
![](/d/20211016/fdec5d732995ad76b7d5caca14240b2d.gif)
拉到最下面:
![](/d/20211016/c829f30651db386ec6922b5a72fdc163.gif)
長這樣:
power management:
Memory: 4k page, physical 1882892k(89076k free), swap 0k(0k free)
vm_info: OpenJDK 64-Bit Server VM (25.181-b13) for linux-amd64 JRE (1.8.0_181-8u181-b13-2~deb9u1-b13), built on Oct 22 2018 18:05:23 by "pbuilder" with gcc 6.3.0 20170516
time: Fri Nov 23 07:00:34 2018
elapsed time: 0 seconds (0d 0h 0m 0s)
于是復制報錯信息Google一波,發(fā)現(xiàn)問題所在。elasticsearch5.+配置默認的內(nèi)存是2g。我給docker的內(nèi)存也只有2g,于是就GG了。
刪除了舊容器,和舊鏡像后,在docker啟動命令中加上-e "ES_JAVA_OPTS=-Xms512m -Xmx512m"解決問題
![](/d/20211016/bcc909b177d30394bd553dff178a74f8.gif)
docker ps :
![](/d/20211016/b199d62ea2668bc86830353463541de0.gif)
最后訪問一波9200端口:
![](/d/20211016/1da6f24a0a8c771f0cb43305de3d869e.gif)
OJBK
以上這篇docker 啟動elasticsearch鏡像,掛載目錄后報錯的解決就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。