はじめに
前回はDocker HubからOpen Libertyイメージをpullしてrunしてみましたが、そもそもまずローカル環境で動かしてなかったということでメモレベルですが書き起こしてみました。Eclipseにも開発ツールのプラグインを入れて手元の開発環境を整えます。
前提環境
以下の環境を使っています。
- MacBook Air 使用
- OS: OS X El Capitan
- Java: Oracle Java 1.8.0_151
- Eclipse: Oxygen
手順
Open Libertyを入れる
-
前提となるJavaの確認をします。ここではローカル開発環境としてMacを使用しているため、Oracle Java 8が入っていることが確認できます(IBM JDKは現時点Macに対応していません。Eclipse OpenJ9もやはりMac対応していません。MacどころかWindowsにも対応してなくて、LinuxとAIXのみのようです。。)
-
DLしたディレクトリに移動し、ダウンロードしたZipファイル(ここではopenliberty-17.0.0.3.zip)を展開します。展開したディレクトリを確認すると、wlpというディレクトリができ、その中に展開されていることがわかります。
-
ここで製品版のWebSphere Libertyとはどう違うのかを見てみました。最初にわかるのがbinディレクトリを見ると、製品版には存在するコマンドがいくつかありません。たとえばfeatureManagerとinstallUtilityといったフィーチャーを追加拡張するためのコマンド、configUtilityというWebSphere Liberty Repository から構成スニペットをダウンロードしてくるコマンド、IBM Cloudとの連携のためのbluemixUtilityコマンドが入っていません。ただしIBM Cloudとの連携は、Eclipseプラグインの開発者ツールを入れることで可能になるようです。
-
ちなみにこちらが製品版のbinディレクトリです。管理機能の拡張をしたいなどの話になったら製品版を使ってください、という感じなのでしょう。他にlibディレクトリを見ると入ってるライブラリが一部異なってたりしますが、ここでは割愛します。
-
ランタイムとなるサーバーを作成していきます。以下のコマンドでほぼ瞬時に作成が完了します。
./sever create server1
※ なお「Class JavaLaunchHelper is implemented in both… One of the two will be used. Which one is undefined.」という警告が出るときがありますが、これはJDK 1.7.0_45で発見されたバグで、JDK1.8.152で修正されているようです。詳細はこちらをご参照ください。当環境では諸事情により、JDK1.8.0_151を使用しているためこの警告が出ていますが、問題なく進めます。
7.usr/servers/server1ディレクトリができるので、server.xmlを確認します。デフォルトではJSP 2.3に対応したjsp-2.3フィーチャーが有効化され、エンドポイントのポートとしてhttpは9080、httpsは9443が指定されています。その他、war/earファイルを自動展開機能も有効化されています。
8.server1を起動してみます。
./server start server1
9.JSPが有効になっていますし、とりあえずなんでもいいから動かすスタンスでHello World系を出してみます。/server1ディレクトリの中にdropinsという開発・テスト環境向けな、アプリケーションを追加・更新・削除などの変更が行われると自動的に反映される仕組みのディレクトリがあります。そこでtest.warディレクトリを作成し、test.warディレクトリに移動してから、サンプルとしてtest.jspを作成します。viで書いちゃったので、もはやEclipseすら使ってません。。お決まりのコードなので省略します。
10.ブラウザからアクセスすると、ローカルホストの9080ポートにて作成したJSPが動いていることがわかります。とりあえずOpen Libertyの稼働が確認できました。
11.一旦サーバーを止めておきます。
./server stop server1
Eclipseにプラグインを入れる
-
Eclipseに開発者ツールであるIBM Liberty Developer Tool for Oxgenをインストールし構成を確認します。Eclipse Marketplaceを開いて「liberty」で検索すると以下のような結果となるので選択してインストールします。
-
必要なフィーチャーを選択してConfirmをクリックしてインストールを進めます。最低限「WebSphere Application Server Liberty Tools」があれば事足りますが、ここでは全部入れています。
-
ライセンスに同意して進み、インストールが終わったらEclipseを再起動して完了です。
-
Eclipse上でOpen Libertyサーバーを構成します。作成済みのserver1を使って構成します。まずservers画面で右クリックしNew>Serverで新規作成します。
-
新しいサーバーを定義します。server typeとしてWebSphere Application Server Libertyを選択し、Hostname、Server nameを入力し、Server runtime environmentのAddをクリックしてOpen Libertyの情報を追加します。
-
NameにOpen Liberty(適当)、導入したインストール・パスを入力し、JREはデフォルトのままでFinishをクリックします。
-
元の画面に戻り、Server runtime environmentに追加したOpen Libertyがセットされていることを確認してNextをクリックします。
-
前述の警告が出ますが、問題なくserver1が起動します。またtest.jspのサンプル・アプリケーションもlocalhostで起動したことがわかります。
-
Eclipse内部ブラウザからアクセスして稼働確認します。開発ツールとランタイムを合わせてこれでローカル開発環境の完成です。
まとめ
以上でローカルMacBookで開発環境を整えました。
参考資料
[1] OpenLiberty.io
https://openliberty.io/
[2] GitHub: OpenLiberty Project
https://github.com/OpenLiberty
[3] Docker Hub
https://hub.docker.com/r/openliberty/open-liberty/
[4] Stack Overflow: Open Libertyのタグページ
https://stackoverflow.com/questions/tagged/open-liberty
[5] WASdev.net
https://developer.ibm.com/wasdev/
[6] Eclipse Open J9
https://www.eclipse.org/openj9/