質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.92%

macOS Mojaveで vitual box+vagrant+centos7+dcoker+docker-composeを使い redmine構築で Operation not permitted

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 594

MShiryo

score 5

前提・実現したいこと

macOS Mojave で 
vitual box + vagrant + centos7 + dcoker + docker-compose を使い 
redmine の構築を試しています。

発生している問題・エラーメッセージ

docker-compose up -d で起動まではできるものの、
docker logs でログを見ると 

chown: changing ownership of 'files': Operation not permitted


など外部共有したいフォルダの権限変更ができない旨のメッセージが発生しており、
Restarting し続けてしまい redmine が起動できません。

試したこと

docmker-compose.yml に privileged: true を追記: 変化なし

version: '3.7'
services:
    redmine:
        container_name: redmine
        image: redmine
        environment:
            REDMINE_DB_POSTGRES: redmine-db
            REDMINE_DB_PASSWORD: redmine
            REDMINE_DB_USERNAME: redmine
            REDMINE_DB_PASSWORD: redmine
        restart: always
        privileged: true
        ports:
            - 3000:3000
        depends_on:
            - redmine-db
        volumes:
            - ./redmine/files:/usr/src/redmine/files
            - ./redmine/config:/usr/src/redmine/config

    redmine-db:
        container_name: redmine-db
        image: postgres
           .
           .

centosのselinuxをdisabled: 変化なし

[vagrant@localhost work]$ getenforce
Disabled

centos7内で外部共有フォルダのグループに、コンテナ内のグループ追加:変化なし
(redmineコンテナ内の /etc/group の redmine = 999)

[vagrant@localhost work]$ sudo chown -R :999 redmine
[vagrant@localhost work]$ sudo chown -R :999 redmine-db

docker-compose.yml の volumes をコメントアウト: 起動できるものの、外部共有できないのでNG

補足情報(FW/ツールのバージョンなど)

バージョンは下記の通りです。
virtual box    : 6.0.14
vagrant        : 2.2.6
centos7        : 1905.1
docker         : 19.03.4
docker-compose : 1.24.1

インストール方法は下記の通りです。
virtual box    : インストーラ
vagrant        : インストーラ
centos7        : vagrant box add centos/7

vagrant        :

cd /Users/xxxxx/vagrant/redmine_test
vagrant init centos/7
vagrant plugin install vagrant-vbguest
vagrant up

Vagrantfile    :

Vagrant.configure("2") do |config|
  config.vm.box = "centos/7"
  config.vm.network "forwarded_port", guest: 3000, host: 3000 # ホストIPアドレス:3000 でRedmineアクセス
  config.vm.network "private_network", ip: "192.168.33.11"
  config.vm.synced_folder "./work", "/home/vagrant/work", type: "nfs", create:"true"
  config.vm.provider "virtualbox" do |v|
    v.memory = 4096
    v.cpus = 2
  end

  config.vm.provision :shell, :path => "provision/provision.sh", :privileged => false
end

docker         : (Vagrantfile の config.vm.provision の shell で実施)

sudo yum update -y

echo 前提パッケージを導入
sudo yum install -y yum-utils device-mapper-persistent-data lvm2

echo StableRepositoryを有効にする
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

echo container-selinuxインストール
sudo yum install -y container-selinux

echo docker-ceインストール
sudo yum install -y docker-ce


docker-compose : (Vagrantfile の config.vm.provision の shell で実施)

sudo curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

vagrant内の権限

[vagrant@localhost work]$ pwd
/home/vagrant/work
[vagrant@localhost work]$ ls -lRa
.:
合計 4
drwxr-xr-x  6     501 games   192 11月  7 20:31 .
drwx------. 4 vagrant vagrant 107 11月  7 20:28 ..
-rw-rw-r--  1     501 games     0 11月  7 20:28 aa.txt
-rwxr-xr-x  1     501 games   980 11月  7 20:30 docker-compose.yml
drwxr-xr-x  4     501 games   128 11月  7 20:31 redmine
drwxr-xr-x  4     501 games   128 11月  7 20:31 redmine-db

./redmine:
合計 0
drwxr-xr-x 4 501 games 128 11月  7 20:31 .
drwxr-xr-x 6 501 games 192 11月  7 20:31 ..
drwxr-xr-x 2 501 games  64 11月  7 20:31 config
drwxr-xr-x 2 501 games  64 11月  7 20:31 files

./redmine/config:
合計 0
drwxr-xr-x 2 501 games  64 11月  7 20:31 .
drwxr-xr-x 4 501 games 128 11月  7 20:31 ..

./redmine/files:
合計 0
drwxr-xr-x 2 501 games  64 11月  7 20:31 .
drwxr-xr-x 4 501 games 128 11月  7 20:31 ..

./redmine-db:
合計 0
drwxr-xr-x 4 501 games 128 11月  7 20:31 .
drwxr-xr-x 6 501 games 192 11月  7 20:31 ..
drwxr-xr-x 2 501 games  64 11月  7 20:31 data
drwxr-xr-x 2 501 games  64 11月  7 20:31 initdb

./redmine-db/data:
合計 0
drwxr-xr-x 2 501 games  64 11月  7 20:31 .
drwxr-xr-x 4 501 games 128 11月  7 20:31 ..

./redmine-db/initdb:
合計 0
drwxr-xr-x 2 501 games  64 11月  7 20:31 .
drwxr-xr-x 4 501 games 128 11月  7 20:31 ..

