Linuxのインストールと仮想マシン・コンテナの利用 – 基本概念から【実践的なdocker-composeコマンド】まで

仮想マシン・コンテナの概念と利用

コンテナ型仮想化とは

サーバ仮想化技術のひとつです。

コンテナの特徴(仮想マシンとの違い)

  • 高速な起動と停止が可能
  • OSカーネルを共有する軽量な仮想化
  • アプリケーションレベルの分離
仮想マシンとコンテナの比較 仮想マシン (VM) ホストOS 物理ハードウェア VM 1 アプリ1 ゲストOS 1 VM 2 アプリ2 ゲストOS 2 コンテナ Dockerエンジン ホストOS 物理ハードウェア Container 1 アプリ1 Container 2 アプリ2 • 完全なOSを含む • リソース消費が大きい • 起動に時間がかかる • OSカーネルを共有 • 軽量で高速 • リソース効率が良い

コンテナ技術を管理するソフトウェア

  • Docker(基本的なソフトウェア)…Docker社が開発したコンテナ仮想化を用いてアプリケーションの開発や実行する環境を構築できるプラットフォーム
  • Kubernetesクバネティス…Googleが開発したコンテナ運用管理を支援するオープンソースのソフトウェア

dockerコマンド

Docker基本コマンド一覧 コンテナのライフサイクル管理 docker run 新規コンテナの作成と起動 docker start/stop コンテナの起動/停止 docker kill コンテナの強制停止 docker rm コンテナの削除 docker ps コンテナ一覧表示 コンテナとの対話 docker attach 標準入出力に接続 docker exec コマンド実行 イメージ管理 docker pull イメージのダウンロード docker push イメージのアップロード docker images イメージ一覧表示

Dockerコマンド実行の前提条件

  1. Dockerデーモン(dockerd)が動作していること。
  2. コマンドを実行するユーザーがDockerグループに属していること(または管理者権限)。

docker-compose コマンドについても同様に、Dockerデーモンとユーザー権限が必要です。

docker run新しいコンテナを作成して起動する
イメージから新しいコンテナを作成し、指定されたコマンドを実行して起動する
docker start既存の停止したコンテナを再起動する
停止しているコンテナを起動するだけ(新しいコンテナは作らない)
docker stopコンテナを安全に停止
docker killコンテナを強制的に停止
docker ps実行中のコンテナの確認
# 停止中のコンテナを含めて確認
docker ps -a
docker rm <コンテナID>停止中のコンテナを削除
docker attachコンテナの標準入出力に接続
docker exec [オプション] <コンテナ名またはID> <コマンド>実行中のコンテナ内でコマンドを実行
docker pullDocker Hubからダウンロード
docker pushDocker Hubにアップロード
docker imagesイメージ一覧表示

Dockerfileとdocker-compose.ymlの違い

DockerfileとDocker Composeの役割 Dockerfile FROM node:14 WORKDIR /app COPY . . CMD [“npm”, “start”] docker-compose.yml services: app: build: . db: mysql:8 Dockerfileがすること: • 1つのアプリケーションをイメージにする手順 • 必要な環境(Node.jsなど)のインストール • アプリケーションコードの配置 docker-compose.ymlがすること: • 複数のイメージを組み合わせる • それぞれの設定(ポート、DB等)を定義 • イメージ同士の連携方法を指定

docker-compose コマンドでできること

  • docker-compose.yml を読み込み
  • 設定に従ってサービスを操作
  • Dockerfile からビルドも実行

docker-compose.yml は「何をどう動かすか」を定義し、docker-compose コマンドはその定義に従って実際の操作を行います。

通常 docker-compose コマンドを実行するディレクトリに docker-compose.yml ファイルが必要です

→docker-compose.ymlが存在しない場合
no configuration file provided: not found

Docker Compose コマンド体系 サービスのライフサイクル管理 docker-compose up サービスの作成と起動 -d: バックグラウンド実行 docker-compose down サービスの停止と削除 –volumes: ボリューム削除 start / stop サービスの起動/停止 特定サービスの指定可 restart サービスの再起動 docker-compose ps コンテナの状態表示 docker-compose logs ログの表示 -f: フォロー モード サービスの操作とビルド docker-compose exec コマンド実行 サービス内でコマンド実行 docker-compose run 一時的なコンテナ実行 –rm: 終了後に削除 docker-compose build サービスのビルド –no-cache: キャッシュ無効 設定と確認 docker-compose config 設定の検証と表示 docker-compose pull イメージの取得 docker-compose version バージョン情報表示

docker-compose up」 コマンドは、docker-compose.ymlに記述された複数のサービス(コンテナ)を一括で構築・起動するためのコマンド

docker-compose up [オプション] [サービス名]

# デタッチモード(バックグラウンド)で実行
docker-compose up -d

# コンテナを起動する前にイメージを再構築
docker-compose up --build

docker-compose logs コンテナのログを確認するためのコマンド

docker-compose logs [オプション] [docker-compose.ymlで定義されたサービス名(コンテナ名ではない)]

# webサービスのタイムスタンプ付きでリアルタイム監視し、最新20行だけ表示
docker-compose logs -f -t --tail=20 web

docker-compose execでサービス何でコマンドを実行、対話形式に入る

docker-compose exec [オプション] <docker-compose.ymlで定義されたサービス名(コンテナ名ではない)> <コマンド>

