annotate paper/mk-wm.tex @ 5:ef6f19e8ec75

update tex
author Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
date Mon, 03 Aug 2020 14:39:40 +0900
parents f84b0189359c
children db794a6414e4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 %%
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 %% 研究報告用スイッチ
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 %% [techrep]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 %%
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 %% 欧文表記無しのスイッチ(etitle,eabstractは任意)
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 %% [noauthor]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 %%
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 %\documentclass[submit,techrep]{ipsj}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 \documentclass[submit,techrep,noauthor]{ipsj}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 \usepackage[dvips,dvipdfmx]{graphicx}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 \usepackage{latexsym}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 \usepackage{listings}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 \lstset{
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 language=C,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 tabsize=2,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 frame=single,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 basicstyle={\tt\footnotesize}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 identifierstyle={\footnotesize}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 commentstyle={\footnotesize\itshape}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 keywordstyle={\footnotesize\ttfamily}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 ndkeywordstyle={\footnotesize\ttfamily}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 stringstyle={\footnotesize\ttfamily},
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 breaklines=true,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 captionpos=b,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 columns=[l]{fullflexible}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 xrightmargin=0zw, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 xleftmargin=1zw, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 aboveskip=1zw,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 numberstyle={\scriptsize}, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 stepnumber=1,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 numbersep=0.5zw, %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 lineskip=-0.5ex,
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 }
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 \usepackage{caption}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 \def\Underline{\setbox0\hbox\bgroup\let\\\endUnderline}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 \def\endUnderline{\vphantom{y}\egroup\smash{\underline{\box0}}\\}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 \def\|{\verb|}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 %
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 %\setcounter{巻数}{59}%vol59=2018
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 %\setcounter{号数}{10}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 %\setcounter{page}{1}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 \renewcommand{\lstlistingname}{Code}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 \begin{document}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 \title{情報工学科演習用のコンテナ技術を用いた新規サービスの設計・実装}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 %\etitle{How to Prepare Your Paper for IPSJ SIG Technical Report \\ (version 2018/10/29)}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 \affiliate{KIE}{琉球大学大学院理工学研究科情報工学専攻}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 \affiliate{IE}{琉球大学工学部工学科知能情報コース}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 \author{宮平 賢}{Miyahira Ken}{IE}[mk@cr.ie.u-ryukyu.ac.jp]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 \author{河野 真治}{Shinji Kono}{IE}[kono@ie.u-ryukyu.ac.jp]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 \begin{abstract}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 IT技術を学ぶ時の学習環境の 1つとして, OS 上の隔離された環境を構築する技術であるコンテナがある. これらはローカルに設置された計算機, あるいはクラウド上に作られる.
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 作成されるコンテナは学生, あるいは教員側から適切に管理するシステムが必要となる.
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 管理システムはマルチユーザで動作するのは当然として, 利用者や管理者に適したUI, sudo権限で動作するコンテナへの対処などが含まれる.
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 学生の演習には, Webサービスの実装や人工知能の学習などがある. そのため, 気軽に開発環境やテスト環境などを用意できる利用のしやすさが重要である.
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 本稿ではコンテナ管理ソフトウェアである Docker, Singularity を用いた新規 Web サービスの設計・実装を行う.
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 \end{abstract}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 \maketitle
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 \section{はじめに}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 情報通信技術の普及に伴い学生が学ぶ学習環境が必要となる。その学習環境として VM や コンテナにより, 手軽に開発し試せる技術が普及している。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 だが, 手元の PC 上で VM や コンテナを立ち上げ, 開発を行うことはできるが, VM や コンテナの使用には高性能 PC や 有料のクラウドサービスが必要になる場合がある。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 この大きな負担を学生に負わせない仕組みが必要である。\par
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
80 琉球大学工学部工学科知能情報コースでは希望の学生に学科のブレードサーバから仮想環境を貸出すサービスを行なっている。貸出をする VM のデフォルトのスペックでは
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
81 不足の場合, 要望に応じてスペックの変更を行なっている。だが, 貸出サービスでは GPU を利用した処理環境を提供することができない。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 %だが, 貸出サービスでは近年盛んに行われている人工知能の研究に必要な環境を提供することができない。
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
83 GPU が搭載されている PC は研究室によっては用意されているが, 研究室に所属していない学生は利用することができない。そのため, 新たな仕組みが必要である。\par
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
84 学科のブレードサーバに搭載される GPU は VM の貸出サービスでは利用することができない。そこでコンテナ技術を利用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
85 コンテナ管理ソフトウェアである Docker では NVIDIA Container Toolkit である nvidia-docker を利用することで, 複数のコンテナで GPU を共有することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
86 Docker は基本的に root 権限で動作する。また一般ユーザが docker コマンドを使用するには docker グループに追加する必要がある。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
87 そのため Docker をマルチユーザ環境で使用すると, 他ユーザのコンテナへアクセスができるなどセキュリティの問題がある。\par
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 そこで, 本論文では, Docker と マルチユーザ環境で利用しやすい Linux コンテナである Singularity を利用したコンテナ貸出サービスを提案する。
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
89 このコンテナ貸出サービスでは, Web コンソールからコンテナの操作を行うことで他ユーザのコンテナへの操作をさせない。また, 本コースの類似サービスの課題でもあったデータの永続化を
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
90 Singularity で, 外部リポジトリの利用を Docker の操作を HTTP API で提供することで解消する。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
93 \section{本コースの類似サービス}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
94 本サービスに類似したサービスとして, Docker をラップし複数のユーザで利用することを目的とした ie-docker \cite{ie-docker}, Kubernetes を利用した教育用コンテナ貸出を目的とした, digdog \cite{digdog} がある。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 \subsection{ie-docker}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 ie-docker とは Docker をラップし複数のユーザで利用することのできるコンテナ管理ツールである。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 利用する学生は ssh でブレードサーバへ接続し, ie-docker を使用してコンテナを操作することができる。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 ie-docker は UID 及び GID 情報を取得し他のユーザのコンテナを操作させない。
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
99 またユーザが使える docker の機能を制限する。表\ref{tb:ie-docker}が ie-docker で利用できる機能である。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
100
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
101 \begin{table}[htb]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 \begin{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 \caption{ie-docker のコマンド}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 \begin{tabular}{c|l} \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 ps & 起動中のコンテナの一覧を表示する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 run & コンテナを作成する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 start & コンテナを起動する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 stop & コンテナを停止する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 attach & 起動しているコンテナに attach する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 cp & コンテナにファイルを送信する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 rm & コンテナを削除する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 \end{tabular}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 \label{tb:ie-docker}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 \end{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
115 \end{table}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
116
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 \subsection{digdog}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 digdog とは Kubernetes を利用したコンテナ貸出サービスである。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
119 学生は Dockerfile を GitLab CI/CD を利用して GitLab Registry に Docker イメージを登録する。
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
120 学科アカウントを使用して Web サービスへログインし, 登録した Docker イメージでコンテナを作成することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
121 コンテナ作成時は digdog が Kubernetes に Deployment を設定する。Deployment は学生のアカウント名で作成された Namespace に設定される。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
122 Namespace は RBAC を用いたリソース操作のアクセス制御が設定されている。そのため学生は Kubernetes コマンドである kubectl コマンドで 手元の PC から Pod の操作を行うことができる。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 RBAC で許可されているリソース操作は表\ref{tb:digdog}である。
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
124
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 \begin{table}[htb]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 \begin{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 \caption{kubectl のコマンド}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 \begin{tabular}{c|l} \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 get & Pod の一覧を表示する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 log & Pod の Log を表示する \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 exec & Pod にアクセスする \\ \hline
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 \end{tabular}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 \label{tb:digdog}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 \end{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 \end{table}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
136
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
137
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
138 \section{サービスの設計}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
139 学生が学習環境を利用する流れを図\ref{fig:wm} に示し, 概要を以下で説明する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
140
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
141 \subsection{利用技術}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
142 サービスではコンテナ貸出を行う。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
143 そこで, コンテナ管理ソフトウェアである Docker, コンテナオーケストレーションソフトである Kubernetes, マルチユーザ環境に適した Linux コンテナである Singularity を利用する。\par
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
144 サービスは Docker や Kubernetes のみで提供することもできる。だが, コンテナ内のデータの永続化が問題となる。そのため Singularity を利用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
145 Singularity では デフォルトで \$HOME, /tmp, /proc, /sys, /dev がコンテナにマウントされる。そのため, コンテナのデータの永続化や大量のデータを扱う場合に適している。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
146
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
147 \subsection{コンテナの作成}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
148 学生は学科アカウントで Web コンソールへログインする。Web コンソールでは 学生のコンテナ一覧や Docker イメージ一覧を確認することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
149 コンテナ作成を選択するとコンテナを作成するために必要な情報を入力する。入力する内容は表\ref{tb:wmcon} である。コンテナ名には学生のアカウント名が補完されるため, 他の学生と被ることはない。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
150 Docker イメージは Docker Hub に登録されているイメージや, 作成したイメージを入力することができる。環境変数とゲストポートはスペース区切りで複数入力することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
151 ホストポートは, エフェメラルポート の範囲から設定される。学生は設定されたホストポートを使用してコンテナのサービスへアクセスする。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
152 また, 学生はコンテナに対して Web コンソールから, または手元の PC から操作することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
153 必要なくなったコンテナは Web コンソールのコンテナ一覧から削除することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
154
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
155 \begin{table}[htb]
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
156 \begin{center}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
157 \caption{コンテナ作成時の入力内容}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
158 \begin{tabular}{c|l} \hline
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
159 ContainerName & コンテナ名 \\ \hline
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
160 Image & Docker イメージ \\ \hline
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
161 Environments & コンテナ作成時の環境変数 \\ \hline
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
162 GuestPort & コンテナが使用するポート番号 \\ \hline
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
163 \end{tabular}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
164 \label{tb:wmcon}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
165 \end{center}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
166 \end{table}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
167
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
168 \subsection{イメージの作成}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
169 Docker イメージの作成は学科で利用している GitLab の CI/CD 機能を使用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
170 学生は学科 GitLab から CI/CD トークンを取得し, Web コンソールで取得したトークンをセットする。この時 Docker 側に GitLab Runner の立ち上げを依頼する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
171 トークンの設定後, Web コンソールから CI/CD 用の Yaml ファイルをダウンロードし Dockerfile と一緒に学科 GitLab のリポジトリに Push する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
172 Docker イメージの Build が成功すると Web コンソールのイメージ一覧で確認ができる。作成した Docker イメージは編集からイメージの使い方を記述でき, 他の学生に共有するか設定を行える。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
173 必要なくなったイメージは Web コンソールのイメージ一覧から削除することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
174
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
175 \subsection{Singularity の利用}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
176 Singularity は Docker イメージをSingularity 用に Build することで, Docker イメージを使用することができる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
177 だが, イメージの Build には sudo 権限が必要となる。Docker イメージの Build を申請性にすると, 管理者の仕事が増え, 学生も利用しづらい。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
178 また, Singularity はユーザ権限で動作するため, 学生が ssh でブレードサーバへ接続し利用する方が適している。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
179 そこで, Web コンソールから Singularity 用のイメージをダウンロードできる仕様とする。\par
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
180 学生は利用したいイメージをダウンロードし, ブレードサーバへ送信して Singularity を使用することができる。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
181
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 \begin{figure}[tb]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 \begin{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 \includegraphics[width=80mm]{Images/whalemountain.pdf}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 \end{center}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 \caption{システム構成}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 \label{fig:wm}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 \end{figure}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
190 \section{サービスの実装}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
191 本コースでは ブレードサーバが 4 台導入され, 1 台に 1 つ GPU が搭載されている。コンテナ貸出サービスの機能を 1 つにまとめると Docker の操作が 1台のブレードサーバのみになる。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
192 そこで, 機能ごとに以下の 3 つにサービスに分ける。また, Docker や Kubernetes の操作を HTTP API で提供することで, リクエスト先の変更で複数のブレードサーバにコンテナを分散することができる。\par
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
193 実装にはDocker や Kubernetes の実装言語であり, 操作するためのライブラリが揃っている Go 言語を使用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
194 \begin{itemize}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
195 \item Web コンソールの表示
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
196 \item Docker の操作
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
197 \item Kubernetes の操作
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
198 \end{itemize}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
199
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
200 \subsection{Web コンソールの表示}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
201 実装には Go 言語の Web フレームワークの 1 つである Gin を使用した。
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
203 \subsection{Docker の操作}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
204 実装には Web コンソールと同じ Gin を使用し, Docker の操作を行うための SDK である Docker client \cite{dockercli} を使用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
205 Docker は sock に対して curl コマンドで操作できる HTTP API を提供している。sock だと複数のサーバに対応できないため, Go で HTTP API を実装する。\par
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
206 サービスを提供する上で Docker の必要となる操作は以下である。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
207 \begin{itemize}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
208 \item コンテナの作成
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
209 \item コンテナの削除
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
210 \item コンテナでコマンド実行
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
211 \item コンテナへファイル送信
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
212 \item イメージの削除
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
213 \item GitLab Runner の作成
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
214 \end{itemize}
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
216 コンテナを作成するにあたって必要となるリクエスト情報は以下である。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
217 \begin{itemize}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
218 \item コンテナ名
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
219 \item コンテナ
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
220 \item イメージの削除
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
221 \item GitLab Runner の作成
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
222 \end{itemize}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
223
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
224 \subsection{Kubernetes の操作}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
225 実装には Web コンソールと同じ Gin を使用し, Kubernetes の操作を行うためのライブラリである client-go \cite{kubecli} を使用する。
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
226
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
227 \section{サービスの評価}
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
228
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
229 \section{類似サービスとの評価}
0
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231 %\begin{lstlisting}[frame=lrbt,label=src:example,caption={コード書き方例}]
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 %package main
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 %import "fmt"
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 %func main() {
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 % fmt.Println("Hello, World!!")
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 %}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 %\end{lstlisting}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 \section{今後の課題}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 \section{まとめ}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
244 \nocite{*}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
245 \bibliographystyle{ipsjunsrt}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 \bibliography{mk-wm}
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247
5
ef6f19e8ec75 update tex
Ken Miyahira <e175733@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
248 \end{document}