以上です。どうかよろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • yurak

    2020/01/23 02:13

    docker-compose.yml の volumes をコメントアウト: 起動できるものの、外部共有できないのでNG
    とありましたが、

    コメントアウトした時の/usr/src/redmine/filesの
    User:Permissionはredmine:redmineであっていますか?

    docker-composeで起動した場合はrootになる可能性があるため為念の確認になります。

    キャンセル

  • MShiryo

    2020/01/23 10:05 編集

    はい、コメントアウトした場合のdockerコンテナ内の
    /usr/src/redmine/files は redmine:redmine です。

    ```
    vagrant上の環境からdockerコンテナへ
    docker exec -it redmineコンテナ bash

    pwd
    /usr/src/redmine

    ls -l
    drwxr-xr-x. 2 redmine redmine 6 Oct 21 16:42 files
    ```

    キャンセル

回答 1

0

centos7内で./redmine を chmod 777 してください。
また、Macであればdcoker+docker-composeだけで永続化含めてredmineを試せますので、vitual box+vagrantでの問題を回避することも可能です。

参考:
http://wordpress.honobono-life.info/lin-base/%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%AE%E3%83%91%E3%83%BC%E3%83%9F%E3%83%83%E3%82%B7%E3%83%A7%E3%83%B3%E8%A8%AD%E5%AE%9A%E3%80%81%E3%83%87%E3%82%A3%E3%83%AC%E3%82%AF%E3%83%88%E3%83%AA%E3%81%AF/

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/01/24 23:55

    返信が遅くなりすみません。
    変わらず、Operation not permittedが発生してしまいました。

    ```
    ・vagrant centos7環境にログイン
    ・cd ../
    ・pwd
    /home

    ・ls -l
    合計 0
    drwx------. 4 vagrant vagrant 107 1月 23 23:42 vagrant

    ・chmod -r 777 vagrant
    chmod: `777' にアクセスできません: そのようなファイルやディレクトリはありません

    ・sudo chmod 777 vagrant/
    ・ls -l
    合計 0
    drwxrwxrwx. 4 vagrant vagrant 107 1月 23 23:42 vagrant

    ・cd vagrant/work
    ・docker-compose up -d
    ・docker logs redmineコンテナ名
    chown: changing ownership of 'files': Operation not permitted

    ※vagrant配下のworkもやりましたが、ダメでした。
    ・cd ../
    ・pwd
    /home/vagrant
    ・sudo chmod 777 work/
    ・ls -l
    合計 0
    drwxrwxrwx. 12 501 games 384 1月 23 23:46 work

    ・cd work
    ・docker-compose up -d
    ・docker logs redmineコンテナ名
    chown: changing ownership of 'files': Operation not permitted
    ```

    以上です。

    キャンセル

  • 2020/01/25 22:55 編集

    vagrant up で ./work にマウントするようにVagrantfileに記載されています。
    config.vm.synced_folder "./work", "/home/vagrant/work", type: "nfs", create:"true"

    MacOS側では ./work は作成されておらず、vagrant up 時に作成される設定となっていますので、
    事前に作成のうえ、chmod 777 してみていただけますでしょうか。
    cd /Users/xxxxx/vagrant/redmine_test  ← workフォルダなし?

    キャンセル

  • 2020/01/27 00:19 編集

    vagrantへのsshログインができなくなってしまったので、
    一度削除をしております。
    またworkフォルダは、先に作成していたと記憶しています。
    今回一度vagrant destroy したので、どちらにしても
    Workフォルダが先に存在した状態になっています。

    なお結論としては、やはりできませんでした。

    ```
    ※ログインできない状態
    ・vagrant ssh
    vagrant@127.0.0.1: Permission denied (publickey,gssapi-keyex,gssapi-with-mic).
    ```

    たぶんですが、下記を行うと出来なくなってしまったので、
    そこはやらない状態から進めています。
    ```
    ・sudo chmod 777 vagrant/
    ・ls -l
    合計 0
    drwxrwxrwx. 4 vagrant vagrant 107 1月 23 23:42 vagrant
    ```

    前置きが長くなってしまいすみません。
    vagrant destroy の後、行なった操作は
    下記になります。
    ```
    ・Vagrantfileを修正
    config.vm.synced_folder "./work", "/home/vagrant/work", type: "nfs", create:"true"
    →config.vm.synced_folder "./work", "/home/vagrant/work", type: "nfs"

    ・pwd
    /Users/xxxxx/vagrant/redmine_test
    ・chmod 777 work
    ・ls -l
    -rw-rw-r--@ 1 xxxxx staff 4421 1 26 22:46 Vagrantfile
    drwxrwxrwx 12 xxxxx staff 384 1 26 23:12 work

    ・ls -l work
    -rw-rw-r-- 1 xxxxx staff 652 1 23 23:45 docker-compose.yml
    drwxrwxrwx 4 xxxxx staff 128 1 23 23:42 redmine

    ・ls -l work/redmine
    drwxrwxrwx 2 xxxxx staff 64 1 23 23:42 files
    drwxrwxrwx 2 xxxxx staff 64 1 23 23:42 plugins

    ・vagrant起動、ログイン
    ・cd ../
    ・pwd
    /home

    ・ls -lR
    .:
    drwx------. 4 vagrant vagrant 107 1月 26 23:37 vagrant ※ここで sudo chmod 777 vagrant をすると、再ログインができなくなりましたのでそのままです。

    ./vagrant:
    drwxrwxrwx 12 501 games 384 1月 26 23:12 work

    ./vagrant/work:
    drwxrwxrwx 4 501 games 128 1月 23 23:42 redmine

    ./vagrant/work/redmine:
    drwxrwxrwx 2 501 games 64 1月 23 23:42 files
    drwxrwxrwx 2 501 games 64 1月 23 23:42 plugins

    ・cd vagrant/work
    ・docker-compose up -d
    ・docker logs redmineコンテナ名
    chown: changing ownership of 'files': Operation not permitted
    ```

    vagrantへのchmod 777 をしていないので、
    教えていただいた通りにできていない状態で申し訳ありません。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る