[an error occurred while processing this directive]
qjailでサーバ内にもういっこサーバを作ってみました。(その3)

第207日目:qjailでサーバ内にもういっこサーバを作ってみました。(その3)

どうも、▲('A`)です。
えーと、まずはお知らせを。
昨日弊社(BIG-server.com)で新しい日記がスタートしました。
あぶらみの屋根裏部屋
という日記です。
この日記でも何度か登場していますあぶらみ君( `э´)が執筆しています。
ホットなサーバの開発に関する事がこれからどしどし書かれると思いますので、
注目して下さい。

こちらでは、相変わらずの調子で▲('A`)がゆるゆるとやっています。
今朝は札幌はとても冷え込んでました。(新札幌周辺は朝の6時で0℃でした。)
久々に吐く息が白かったです。
来週の週間予報では火曜か水曜に雪が降るそうです。
五十肩と脳梗塞の身には辛い季節がやってきましたよ。
あ、そうだ、今日は午後から病院行かなきゃ。

前回の日記に続き今回もqjailについてのお話しです。
えーと、前回仮想ホストdokuo01を作りまして、早速Apacheとかqmailとかインストールを
試みたのですが、ちょっと幾つかインストールの途中でコケまして・・・
気付いた事を書きます、ハイ。

まず、デフォルトのqjailですと、仮想ホストの雛型でそのまま作ると
インストール時にエラーになる事があります。
特にportsでソースからインストールする際に発生します。
例として、qmailとMySQLをあげますね。
まずはqmailをインストールする際に出たエラーです。
/usr/sbinにはsendmailのラッパーへのリンクがあります。
FreeBSDのデフォルトではこんな風になっているのです。
lrwxr-xr-x 1 root wheel 21 Oct 13 10:22 /usr/sbin/sendmail -> /usr/sbin/mailwrapper -r-xr-xr-x 1 root wheel 7752 Oct 13 10:22 mailwrapper
qmailをインストールすると、こうなります。
lrwxr-xr-x 1 root wheel 23 Oct 17 20:17 sendmail -> /var/qmail/bin/sendmail

で、qmailをインストールすると、一般的にqmailで作られたラッパーにリンクを
貼り直すのですが、/usr/sbinが書き込みできない状態なので、前のリンクを
消せません。なので、置き換えられなかった、と。

次にMySQLです。
▲('A`)の場合、MySQLはsjis・ujisに対応できる様にする為、ports(ソース)から
インストールしています。
で、インストールの際にportsのディレクトリにworkディレクトリを生成しようと
するのですが、これまた/usr/portsが書き込みできない状態なので、
こんなエラーが出て止まります。
===> p5-DBD-mysql50-4.013 depends on file: /usr/local/bin/perl5.10.1 - found mkdir: /basejail/usr/ports/databases/p5-DBD-mysql50/work: Read-only file system *** Error code 1

で、どうしてこんな現象が起きるかと言いますと、前回の日記で書いた通り
portsの上位のディレクトリ(/usr)が割り当てられている場所が
リードオンリー(ro)になっているからです。
banana3237# cat /usr/local/etc/fstab.qjail.dokuo01
/hd/jails/basejail /hd/jails/dokuo01/basejail nullfs ro 0 0
banana3237#

[仮想ホストdokuo01の各ディレクトリ]
banana3237# ls -l /hd/jails/dokuo01/
total 29
-rw-r--r-- 1 root wheel 798 Oct 15 18:44 .cshrc
-rw-r--r-- 2 root wheel 265 Oct 15 18:44 .profile
-r--r--r-- 1 root wheel 6206 Oct 15 18:44 COPYRIGHT
drwxr-xr-x 8 root wheel 512 Oct 13 03:20 basejail
lrwxr-xr-x 1 root wheel 13 Oct 15 18:44 bin -> /basejail/bin
lrwxr-xr-x 1 root wheel 14 Oct 15 18:44 boot -> /basejail/boot
dr-xr-xr-x 6 root wheel 512 Oct 15 18:53 dev
drwxr-xr-x 20 root wheel 2048 Oct 15 18:58 etc
lrwxr-xr-x 1 root wheel 8 Oct 15 18:50 home -> usr/home
lrwxr-xr-x 1 root wheel 13 Oct 15 18:44 lib -> /basejail/lib
lrwxr-xr-x 1 root wheel 17 Oct 15 18:44 libexec -> /basejail/libexec
drwxr-xr-x 2 root wheel 512 Oct 15 18:44 media
drwxr-xr-x 2 root wheel 512 Oct 15 18:44 mnt
dr-xr-xr-x 1 root wheel 0 Oct 15 19:02 proc
drwxr-xr-x 2 root wheel 512 Oct 15 18:50 root
lrwxr-xr-x 1 root wheel 14 Oct 15 18:44 sbin -> /basejail/sbin
lrwxr-xr-x 1 root wheel 11 Oct 15 18:44 sys -> usr/src/sys
drwxrwxrwt 7 root wheel 512 Oct 15 18:54 tmp
drwxr-xr-x 4 root wheel 512 Oct 15 18:50 usr
drwxr-xr-x 21 root wheel 512 Oct 15 18:53 var
banana3237#
[仮想ホストdokuo01の/usrディレクトリの中]
banana3237# ls -l /hd/jails/dokuo01/
total 4
lrwxr-xr-x 1 root wheel 17 Oct 15 18:44 bin -> /basejail/usr/bin
drwxr-xr-x 4 root wheel 512 Oct 15 18:58 home
lrwxr-xr-x 1 root wheel 21 Oct 15 18:44 include -> /basejail/usr/include
lrwxr-xr-x 1 root wheel 17 Oct 15 18:44 lib -> /basejail/usr/lib
lrwxr-xr-x 1 root wheel 19 Oct 15 18:44 lib32 -> /basejail/usr/lib32
lrwxr-xr-x 1 root wheel 21 Oct 15 18:44 libdata -> /basejail/usr/libdata
lrwxr-xr-x 1 root wheel 21 Oct 15 18:44 libexec -> /basejail/usr/libexec
drwxr-xr-x 3 root wheel 512 Oct 15 18:44 local
lrwxr-xr-x 1 root wheel 19 Oct 15 18:44 ports -> /basejail/usr/ports
lrwxr-xr-x 1 root wheel 18 Oct 15 18:44 sbin -> /basejail/usr/sbin
lrwxr-xr-x 1 root wheel 19 Oct 15 18:44 share -> /basejail/usr/share
lrwxr-xr-x 1 root wheel 17 Oct 15 18:44 src -> /basejail/usr/src
banana3237#

えーと、これを解決するには、事前に/usr/local/etc/fstab.qjail.dokuo01を
親ホスト上で修正して書き込みもできる様にしておくか、jailの雛型(/hd/jails/newjail/)内の
usrディレクトリを修正しておくと良いです。
(▲('A`)の場合にはfstab.qjail.dokuo01の方をro -> rw に直しました。)

で、直したら、もう一度仮想ホストを作り直して、qjailを再起動します。

そうだ、仮想ホストを削除したい時には、以下のコマンドを実行します。
qjail stop dokuo02
大切なのは仮想ホストを動かしている場合には事前に停止させる必要です。
仮想ホストを動かしたままで、deleteコマンドを実行しても、消えません。
注意して下さい。

で、それから以下のコマンドを実行です。
qjail delete dokuo02
ただ、このコマンドを実行すると、今まで作った仮想ホストの中身はサクッと
消えて本当に無くなりますので、覚悟しておいて下さい。


ここまで色々やってみましたが、jailでの仮想化を進める上で、親ホスト側で
仮想ホストにどこまでの処理を許可してあげるか事前に考えてあげる必要が
あるでしょう。

仮想ホスト上で色々とソフトウェアをインストールするのを許すなら、
更新先のディレクトリを書き込み可能に予め親ホスト側で設定して
あげないといけません。

一方、仮想ホストのユーザに予め決めておいたサービスのみを使わせるのなら、
雛型を直す必要もないでしょう。

でもね、もしも仮想ホスト上でカーネル再構築とかもしたい、別のバージョンの
OSを入れたいという場合には、どっちにしても親ホスト側で作業してあげないと
いけない訳です。

で、今は何をしているかと言いますと、仮想ホストdokuo02 いうのを作ってみて、
こいつでは別のバージョンのFreeBSDで動かそうかな、と色々やっているところです。
ちなみに親ホストはFreeBSD 8.1R amd64ですので、まずは8.1R i386を動かして
みようと。

ただ、何故か親ホスト上でworldやカーネルの再構築処理(buildworld、buildkernel)を
走らせると、とてもとても時間がかかっています。
まあ、ちょっと古くなったサーバですじ、HDDもコタコタになってるかもしれませんが、
ちょっと気長に処理が終わるのを待ってあげないといけない、かもです。

今回の日記はちょっと短めですが、これで終わります。
ちょっと今日はこれから病院に行ってきますので、それでは、また。▲('A`)/

【追記 10/25 18:00】
えーと、qjailで親ホストと違うOSを入れるのを挑戦していましたが、
どうもうまく動きません。
qjail本体をインストールした際に入れ込んだOSバージョンで仮想ホストを
動かす様になっている様な動きです。
なので、仮想ホスト内のbinとかboot、lib等を差し替えても、変わりが
ありません・・・・
ちょっと気長に色々やってみます。
googleさんで調べても出てこないんですよねえ・・・トホホです。
それでは、また。

206日目に戻る。   208日目に続く。

目次に戻る
1日目 2日目 3日目 4日目 5日目 6日目 7日目
8日目 9日目 10日目 11日目 12日目 13日目 14日目
15日目 16日目 17日目 18日目 19日目 20日目 21日目
22日目 23日目 24日目 25日目 26日目 27日目 28日目
29日目 30日目 31日目 32日目 33日目 34日目 35日目
36日目 37日目 38日目 39日目 40日目 41日目 42日目
43日目 44日目 45日目 46日目 47日目 48日目 49日目
50日目 51日目 52日目 53日目 54日目 55日目 56日目
57日目 58日目 59日目 60日目 61日目 62日目 63日目
64日目 65日目 66日目 67日目 68日目 69日目 70日目
71日目 72日目 73日目 74日目 75日目 76日目 77日目
78日目 79日目 80日目 81日目 82日目 83日目 84日目
85日目 86日目 87日目 88日目 89日目 90日目 91日目
92日目 93日目 94日目 95日目 96日目 97日目 98日目
99日目 100日目 101日目 102日目 103日目 104日目 105日目
106日目 107日目 108日目 109日目 110日目 111日目 112日目
113日目 114日目 115日目 116日目 117日目 118日目 119日目
120日目 121日目 122日目 123日目 124日目 125日目 126日目
127日目 128日目 129日目 130日目 131日目 132日目 133日目
134日目 135日目 136日目 137日目 138日目 139日目 140日目
141日目 142日目 143日目 144日目 145日目 146日目 147日目
148日目 149日目 150日目 151日目 152日目 153日目 154日目
155日目 156日目 157日目 158日目 159日目 160日目 161日目
162日目 163日目 164日目 165日目 166日目 167日目 168日目
169日目 170日目 171日目 172日目 173日目 174日目 175日目
176日目 177日目 178日目 179日目 180日目 181日目 182日目
183日目 184日目 185日目 186日目 187日目 188日目 189日目
190日目 191日目 192日目 193日目 194日目 195日目 196日目
197日目 198日目 199日目 200日目 201日目 202日目 203日目
204日目 205日目 206日目 207日目 208日目 209日目 210日目
211日目 212日目 213日目 214日目 215日目 216日目 217日目
218日目 219日目 220日目 221日目 222日目 223日目 224日目
225日目 226日目 227日目 228日目 229日目 230日目 231日目
232日目 233日目 234日目 235日目 236日目 237日目 238日目
239日目 240日目 241日目 242日目 243日目 244日目 245日目
246日目 247日目 248日目 249日目 250日目 251日目 252日目
253日目 254日目 255日目 256日目 257日目 258日目 259日目
260日目 261日目 262日目 263日目 264日目 265日目 266日目
267日目 268日目 269日目 270日目 271日目 272日目 273日目
274日目 275日目 276日目 277日目 278日目 279日目 280日目
281日目 282日目 283日目 284日目 285日目 286日目 287日目
288日目 289日目 290日目 291日目 292日目 293日目 294日目
295日目 296日目 297日目 298日目 299日目 300日目 301日目
302日目 303日目 304日目 305日目 306日目 307日目 308日目
309日目 310日目 311日目 312日目 313日目 314日目 315日目
316日目 317日目 318日目 319日目 320日目 321日目 322日目
323日目 324日目 325日目 326日目 327日目 328日目 329日目
330日目 331日目 332日目 333日目 334日目 335日目 336日目
337日目 338日目 339日目 340日目 341日目 342日目 343日目
344日目 345日目 346日目 347日目 348日目 349日目 350日目
351日目 352日目 353日目 354日目 355日目 356日目 357日目
358日目 359日目 360日目 361日目 362日目 363日目 364日目

いま一番お得なページ! 解析
[an error occurred while processing this directive]