長く運用するサーバーは仮想マシンにしておこう

新年早々、オンプレで運用しているサーバーが動かなくなってしまいました。このサーバーで運用しているサービスは以下の通りです。

  • JIRA(Issue管理)
  • Confluence(Wiki)
  • BitBucket(Git)

つまり、開発を支えている基幹サーバーが動かなくなってしまったということです。いつもなら、サービスを再起動すれば動き出すのですが、今回は、何度、再起動しても動き出しませんでした。

原因は?

原因はメモリ不足です。このサーバーは実機ではなく、VMware上で動かしている仮想サーバーです。仮想マシンに割り当てているメモリは5GB。以前は4GBで十分だったのですが、有るときから4GBでは起動しなくなり、5GBに増やして運用していました。しかし、扱うデータ量が増えたことやサービスのバージョンアップなどにより必要なメモリ量が増え、耐えられなくなってしまったようです。
ログにも時折、メモリ不足を意味するログが出力されていました。特に、ここ2日間はConfluenceが突然終了するということが起きていました。

ホストマシンを変更する

割り当てメモリを増やしたいところですが、VMwareを動かしているマシンは8GBしか積んでいません。増設もできないマシンです。そのため、仮想サーバーを動かすマシンを変更するほか有りません。
そこで、別のマシンに移動し、割り当てメモリを8GBに増やしました。すると、動かなかったらサービスが動き出しました。

仮想サーバーであることのメリット

今回は、サービスを動かしているサーバーが、仮想マシンで良かったと思いました。サーバーを動かすマシンを変更するときに、仮想マシンファイルをコピーするだけで、物理マシンを移行することが出来ました。
これが実機に直接インストールしたサーバーだったら、必要データをバックアップし、移行先のサーバーにOSをインストール、サービスをインストール、データを復元などの作業が必要になります。OSにインストールされたコンポーネントのバージョン違いなどに煩わされることもありません。
マシンの移行に必要な時間は実質、仮想マシンファイルのコピー時間だけでした。容量は81GB、ネットワーク越しにWi-Fi環境でコピーしましたが、1時間ちょっとで終わりました。そして。サーバーは移行先のマシン上で無事、動き出しました。
 

投稿者プロフィール

林 晃
林 晃macOS/iOSアプリ/SDK/ミドルウェア開発が専門の開発者
アールケー開発代表。macOS/iOSアプリ/SDK/ミドルウェア開発が専門の開発者。ObjC/Swift/C++使い。豊富な開発実務経験を基に、教育コンテンツ開発、技術書執筆、技術指導、技術セミナー講師、企業内研修講師、行政・自治体職員研修講師も行います。

基礎から学ぶMetal


「基礎から学ぶMetal」を執筆しました。本書はMetalを使ってGPUプログラミングを行うための最初のステップを解説するMetalの解説書です。

私が初めてGPUプログラミングを行ったとき、どこから手をつけて、学んでいけば良いのか分からず呆然としました。もし、あのとき、これを教えてくれればという部分を解説しました。本書で解説している部分はMetalの基礎となる部分で、Metalを使うときに必ず触れることになる部分です。

詳細

基礎から学ぶSwiftUI


「基礎から学ぶ SwiftUI」というタイトルの本を執筆しました。

SwiftUIの入門書です。

SwiftUIのコンセプトは「ユーザーインターフェイスを作るための最短パスを提供する」「一度学べば(Appleのプラットフォームの)どこにでも適用できる」です。

SwiftUIの概要から始まって、一つ一つのテクノロジートピックに注目しながらSwiftUIとは何か?どんなことができるのか?どのようなコードを書けば良いのかなどを丸々一冊使って解説しています。

詳細

最近の著書

  1. 基礎から学ぶ SwiftUI

最近の記事