Libertyの始め方


IBMの開発しているJava EEランタイム,WebSphere Libertyは,オープンソースOpen Libertyとして開発され,どなたでも無償で利用できるようになっています。また,製品版のWebSphere Libertyも,開発者個人で利用する場合は無償で利用できます1

この記事では,Windows 10環境にLibertyを導入し,Eclipseで開発をはじめるまでの手順を紹介します。

Liberty

WebSphere Libertyの導入

導入イメージは,こちらからダウンロードできます。
* https://www.ibm.com/support/pages/websphere-liberty-developers

Windows様にJava SE 8実行環境を含んだWebProfile8のZIPファイルが公開されてるのでこれをダウンロードします。ダウンロードしたら適当なディレクトリに展開します。ここでは,C:\OPTに展開します。

Open Libertyの導入

Open Libertyは,Java実行環境を含んだ導入ファイルは公開されていないので,別途Java実行環境をAdoptOpenJDKなどからダウンロードして導入しておきます。2021年4月現在,Open LibertyではOpenJDK 8や11,16が使用できます。

導入イメージは,こちらからダウンロードできます。
* https://www.openliberty.io/downloads/

パッケージは,全部を含んだ「All GA Features」をダウンロードしておきましょう。こちらも,C:\OPTに展開することにします。

Libertyのディレクトリ構成

C:\OPT
 + wlp
   + bin
   + clients
   + dev
   + lafile
   + lib
   + temlates
   + usr 
     + servers
     | + <server name>
     |   + apps
     |   + dropins
     |   + logs
     |   + workarea
     + shared
       + apps
       + config
       + resources

主なディレクトリの用途は以下の通りです。


wlp/bin

Libertyを操作するコマンド

wlp/dev

Liberty上で稼働するアプリケーションのビルドに必要なJARファイル

wlp/lib

Libertyのランタイム自体を構成するJARファイルや構成ファイル

wlp/usr

ユーザーの作成したサーバー定義やアプリケーション,リソースなど

wlp/usr/servers/<サーバー名>

特定のサーバーで利用される構成やアプリケーション,リソースなど

wlp/usr/shared

複数のサーバーで共有される構成やアプリケーション,リソースなど

serverコマンド

binディレクトリにあるserverコマンドが,サーバーの管理に使うメインのコマンドです。以下の書式で利用します。

server アクション <サーバー名> <オプション>

サーバー名を省略すると「defaultServer」というサーバーをターゲットサーバーに指定したことになります。アクションには以下のようなものがあります。


help
ヘルプを表示します。server help <アクション名>とすると,アクションごとに利用可能なオプションの説明が出ます。

create
サーバーの構成を新規に作成します。

run
サーバーをコンソールのフォアグラウンドで起動します。実行中にキーボードからCtrl+Cを入力すると,サーバーが停止してコマンドラインに戻ります。

start
サーバーをバックグラウンドで起動します。

status
指定されたサーバーの稼働状況を表示します。

stop
サーバーを停止します。

サーバー構成の作成と起動・停止

コマンドラインを起動して一連の流れを実行してみます。serverコマンドが格納されているC:\OPT\wlp\binディレクトリに移動しましょう。システムに既に他にJavaが入っている場合にも,WebSphere Liberty同梱のJavaが使われるように環境変数JAVA_HOMEを設定しておきます。

C:\> cd C:\OPT\wlp\bin
C:\OPT\wlp\bin> set JAVA_HOME=C:\OPT\wlp\java\java

OpenLibertyを使用していて,別途JDKを導入した場合には,その導入ディレクトリを指定します。

サーバーの構成を作成してみましょう。ここではServer01という名前のサーバーを作成します。

C:\OPT\wlp\bin> server create Server01
サーバー Server01 が作成されました。

C:\OPT\wlp\usr\servers\Server01というディレクトリが作成され,必要な構成ファイルが配置されます。メインとなる構成ファイルはserver.xmlというファイルです。Java EE 8.0 Web ProfileのAPIが使用できるように構成されています。

server.xml
<?xml version="1.0" encoding="UTF-8"?>
<server description="new server">

    <!-- Enable features -->
    <featureManager>
        <feature>webProfile-8.0</feature>
    </featureManager>

    <!-- To access this server from a remote client add a host attribute to the following element, e.g. host="*" -->
    <httpEndpoint id="defaultHttpEndpoint"
                  httpPort="9080"
                  httpsPort="9443" />

    <!-- Automatically expand WAR files and EAR files -->
    <applicationManager autoExpand="true"/>

