国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

解決Docker Machine中的容器文件不能持久的問題

Amio / 3303人閱讀

摘要:解決中的容器文件不能持久的問題目前下使用的主流方式還是使用需要借用虛擬器啟動一個宿主機才能在上面啟動多個容器當我們在容器中運行服務時經常會有需要將服務數據持久化的場景比如運行集群時需要將索引數據持久保存到磁盤那具體保存到哪里呢容器的無狀態特

解決Docker Machine中的容器文件不能持久的問題

目前Mac下使用docker的主流方式還是使用Docker machine.
Docker machine需要借用Virtual Box虛擬器啟動一個Linux宿主機, 才能在上面啟動多個Docker容器.

當我們在docker容器中運行服務時,經常會有需要將服務數據持久化的場景.比如運行Elasticsearch集群時, 需要將索引數據持久保存到磁盤.

那具體保存到哪里呢?容器的無狀態特性決定了我們不應該將數據保存在容器中, 因為容器一旦重啟, 文件數據就會丟失.一般應該使用volume參數,通過掛載外部文件系統到Docker容器中來保存數據.

當我在Mac下使用Docker開發時, 遇到這種場景, 自然就想到了將服務數據保存到Linux宿主機上. 結果很不辛, 使用Docker Machine創建的Linux宿主機的文件系統幾乎也是不能持久的, Linux重啟后, 之前寫入的文件都會丟失.

不過好在使用Docker Machine創建的Linux宿主機上面,自動掛載了Mac上的用戶目錄到Linux宿主機上. 如下:

Linux: /Users   --->   Mac  : /Users

我們掛載文件系統時, 將應用的數據保存到/Users不久可以了嗎?

然而現實還是那么殘酷. 當我使用按照這個方式啟動Elasticsearch時:

docker run -v "/Users/isaac/work/data":/usr/share/elasticsearch/data elasticsearch:2.3.3

卻得到了以下錯誤:

Exception in thread "main" java.lang.IllegalStateException: Unable to access "path.data" (/usr/share/elasticsearch/data/elasticsearch)
Likely root cause: java.nio.file.AccessDeniedException: /usr/share/elasticsearch/data/elasticsearch
    at sun.nio.fs.UnixException.translateToIOException(UnixException.java:84)
    at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:102)
    at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:107)
    at sun.nio.fs.UnixFileSystemProvider.createDirectory(UnixFileSystemProvider.java:384)
    at java.nio.file.Files.createDirectory(Files.java:674)
    at java.nio.file.Files.createAndCheckIsDirectory(Files.java:781)
    at java.nio.file.Files.createDirectories(Files.java:767)
    at org.elasticsearch.bootstrap.Security.ensureDirectoryExists(Security.java:337)
    at org.elasticsearch.bootstrap.Security.addPath(Security.java:314)
    at org.elasticsearch.bootstrap.Security.addFilePermissions(Security.java:259)
    at org.elasticsearch.bootstrap.Security.createPermissions(Security.java:212)
    at org.elasticsearch.bootstrap.Security.configure(Security.java:118)
    at org.elasticsearch.bootstrap.Bootstrap.setupSecurity(Bootstrap.java:196)
    at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:167)
    at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:270)
    at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:35)

經過分析, 文件操作失敗是因為用戶權限的問題.
查看Linux宿主機的用戶信息:

docker-machine ssh default
cat /etc/passwd

得到以下內容:

root:x:0:0:root:/root:/bin/sh
lp:x:7:7:lp:/var/spool/lpd:/bin/sh
nobody:x:65534:65534:nobody:/nonexistent:/bin/false
tc:x:1001:50:Linux User,,,:/home/tc:/bin/sh
docker:x:1000:50:Linux User,,,:/home/docker:/bin/sh

所以通過指定啟動Docker容器的用戶, 可以解決此問題:

docker run -u 1000 -v "/Users/isaac/work/data":/usr/share/elasticsearch/data elasticsearch:2.3.3 

其中:-u 1000 代表使用id為1000的docker用戶來啟動應用

在docker-compose.yml中指定啟動用戶為docker用戶:

elasticsearch1:
    image: elasticsearch:2.3.3
    command: "elasticsearch -Des.cluster.name=elasticsearch -Des.discovery.zen.ping.unicast.hosts=elasticsearch_master"
    links:
      - elasticsearch_master
    volumes:
      - /Users/isaac/work/data:/usr/share/elasticsearch/data
    user: "1000"

ok,啟動服務后, 數據終于持久不丟失了.

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/26591.html

相關文章

  • Docker Volume 之權限管理(轉)

    摘要:發現問題之后,相應的解決方法也很簡單把當前目錄的擁有者賦值給,再啟動容器就一切正常了。這時我們已經可以知道容器的本地數據卷中文件目錄的權限是和宿主機上一致的,只是在容器和宿主機中可能映射為不同的用戶組名稱。 Volume數據卷是Docker的一個重要概念。數據卷是可供一個或多個容器使用的特殊目錄,可以為容器應用存儲提供有價值的特性: 持久化數據與容器的生命周期解耦:在容器刪除之后數據卷...

    sf190404 評論0 收藏0
  • 市長信箱郵件查詢服務: 在Docker上安裝Elasticsearch集群作為服務

    摘要:市長信箱郵件查詢服務在上安裝作為一個服務在上一章我完成了替換的工作按照之前的計劃現在是該把遷移到的時候了為什么要遷移到為后續展示的彈性做準備使用可以方便的部署多節點很火我開發機是要在上使用需要安裝的原理就是在上安裝一臺虛擬機作為容器的宿 市長信箱郵件查詢服務: 在Docker上安裝Elasticsearch作為一個服務 在上一章,我完成了Elasticsearch替換Mysql的工作....

    why_rookie 評論0 收藏0
  • 構建微型數據中心——在laptop上運行Rancher

    摘要:對于開發人員而言,他們的最終目標是擁有自己的數據中心,使他們能夠在貼近真實情況的副本上測試他們的服務。這個想法在最近的六個月來變得非常受歡迎,因為許多大型機構已經開始為開發人員提供一個完整的以讓數據中心能夠在本地運行。 對于開發人員而言,他們的最終目標是擁有自己的數據中心(data center),使他們能夠在貼近真實情況的副本上測試他們的服務。然而,開發人員的開發過程中卻充滿了妥協。...

    dmlllll 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<