ブートプロセスとsystemd

  1. 電源投入
  2. ファームウェア(BIOS、UEFI)動作…マザーボード上のNVRAM(不揮発性メモリ)
    • ブートローダを呼び出す…現在GRUB2がよく使用される
    • 優先順位に従って各デバイスの先頭セクタのMBRを読み込む
  3. ブートローダ
    • kernel(Linuxの基本システム)とRAMディスク
    • ブートローダは起動されると、記憶装置(HDD)内のカーネルをロードし、制御を移します。
  4. カーネルを起動
    • メモリ初期化やハードウェア認識
  5. systemd、initでサービス(sshd、httpd、mysqld)起動
    • init:SysVinit(Sustem Five Init)将来
    • systemd:現在のLinuxで採用
  6. ログインプロンプト表示

UEFI

Unified Extensible Firmware Interface

IntelがBIOSにかわるインターフェイスとして考案したのが、UEFIです。

  • GUIでの操作をサポート
  • 3TBを超える大容量HDDからの起動をサポート

systemd

サービスを並列に起動することにより、起動が高速

Unit(処理単位)

  • systemctlで制御
  • 以下のタイプがあります
    • service(各種サービス起動)httpd、sshd等
    • device(デバイス)
    • mount(ファイルシステム)/etc/fstab
    • swap(スワップ領域の有効化。ディスクをメモリに)
    • target(複数Unitをグループ化)

ターゲット

ターゲット
(systemd)
ランレベル
(init)
default.targetシステム起動時のデフォルトのターゲット
sysinit.targetシステム起動時の初期段階のセットアップを行う
poweroff.target0システム終了
rescue.target1レスキュー(シングルユーザー)モード
multi-user.target2,3,4CUIログイン
graphical.target5グラフィカルログイン
reboot.target6システム再起動

systemctl

systemdが稼働するシステムの各サービスの管理はsystemctlコマンドを使用します。

systemctl サブコマンド Unit名

enable自動起動を有効
get-default次回起動時のターゲットを表示
set-default次回起動時のターゲットを設定
haltシステムを停止しhalt状態にする(停止)
poweroffシステムを停止し電源を切断
startサービスを起動
stopサービスを停止
restartサービスを再起動
is-activeサービスが稼働しているかを表示
isolateほかのUnitを停止し、対象のUnitを起動
rebootシステムを再起動

シャットダウン、再起動

シャットダウンや再起動は、systemctrコマンド以外にshutdownコマンドを使う方法があります。

shutdown [オプション] 時間 [メッセージ]
-hシャットダウンする
-rシャットダウン後再起動する
-f次回起動時にfsckをスキップする
-h、-rと併用する
-F次回起動時にfsckを実行する
-h、-rと併用する
-kシャットダウンせずに警告メッセージを通知
-cシャットダウンをキャンセルする

ssh

公開鍵認証 … 秘密鍵で暗号化→公開鍵で復号化(上記認証)

公開鍵暗号 … 公開鍵で暗号化→秘密鍵で復号化

プロセスの生成、監視、終了

プロセスという基本単位でOSは動作中のプログラムを管理します。

psコマンド

process status

psコマンドは現在実行中のプロセスを表示するときに使います。

aほかのユーザのプロセスも表示
f親子関係をツリー上で表示
uユーザ名を表示
xデーモン等表示
-eすべてのプロセスを表示
-f完全なフォーマットでプロセスを表示
-l詳細情報を表示
-p PID指定のPIDの情報を表示
-C プロセス名指定の名前の情報を表示
-w長い行は折返し

topコマンド

実行中のプロセスを継続的に監視するときに使用します。

killコマンド

killコマンドはプロセスにシグナルを送ります。プロセスはシグナルを受け取るとそれに応じた、動作を実行します。

シグナル名シグナルID動作
HUP1ハングアップ(端末が制御不能)
INT2キーボードからの割り込み(Ctrl + Cキー)
KILL9強制終了
TERM15終了(デフォルト)
CONT18停止しているプロセスを再開
STOP19一時停止
TSTP20端末から一時停止(Ctrl + Zキー)

killallコマンド

指定したコマンドを実行している全てのプロセスに対してシグナルを送します。

killall [-シグナル名、-シグナル番号] プロセス名(コマンド名)

pgrepコマンド

指定のプロセスのPIDを表示します。

-U、–uid ユーザ名実行ユーザーを指定
-G、–group グループ名実行グループを指定
-n、–newestもっとも新しいプロセスを選択
-o、–oldestもっとも古いプロセスを選択
-l、–list-nameプロセス名も表示

フォアグラウンドとバックグラウンド

bg

フォアグラウンドで実行中のジョブをバックグラウンドで実行する

fg

バックグラウンドで実行中のジョブをフォアグラウンドで実行する

端末の活用

tmux、screen

複数の画面で切り替えて作業を行えるソフトウェアです。

デスクトップ環境の利用

LinuxはGUIを実現する機能はそなわっていないです。

そこで、GUIをじつげんするためのシステムとしてX Window Systemが使われてきました。

X Window System

XサーバとXクライアントから構成されています。

ウィンドウマネージャ

X Window Systemの外観を制御しているのがウィンドウマネージャです。

twmは最小限の機能を備えたウィンドウマネージャです。

GUIの起動

startxコマンドでX Window Systemが起動します。(CUI環境‥ランレベル3)

ディスプレイマネージャ

  • ランレベル5で起動すると、ディスプレイマネージャはXサーバを起動し、GUIのログイン画面を表示させます。
  • initやsystemdによりディスプレイマネージャーサービスが起動されます。

xauth

xauthコマンドはXサーバの接続で使われる資格情報を表示したり、クライアント認証ファイルを編集するときに使います。

  • xauth listコマンドでXサーバごとの接続に使用される資格情報が表示されます。(Xサーバ側)
  • xauthのaddコマンドで、ユーザの~/.Xauthorityファイル(クライアント認証ファイル)にXサーバと同じ資格情報を保存し、Xサーバと資格情報が一致したユーザのみがアクセスできるようになります。(Xクライアント側)