</server>

ダウンロードしたパッケージによっては,ことなるサーバー構成ファイルが作成されている場合があります。その場合は,C:\OPT\wlp\usr\servers\Server01を消去した上で,以下のようにテンプレートを明示的に指定してサーバー構成を作成してください。テンプレートは,C:\OPT\wlp\templateディレクトリのしたにある名前のどれかを指定します。

C:\OPT\wlp\bin> server create Server01 --template=webProfile8
サーバー Server01 が作成されました。

サーバーをフォアグラウンドで起動してみましょう。

C:\OPT\wlp\bin> server run Server01
IBM J9 VM バージョン 8.0.6.25 - pwa6480sr6fp25-20210115_01(SR6 FP25) (ja_JP) で、Server01 (WebSphere Application Server 21.0.0.5/wlp-1.0.52.cl210520210510-1231) を起動しています
[AUDIT   ] CWWKE0001I: サーバー Server01 が起動されました。
[AUDIT   ] CWWKE0100I: この製品は、開発使用向け、および限定的な実動使用向けにライセンスが交付されています。 全ライセンス条項は以下で表示可能です: https://public.dhe.ibm.com/ibmdl/export/pub/software/websphere/wasdev/license/base_ilan/ilan/21.0.0.5/lafiles/ja.html
[AUDIT   ] CWWKZ0058I: アプリケーションの dropins をモニター中です。
[AUDIT   ] CWWKF0012I: サーバーは次のフィーチャーをインストールしました。[appSecurity-2.0, appSecurity-3.0, beanValidation-2.0, cdi-2.0, distributedMap-1.0, ejbLite-3.2, el-3.0, jaspic-1.1, jaxrs-2.1, jaxrsClient-2.1, jdbc-4.2, jndi-1.0, jpa-2.2, jpaContainer-2.2, jsf-2.3, jsonb-1.0, jsonp-1.1, jsp-2.3, managedBeans-1.0, servlet-4.0, ssl-1.0, webProfile-8.0, websocket-1.1]。
[AUDIT   ] CWWKF0011I: Server01 サーバーは、Smarter Planet に対応する準備ができました。Server01 サーバーは 2.123 秒で始 動しました。
[AUDIT   ] CWPKI0820A: デフォルトの鍵ストアは'keystore_password' 環境変数を使用して作成されました。

この状態でブラウザでhttp://localhost:9080にアクセスすると,Libertyが起動していることを確認できます。

起動メッセージに「アプリケーションの dropins をモニター中です」と表示されています。サーバー名のディレクトリにあるdropinsディレクトリに,EARやWARの拡張子を持つJava EEのアプリケーションのファイルを配置すると,自動的にアプリケーションとして認識され,導入と起動がおこなわれます。アプリケーションはEAR/WARのアーカイブファイルをそのまま配置してもいいですし,同名のディレクトリを作成して展開したファイルをおこなうこともできます。

ここで,もう一つコマンドプロンプトを開いて,dropinsの下にディレクトリを作ってみましょう。

C:\> cd C:\OPT\wlp\usr\servers\Server01\dropins

C:\OPT\wlp\usr\servers\Server01\dropins> mkdir test.war

もとのコマンドラインのウィンドウを見ると,以下のようなログが表示されていると思います。ディレクトリをモニターしているLibertyが作成したディレクトリを認識し,アプリケーションとして導入がおこなわれました。

[AUDIT   ] CWWKT0016I: Web アプリケーションが使用可能です (default_host): http://localhost:9080/test/
[AUDIT   ] CWWKZ0001I: アプリケーション test が 3.309 秒で開始しました。

このディレクトリの中にJSPファイルを作ってみましょう。「^Z」の入力は,Ctrl+Zをおした後Enterを入力します。

C:\OPT\wlp\usr\servers\Server01\dropins> cd test.war

C:\OPT\wlp\usr\servers\Server01\dropins\test.war> copy con index.jsp
<html>
<head><title>test page</title></head>
<body>It is <%= new java.util.Date() %> now.</body>
</html>
^Z
        1 個のファイルをコピーしました。

ブラウザでhttp://localhost:9080/test/index.jspにアクセスすると,現在時刻が表示されると思います。

サーバーを停止するには,server runを実行したウィンドウでCtrl+Cを入力します。

