NASDAQも採用進めるリアルタイムJava

杉山貴章(オングス) 2007年07月11日 19時26分

  • このエントリーをはてなブックマークに追加

 この特集では組み込みではないエンタープライズ分野でのリアルタイムの今をお伝えする。第1回目はJavaについてだ。

 1995年に初めてJavaが世に姿を表してからすでに12年が経過した。すでに言語としては安定期に入っており、エンドユーザから見て何かが大きく変わるということは少なくなってきたように思われる。そんな中で今後大きな変化が見込まれる分野のひとつにエンタープライズ・リアルタイム・システムを挙げることができる。リアルタイムといえば元々は組み込み分野が主なターゲットであったが、近年エンタープライズ・システムでもリアルタイム性を要求されるケースが増えてきており、リアルタイムJava仕様が再び注目を浴び始めている。5月に行われたJavaOneでは、NASDAQがオンライン・トレードのシステムにおいてリアルタイムJavaへのマイグレーションを始めていると発表して衝撃をもたらした。

 今回、Sun Microsystemsのソフトウェア・ビジネス総括本部に勤める山口浩氏にインタビューする機会を得、リアルタイムJavaが現在どういう状況にあり、最終的にSunとしてどういう形でこれを活用したいと考えているかなどを話していただいた。

――まず、Javaによるリアルタイム・システム開発のこれまでの経緯と、エンタープライズ分野でそれを活用するにあたってSunがどういう戦略を考えているか教えてください。

 まずJavaによるリアルタイムシステムについて議論され始めたのが1997年頃のことです。その頃はリアルタイム系といったら組み込み分野が主だったわけですが、C言語やアセンブラによる開発はどこかで行き詰まるという指摘から、Javaを使えないかといったことを考えるようになりました。当時のJavaは組み込みに使えるほど性能がよいわけではなかったのですが、この議論を積極的に推し進めたGreg Bollella(当時IBMで働いており、後にSunに移籍)らは性能の問題はいずれ解決できると考えていました。

 実際の仕様はJSR 1(RTSJ: Real-time Specification for Java)として策定されて、最初にリリースされたのが2002年です。ただそのときは組み込みLinuxを対象としていて、Solarisで動かすというようなことは考えていませんでした。それから2003年頃にGreg BollellaがSun Labで始めたのがProject Mackinac(プロジェクト・マキノ)で、これはSolarisのような汎用OSの上で通常のJavaプログラムとリアルタイムのJavaプログラムを同時に動かそうというものでした。

 リアルタイム性が要求されるアプリケーションとはいえ、全てをリアルタイムJavaで記述するのは困難で、部分的にはリアルタイムでなくてもいいところがあるわけです。Javaならばリアルタイム・プログラムとそうでないプログラムを全て共通のプラットフォーム上でスマートに記述することができます。

 一方でSolarisですが、これはバージョン7か8の頃にリアルタイムOSとして使用できるように内部の仕組みを作り替えました。具体的にはリアルタイムクラスというのが用意されていて、これはシステムクラスよりも高いプライオリティで動作します。通常はリアルタイムで動くスレッドというのは無いのですが、リアルタイムOSとして使いたい場合にはこの部分のプライオリティを利用すれば、システムに邪魔されないスレッドを実行することができるわけです。

 Project Mackinacではこれを利用して通常のJavaプログラムとリアルタイムのJavaプログラムの共存を実現しようとしました。実際にこの実装がSun Java Real-Time System(Java RTS)としてリリースされたのが2005年です。Greg BollellaはProject Mackinacを進めるにあたって「リアルタイムについては我々に任せなさい。あなた方はその上で何を書けばいいかを考えなさい」というようなことを言っています。つまりリアルタイム性についてはRTSで保証するから、開発者はその上で自分の目的とするJavaアプリケーションを書けばいいということです。

――それはRTSJとJava SEを同時に使ってもいいということでしょうか。

 RTSJというのはJava SEとは独立した仕様ですが、SEと同居しては駄目というわけでもないんですね。Project MackinacではSEの上にリアルタイムJavaを載せることで、両者を同時に利用しても矛盾が生じないようにしました。これによって、通常の部分はJava SEのAPIを使って書けば通常のスレッドとして動作し、リアルタイム性が要求される部分はRTSJを使って書けばリアルタイム・スレッドとして動作するというようになっています。

 このようなことが可能になると、エンタープライズ向けの大規模なアプリケーションでもリアルタイムクラスを利用できるようになるわけです。逆にリアルタイムクラスのみしか使えない環境では、エンタープライズ・アプリケーションを作るのは非常に大変です。現在リアルタイムタイムJavaがエンタープライズ分野で注目されている理由はこういう点にあると思います。

 2年前にリリースされたSun Java Real-Time System 1.0はJ2SE 1.4ベースでプラットフォームもSPRAC版のSolarisのみでした。現在は2.0の開発が進められていて、こちらはJ2SE 5.0ベースで、SPARC版とx86版の両方のSolaris 10をサポートします。RTSJはバージョン1.0.2準拠となります。またリアルタイムGCも強化されています。2.0はもう間もなく製品版(GA)がリリースされる予定です。

  • このエントリーをはてなブックマークに追加
関連キーワード
経営

関連ホワイトペーパー

SpecialPR

連載

CIO
ハードから読み解くITトレンド放談
大木豊成「仕事で使うアップルのトリセツ」
研究現場から見たAI
ITは「ひみつ道具」の夢を見る
内製化とユーザー体験の関係
米ZDNet編集長Larryの独り言
今週の明言
「プロジェクトマネジメント」の解き方
田中克己「2020年のIT企業」
松岡功「一言もの申す」
林 雅之「デジタル未来からの手紙」
谷川耕一「エンプラITならこれは知っとけ」
Fintechの正体
内山悟志「IT部門はどこに向かうのか」
情報通信技術の新しい使い方
三国大洋のスクラップブック
大河原克行のエンプラ徒然
コミュニケーション
情報系システム最適化
モバイル
通信のゆくえを追う
セキュリティ
企業セキュリティの歩き方
サイバーセキュリティ未来考
セキュリティの論点
ネットワークセキュリティ
スペシャル
Gartner Symposium
企業決算
ソフトウェア開発パラダイムの進化
座談会@ZDNet
Dr.津田のクラウドトップガン対談
CSIRT座談会--バンダイナムコや大成建設、DeNAに聞く
創造的破壊を--次世代SIer座談会
「SD-WAN」の現在
展望2017
IBM World of Watson
de:code
Sapphire Now
VMworld
Microsoft WPC
HPE Discover
Oracle OpenWorld
Dell EMC World
AWS re:Invent
AWS Summit
PTC LiveWorx
古賀政純「Dockerがもたらすビジネス変革」
さとうなおきの「週刊Azureなう」
誰もが開発者になる時代 ~業務システム開発の現場を行く~
中国ビジネス四方山話
より賢く活用するためのOSS最新動向
「Windows 10」法人導入の手引き
Windows Server 2003サポート終了へ秒読み
米株式動向
実践ビッグデータ
日本株展望
ベトナムでビジネス
アジアのIT
10の事情
エンタープライズトレンド
クラウドと仮想化