「VM」の版間の差分

提供:senooken JP Wiki
(OS から VM に分離。)
 
(認証情報)
 
(同じ利用者による、間の2版が非表示)
29行目: 29行目:
===== Use environment variables =====
===== Use environment variables =====
[https://docs.docker.com/compose/how-tos/environment-variables/ Use environment variables | Docker Docs]
[https://docs.docker.com/compose/how-tos/environment-variables/ Use environment variables | Docker Docs]
====== Set environment variables within your container's environment ======
[https://docs.docker.com/compose/how-tos/environment-variables/set-environment-variables/ Set environment variables | Docker Docs]
====== Interpolation ======
[https://docs.docker.com/compose/how-tos/environment-variables/variable-interpolation/#env-file Interpolation | Docker Docs]
.envファイルで環境変数を渡せる。
Dockerfileにも渡すことができる。
https://chatgpt.com/c/673bedde-f5d0-800b-b604-fbb93c2dffe4
docker-compose.ymlのargsで引数として.envの環境変数を設定。
version: '3.8'
services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
      args:
        APP_ENV: ${APP_ENV}
    ports:
      - "${APP_PORT}:80"
Dockerfileで受け取って参照。
FROM php:8.1-cli
# ビルド引数を定義
ARG APP_ENV
# ビルド時の環境変数を設定
ENV APP_ENV=${APP_ENV}
# 確認用
RUN echo "App Environment: $APP_ENV"
WORKDIR /app


=== Image ===
=== Image ===
212行目: 249行目:
  pgrep cron  # cronプロセスの確認
  pgrep cron  # cronプロセスの確認


==== 認証情報 ====
composerでプライベートリポジトリーをinstallしようとすると少々厄介。
https://chatgpt.com/c/673bedde-f5d0-800b-b604-fbb93c2dffe4
いくつか方法がある。.envに認証情報を記入して、それを参照するのがシンプル。
.env
<nowiki>COMPOSER_AUTH='{"github-oauth":{"github.com":"YOUR_TOKEN"}}'</nowiki>
github.comの[Settings]-[Developer settings]-[Personal access tokens]-[[Tokens (classic)](https://github.com/settings/tokens)]-[Generate new token] から作成した新しいトークンを記入しておく ([Select scopes]=[repo] を最低チェック)
'''<code>docker-compose.yml</code>'''
version: '3.8'
services:
<nowiki> </nowiki> app:
<nowiki> </nowiki>  build:
      context: .
      args:
        COMPOSER_AUTH: ${COMPOSER_AUTH}
    volumes:
      - .:/app
Dockerfile
ARG COMPOSER_AUTH
ENV COMPOSER_AUTH=${COMPOSER_AUTH}
[[Category:IT]]
[[Category:IT]]

2024年11月19日 (火) 12:14時点における最新版

UTM

Control

Capture

Controls | UTM Documentation

デフォルトだと、Control-Tabなど、一部のMac本体のホットキーが有効になっている。例えば、Windows側でc-tabを入力できなくて困る。

4番のボタンまたは、control-optionで、カーソルとキーボードをVMでキャプチャーする。これで入力可能になる。

Docker

Network

docker network ls

上記コマンドでコンテナーごとのネットワーク識別子を確認できる。コンテナー同士で同一ネットワークにするには、片方のservices.networks:でこのネットワーク識別子を指定する。

Compose

phpのアプリサーバー、DBサーバーを一つのイメージで作ることもできるが、別のイメージにして連動させることもできる。別のイメージ・コンテナーにしたほうが、管理しやすい模様。

docker composeで複数のイメージ・コンテナーを一体に管理できる。その際に、特有の事項がある。

PHPのPDOをDockerコンテナ内で使おうとしたところ、"No such file or directory" エラーが発生した話 #docker-compose - Qiita

docker composeで一体管理しているコンテナー群は、同一ネットワークに参加する。ホスト名はservice名になる。したがって、例えばアプリサーバーからDBサーバーへのアクセス時には、ホスト名に注意する。

How-tos

Use environment variables

Use environment variables | Docker Docs

Set environment variables within your container's environment

Set environment variables | Docker Docs

Interpolation

Interpolation | Docker Docs

.envファイルで環境変数を渡せる。

Dockerfileにも渡すことができる。

https://chatgpt.com/c/673bedde-f5d0-800b-b604-fbb93c2dffe4

docker-compose.ymlのargsで引数として.envの環境変数を設定。

version: '3.8'
services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
      args:
        APP_ENV: ${APP_ENV}
    ports:
      - "${APP_PORT}:80"

Dockerfileで受け取って参照。

FROM php:8.1-cli

# ビルド引数を定義
ARG APP_ENV

# ビルド時の環境変数を設定
ENV APP_ENV=${APP_ENV}

# 確認用
RUN echo "App Environment: $APP_ENV"

WORKDIR /app

Image

PHP

Ref: php - Official Image | Docker Hub.

Dockerの公式PHPイメージを使う場合、いくつかPHP関係のライブラリーや拡張モジュールをインストール・設定するための専用コマンドが用意されている。

RUN pecl install memcached-3.2.0 \
	&& docker-php-ext-enable memcached

peclの拡張機能インストール時はバージョン指定が推奨される。

docker-php-ext-install

Docker で PHP 拡張モジュールをインストールする | QUARTETCOM TECH BLOG

PHP拡張モジュールのインストールと設定を行うヘルパーコマンドが用意されている。--helpで対象拡張モジュール一覧を確認できる。

$ docker run php:latest docker-php-ext-install --help

# .....
Possible values for ext-name:
bcmath bz2 calendar ctype curl dba dl_test dom enchant exif ffi fileinfo filter ftp gd gettext gmp hash iconv imap intl json ldap mbstring mysqli oci8 odbc opcache pcntl pdo pdo_dblib pdo_firebird pdo_mysql pdo_oci pdo_odbc pdo_pgsql pdo_sqlite pgsql phar posix pspell random readline reflection session shmop simplexml snmp soap sockets sodium spl standard sysvmsg sysvsem sysvshm tidy tokenizer xml xmlreader xmlwriter xsl zend_test zip
# .....

PECL以外は一通り使用可能。

error

docker-php-ext-installでインストールする際には、必要な依存関係もセットで指定しないとエラーが出る。

FROM php:7.3.23-apache
RUN apt update
RUN docker-php-ext-install pdo_mysql
RUN apt install -y libbz2-dev && docker-php-ext-install bz2
RUN apt install -y libpng-dev && docker-php-ext-install gd
RUN apt install -y libzip-dev && docker-php-ext-install zip
RUN apt install -y ssl-cert && a2enmod rewrite ssl && a2ensite default-ssl
COPY --from=composer /usr/bin/composer /usr/bin/composer

ヘッダーのあるlib*-devもセットでインストールしておく。

phpmyadmin

Ref: phpmyadmin - Official Image | Docker Hub.

以下のdocker-compose.ymlを格納しておいて、networksのところをつなげたいやつにあわせる。

services:
  phpmyadmin:
    image: phpmyadmin
    restart: always
    ports:
      - 8080:80
    environment:
      - PMA_ARBITARY=1
    networks:
      - development_default
        # - wordpress_default
networks:
  wordpress_default:
    external: true
  development_default:
    external: false

特に重要な環境変数。

  • PMA_ARBITRARY - when set to 1 connection to the arbitrary server will be allowed
  • PMA_HOST: デフォルトはdb。servicesがdb以外なら指定必要。
  • PMA_USER/PMA_PASSWORD=phpmyadminのデフォルトユーザー。これを指定しておくと、自動ログインする。

MySQL

import

Ref: Import data.sql MySQL Docker Container - Stack Overflow.

docker exec -i mysql-container mysql -uuser -ppassword name_db < data.sql

上記のようなコマンドで取り込む。

Error

connect ENOENT \\.\pipe\errorReporter

https://github.com/docker/for-win/issues/14080

再起動で直るらしい?

インストール時のアカウントの権限があるので、アカウント権限がある状態で再インストールするとOK。

`version` is obsolete

【docker compose】警告`version` is obsoleteの解決法

$ docker compose up
time="2024-07-02T09:54:45+09:00" level=warning msg="C:\\Users\\senoo_0901\\project\\main\\GASProj\\docker\\docker-compose.yml: `version` is obsolete"

docker compose v2からversion指令は廃止になった。単純に削除すればいい。

Other

RUN/CMD/ENTRYPOINTの違い

Dockerfileでコマンドを実行する指令が複数ある。違いを整理する。

  • RUN: イメージ作成時=docker build字に実行。ソフトウェアのパッケージインストール、ファイルコピー変更などを行う。
  • CMD: コンテナ開始時=docker start、作成時=docker run時に実行される。docker run時のコマンドのデフォルト値。引数があればそちら優先。VolumeのバインドはRUN後になるのでCMD/ENTRYPOINTで行う必要がある。
  • ENTRYPOINT: コンテナ開始時=docker start、作成時=docker run時に実行される。docker run時に強制実行。上書き不能。ただし、CMDや実行時に引数を後ろに追加できる。

CMD/ENTRYPOINTはDockerfile内でそれぞれ1回しか指定できない。一番最後の指定で上書きされる。

「The shell form of ENTRYPOINT prevents any CMD command line arguments from being used.」とあるように、 ENTRYPOINTとCMDを併用する場合、exec形式で指定しないとCMDが無視される。

How to combine CMD and ENTRYPOINT - Open Source Projects / Compose - Docker Community Forums

ENTRYPOINTにコマンドを追記したい場合、entrypoint.shのようなスクリプトを実行する形にして、スクリプト内で引数処理するのがいいらしい。

権限設定

Apache HTTP Serverの/var/wwwの権限設定 | GNU social JP Web

Why does chown not work in RUN command in Docker? - DevOps Stack Exchange

バインドボリュームする場合、RUNの後にバインドされるからCMDで設定が必要。

DockerfileにENTRYPOINTもCMDも無い?? | へるぷログ

CMD/ENTRYPOINTを指定しない場合、元イメージのCMD/ENTRYPOINTが実行される模様。apacheだとapache2-foregroundコマンド。

docker-composeでコンテナの初回起動時に特定の処理を行う方法 #Docker - Qiita

初回起動時に処理をする方法もあるが、一時ファイルを生成するなどするもの。権限設定は毎回実行してもOKなものなので、毎回実行する。

umask for non-root users not as expected · Issue #1142 · docker-library/php

/root/.bashrcにumaskを指定する。これがないと、コマンドラインでdocker exec -i で実行した際デフォルトのumask 022でのファイル生成になり、この作業コマンドでログが発生したら、サーバープロセスから追記できない。

FROM php:7.3.23-apache
RUN apt update && apt install -y \
      ssl-cert
RUN docker-php-ext-install pdo_mysql
RUN a2enmod rewrite ssl
RUN a2ensite default-ssl
COPY --from=composer /usr/bin/composer /usr/bin/composer

ENV BASH_ENV /root/.bashrc
RUN usermod -aG www-data root \
      && echo "umask 002" >>/root/.bashrc
CMD chgrp -R www-data /var/www && chmod 2775 /var/www \
      && find /var/www -type d -exec chmod 2775 {} \; \
      && find /var/www -type f -exec chmod 0664 {} \; \
      && apache2-foreground

dockerfile - Is it possible to set the default command when the `docker exec` command is run on an already running container? - Stack Overflow

docker exec実行時は、デフォルト実行されるコマンドはない。[Bash Startup Files (Bash Reference Manual)] にあるように、BASH_ENVに指定したファイルを非対話実行でも読み込むのでこれを指定して、常にbash -cで実行する。

あるいは、BASH_ENVを指定せずに、bash -c 'umask 002; 'で実行する。

他に上記にあるように、ENTRYPOINTでumaskを指定する方法がある。が、これは関係ない気がする。chomd 2775 /var/wwwでスティッキーを指定しているから、後続の作成時は自動で2775になっているはずだから。

docker runとexec

docker runとdocker execの違いの解説 | めもたんす

run: イメージ作成・実行。

exec: 起動中のイメージで実行。

Japanese input/日本語入力

OSに日本語のロケールが入っていないのが原因。

Debian系の場合。

## For Japanese input.
RUN apt install -y locales
RUN (rm /etc/locale.gen && sed '/# ja_JP.UTF-8 UTF-8/s/# //' >/etc/locale.gen) </etc/locale.gen
RUN locale-gen
ENV LANG=ja_JP.UTF-8

/etc/locale.genのファイルの修正が必要。

これで日本語が使用可能になる。

cron

How to run a cron job inside a docker container? - Stack Overflow

Docker内でcronを実行する方法がいくつかある。

## For cron.
RUN apt install -y cron
RUN (crontab -l ; echo '* * * * * /usr/local/bin/php /var/www/artisan schedule:run >/dev/null 2>&1') | crontab
CMD cron # CMDは最後の1個しか有効じゃないので、最後にまとめて指定することに注意する。

動作確認

crontab -l  # crontabの確認
pgrep cron  # cronプロセスの確認

認証情報

composerでプライベートリポジトリーをinstallしようとすると少々厄介。

https://chatgpt.com/c/673bedde-f5d0-800b-b604-fbb93c2dffe4

いくつか方法がある。.envに認証情報を記入して、それを参照するのがシンプル。

.env

COMPOSER_AUTH='{"github-oauth":{"github.com":"YOUR_TOKEN"}}'

github.comの[Settings]-[Developer settings]-[Personal access tokens]-[[Tokens (classic)](https://github.com/settings/tokens)]-[Generate new token] から作成した新しいトークンを記入しておく ([Select scopes]=[repo] を最低チェック)

docker-compose.yml

version: '3.8'
services:
  app:
    build:
      context: .
      args:
        COMPOSER_AUTH: ${COMPOSER_AUTH}
    volumes:
      - .:/app

Dockerfile

ARG COMPOSER_AUTH
ENV COMPOSER_AUTH=${COMPOSER_AUTH}