[AUDIT   ] CWWKE0085I: JVM が終了するため、サーバー Server01 が停止しています。
[AUDIT   ] CWWKE1100I: サーバーが静止するまで最大 30 秒間待機します。
[AUDIT   ] CWWKT0017I: Web アプリケーションが削除されました (default_host): http://localhost:9080/test/
[AUDIT   ] CWWKZ0009I: アプリケーション test は正常に停止しました。
[AUDIT   ] CWWKE0036I: 6 分, 40.5 秒後にサーバー Server01 が停止しました。
バッチ ジョブを終了しますか (Y/N)? y

C:\OPT\wlp\bin>

Eclipse

OSSのJavaのIDE,Eclipseをダウンロードサイトからダウンロードして導入します。いろいろな種類のパッケージがありますが,Java EEのアプリケーションを開発するので「Eclipse IDE for Enterprise Java and Web Developers」をダウンロードします。

Eclipseは,2021年3月版から自身を実行するJDKを同梱するようになりました。そのため導入や設定が容易になっています。ダウンロードしたZIPファイルをC:\OPT\eclipseディレクトリなどに展開します。展開してできたeclipse.exeを開くとEclipseが起動します。ワークスペースを保存するディレクトリなどを指定して起動が完了すると,Welcome画面が表示されます。Homeボタンを押して通常の画面,ワークベンチにうつります。

Eclipseで,Libertyをつかった開発をおこなうためには,開発者ツールをEclipseのプラグインとして追加する必要があります。プラグインは,Eclipse Marketplaceからダウンロードし導入することができます。メニューのHelpからEclipse Marketplace...を選んでMarketplaceを起動しましょう。

Find欄に「liberty」といれて検索します。IBM Liberty Developer Toolsが見つかるので,Installボタンを押して導入します。

導入するコンポーネントはデフォルトのままで構いません。

使用条件などが表示されるのでAcceptを選ぶと導入がおこなわれます。導入後はEclipseを再起動するように要求されます。再起動すると,Libertyの開発者情報などを含んだWelcomeページが表示されます。閉じてワークベンチに移動します。

開発者ツールを導入すると,Eclipse上にLibertyサーバーを定義できるようになります。Serverのビューからリンクをクリックして新規作成を選びます。

サーバーの種類としてIBMのLibertyが選択できるようになっています。

登録するLibertyは,導入済みのものを指定することもできますし,開発者ツールを使ってWebサイトからダウンロードすることもできます。ここでは,前半で導入したLibertyの環境を利用しましょう。Choose an existing installationを選び,PathにLibertyを導入したディレクトリを指定します。またLibertyの実行に使用するJREを,Libertyに同梱していたものをつかう場合には画面のConfigure JREs...のリンクをクリックします。

Add...を選んでStandard VMを選びます。

JRE homeに,Libertyに同梱されていたJDKのディレクトリを指定し,JRE nameにIBM Java 8などの名前を指定します。

FinishでJREの登録を完了し,PreferencesのページをApply and Closeで閉じます。もとのNew Serverのダイアログボックスにもどったら,Use a specific JREにいま登録したJREを指定してNextボタンを押します。

つぎの画面でLibertyのサーバー構成を選択します。前半で作成したServer01が表示されていると思います。Eclipseの中と外では使うサーバー構成を分けた方が混乱が少ないのでNew...ボタンで新規のサーバー構成を作成します。なまえはEclipse01など適当な名前をつけます。

Finishをおすと,Serverビューに作成したLibertyがあらわれ,操作ができるようになります。右クリックしてStartを選ぶとサーバーが起動します。初回は,Windowsのファイヤーウォールが通信を許可するか尋ねるダイアログボックスが出るかもしれませんので,適宜,アクセスを許可します。

サーバーが正常に起動したことを確認します。

これで,Eclipse上でJava EEのWebプロジェクトやEJBプロジェクトを作成し,Run on ServerでLibertyを選択すれば,Liberty上で実行やテスト,デバッグなどができるようになります。

まとめ

WebSphere LibertyやOpen Libertyをダウンロードし,導入実行するまで。Eclipseを導入し,Libertyのテスト環境を構築するまでをご紹介しました。次回は,Eclipse上でのLibertyの構成のしかたなどについて解説しようかと思います。


  1. 開発用途であっても,複数の開発者が利用するサーバーとして利用する場合には,ライセンスの購入が必要になります。