docker-compose.yml ファイルで './' 相対パスを許可する バージョン: '3' ... ボリューム: - ./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 mongo docker: デーモンからのエラー応答: ./init-mongo.js を作成: 「./init-mongo.js」にはローカル ボリューム名に無効な文字が含まれています。「[a-zA-Z0-9][a-zA-Z0-9_.-]」のみが許可されます。ホスト ディレクトリを渡す場合は、絶対パスを使用してください。 「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 mongo 3081e25a20fa8b2e95850897b3b32b08da298f73d7e458119fa3f2c85b45f020 補足: Docker -v にはマウントされたディレクトリに対する権限がありません 権限が拒否されました 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 その後、エラーが報告され続けます:
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 次にマウントされたフォルダに移動します /usr/local/etc/redis をコピーします エラーが見つかりました:
つまり、許可がない 3. 原因と解決策3.1 理由Centos7のセキュリティモジュールselinuxは権限を無効にしています 3.2 解決策解決方法は3つあります。 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ホワイトリストに追加します。 セキュリティテキストを変更する形式は次のとおりです。
パラメータなしのオプション: -R: このディレクトリの下にあるすべてのディレクトリも同時に変更されます。 -t: セキュリティ ドキュメントのタイプ フィールドが続きます (例: httpd_sys_content_t)。 -u : 続いて ID 識別子 (例: system_u) が続きます。 -r: 次の通りの色、例: system_r 埋め込む: chcon -Rt svirt_sandbox_file_t /home/redis/redis.conf 4. Dockerマウントに関する経験4.1 コンテナディレクトリは相対パスにできません 4.2 ホストディレクトリが存在しない場合は自動的に生成されます 4.3 ホストディレクトリが相対パスの場合はどうなりますか? この質問に対する答えは、docker inspect コマンドを使用してコンテナの「マウント」セクションを確認することで得られます。 上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。 以下もご興味があるかもしれません:
|
<<: CSS3 を使用して中心点の周りに要素を配置する方法の例
1. WEBを理解するWeb ページは主にテキスト、画像、ハイパーリンクなどの要素で構成されていま...
1. このマシンに新しい設定ファイルdocker_nginx.confを作成します。 サーバー{ 7...
前回の記事では、Docker を使用して Laravel アプリケーションをデプロイする方法について...
1. ElasticSearch とは何ですか? Elasticsearch も Java で開発さ...
今日、vue3+viteプロジェクトの実践で、svgを使用する場合、以前の記述方法が使用できないこと...
Web ページでは、基本的に <input type="file">...
Docker入門Docker は、アプリケーションをより速く配信するのに役立つオープンソースのコンテ...
上の境界線のみを表示する <table frame=above>下の境界線のみを表示する...
垂直方向では、ヘッダーの配置を上、中央、下に設定できます。基本的な構文構文Top は上、Middle...
序文現在、私の会社で使用しているオペレーティングシステムはすべて CentOS7.4 で、アプリケー...
目次1. ブール2. 表現3. マルチクラスパッケージ4. v-bind でクラス class を直...
閉鎖による問題を回避するためのletについてオブジェクト指向の考え方を使用して、購入者情報の削除機能...
トランザクション分離レベルの設定 グローバルトランザクション分離レベルを読み取りコミット済みに設定;...
目次MySQLがmy.cnfを読み込む順序1. mysql.server の起動方法2. mysql...
メインライブラリの構成1. MySQLを設定する vim /etc/my.cn # ファイルに次の内...