av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

解決docker run中使用 ./ 相對路徑掛載文件或目錄失敗的問題

瀏覽:110日期:2024-11-04 11:56:57

docker-compose.yml文件中允許使用’./’相對路徑

version: ’3’ ... volumes: - ./init-mongo.js:/docker-entrypoint-initdb.d/init-mongo.js:ro - ./mongo-volume:/data/db ...

會將當前路徑下的init-mongo.js文件掛載到容器中的/docker-entrypoint-initdb.d/init-mongo.js,并且設置為只讀方式;

會將當前路徑下的mongo-volume目錄掛載到容器中/data/db,如果不存在mongo-volume,則會自動創建該目錄

但如果是docker run的方式就不能像上面一樣用相對路徑了

>>> docker run -d --restart always -p 27017-27019:27017-27019 -e MONGO_INITDB_DATABASE=job -e MONGO_INITDB_ROOT_USERNAME=root -e MONGO_INITDB_ROOT_PASSWORD=root -v $PWD/init-mongo.js:/docker-entrypoint-initdb.d/init-mongo.js:ro -v ./mongo-volume:/data/db --name my-mongo-container mongodocker: Error response from daemon: create ./init-mongo.js: './init-mongo.js' includes invalid characters for a local volume name, only '[a-zA-Z0-9][a-zA-Z0-9_.-]' are allowed. If you intended to pass a host directory, use absolute path.See ’docker run --help’.

需要用到$PWD替代點號’.’

>>> docker run -d --restart always -p 27017-27019:27017-27019 -e MONGO_INITDB_DATABASE=job -e MONGO_INITDB_ROOT_USERNAME=root -e MONGO_INITDB_ROOT_PASSWORD=root -v $PWD/init-mongo.js:/docker-entrypoint-initdb.d/init-mongo.js:ro -v $PWD/mongo-volume:/data/db --name my-mongo-container mongo3081e25a20fa8b2e95850897b3b32b08da298f73d7e458119fa3f2c85b45f020

補充:Docker -v 對掛載的目錄沒有權限 Permission denied

1.問題

今天在使用docker掛載redis的時候老是報錯

docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 -p 6378:6379 redis redis-server /usr/local/etc/redis/redis.conf

然后一直報錯:

Fatal error, can’t open config file ’/usr/redis/redis.conf’

2.排查過程

查看日志也是這樣

然后我把使用配置文件的地方去掉

docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 -p 6378:6379 redis

然后進入容器

docker exec -it redis2 /bin/bash

然后進入掛載的文件夾下

cd /usr/local/etc/redis

發現報錯:

cannot open directory ’.’: Permission denied

也就是沒有權限

3.原因以及解決方案3.1 原因

centos7中安全模塊selinux把權限禁掉了

3.2解決方案

有三種方法解決:

1.在運行時加 --privileged=true

docker run -v /home/redis/redis.conf:/usr/local/etc/redis/redis.conf --name redis2 --privileged=true redis redis-server /usr/local/etc/redis/redis.conf

2.臨時關閉selinux然后再打開

[root@localhost tomcat]# setenforce 0[root@localhost tomcat]# setenforce 1

3.添加linux規則,把要掛載的目錄添加到selinux白名單

更改安全性文本的格式如下

chcon [-R] [-t type] [-u user] [-r role] 文件或者目錄

選頃不參數:

-R :該目錄下的所有目錄也同時修改;

-t :后面接安全性本文的類型字段,例如 httpd_sys_content_t ;

-u :后面接身份識別,例如 system_u;

-r :后面街覘色,例如 system_r

執行:

chcon -Rt svirt_sandbox_file_t /home/redis/redis.conf4.關于docker掛載的一些經驗

4.1 容器目錄不可以為相對路徑

4.2 宿主機目錄如果不存在,則會自動生成

4.3 宿主機的目錄如果為相對路徑呢

可以通過docker inspect命令,查看容器“Mounts”那一部分,我們可以得到這個問題的答案。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Docker
相關文章:
主站蜘蛛池模板: 久久毛片| 黄色网络在线观看 | 中文字幕在线电影观看 | 欧美亚洲国产日韩 | 久久精品av麻豆的观看方式 | 中文字幕日韩欧美 | 精品免费国产视频 | 日本中出视频 | 手机av在线 | 国产婷婷色综合av蜜臀av | 在线观看av网站永久 | 337p日本欧洲亚洲大胆精蜜臀 | 日p视频免费看 | 二区av | 日本电影免费完整观看 | 天天插天天舔 | 精产国产伦理一二三区 | 99精品视频在线 | 亚洲欧洲精品在线 | 狠狠综合久久av一区二区小说 | 日韩成人精品视频 | 亚洲国产精品99久久久久久久久 | 亚洲精品成人av久久 | 91久久精品日日躁夜夜躁国产 | 国产精品一区二区三区久久久 | 精品国产成人 | 亚洲精品欧美精品 | 精久久久久 | 午夜在线小视频 | 国产亚洲精品一区二区三区 | 久在线视频播放免费视频 | 久久国产精品一区二区三区 | 久久久久国色av免费观看性色 | 国产a区| 国产精品久久久亚洲 | 在线观看中文字幕 | 欧美日韩亚洲国产 | 国产精品爱久久久久久久 | 免费成人在线网站 | 亚洲欧美日韩一区二区 | 国产亚洲一区二区精品 |