Zend_Queue-Adapters.xml 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.queue.adapters">
  5. <title>アダプタ</title>
  6. <para>
  7. <classname>Zend_Queue</classname>は、
  8. インターフェース<classname>Zend_Queue_Adapter_AdapterInterface</classname>を実装する
  9. すべての待ち行列をサポートします。
  10. 以下のメッセージ待ち行列サービスがサポートされます:
  11. </para>
  12. <itemizedlist>
  13. <listitem>
  14. <para>
  15. <ulink url="http://activemq.apache.org/">Apache ActiveMQ</ulink>.
  16. </para>
  17. </listitem>
  18. <listitem>
  19. <para>
  20. <classname>Zend_Db</classname>を経たデータベースによる待ち行列
  21. </para>
  22. </listitem>
  23. <listitem>
  24. <para>
  25. <classname>Memcache</classname>による
  26. <ulink url="http://memcachedb.org/memcacheq/">MemcacheQ</ulink>待ち行列
  27. </para>
  28. </listitem>
  29. <listitem>
  30. <para>
  31. <ulink url="http://www.zend.co.jp/product/zendplatform.html">Zend Platform</ulink>
  32. のジョブキュー。
  33. </para>
  34. </listitem>
  35. <listitem>
  36. <para>
  37. 内部配列。ユニットテストに役立ちます。
  38. </para>
  39. </listitem>
  40. </itemizedlist>
  41. <note id="zend.queue.adapters.limitations">
  42. <title>限定事項</title>
  43. <para>
  44. メッセージ・トランザクション処理は、サポートされません。
  45. </para>
  46. </note>
  47. <sect2 id="zend.queue.adapters.configuration">
  48. <title>固有のアダプタ - 設定の構成</title>
  49. <para>
  50. デフォルトの設定が示される場合は、パラメータは任意です。
  51. デフォルトの設定が指定されない場合は、パラメータが必要です。
  52. </para>
  53. <sect3 id="zend.queue.adapters.configuration.activemq">
  54. <title>Apache ActiveMQ - Zend_Queue_Adapter_Activemq</title>
  55. <para>
  56. ここでリストされたオプションは、既知の必須条件です。
  57. すべてのメッセージ発信サーバが、
  58. ユーザー名またはパスワードを必要とするというわけではありません。
  59. </para>
  60. <itemizedlist>
  61. <listitem>
  62. <para>
  63. <emphasis>$options['name'] = '/temp/queue1';</emphasis>
  64. </para>
  65. <para>
  66. これは、使い始めたい待ち行列の名前です。(必須)
  67. </para>
  68. </listitem>
  69. <listitem>
  70. <para>
  71. <emphasis>$options['driverOptions']['host'] = 'host.domain.tld';</emphasis>
  72. </para>
  73. <para>
  74. <emphasis>$options['driverOptions']['host'] = '127.0.0.1';</emphasis>
  75. </para>
  76. <para>
  77. ホストをIPアドレスまたはホスト名にセットするかもしれません。
  78. </para>
  79. <para>
  80. ホストのデフォルトの設定は '127.0.0.1' です。
  81. </para>
  82. </listitem>
  83. <listitem>
  84. <para>
  85. <emphasis>$options['driverOptions']['port'] = 61613;</emphasis>
  86. </para>
  87. <para>ポートのデフォルトの設定は 61613 です。</para>
  88. </listitem>
  89. <listitem>
  90. <para>
  91. <emphasis>$options['driverOptions']['username'] = 'username';</emphasis>
  92. </para>
  93. <para>
  94. 一部のメッセージ発信サーバのために選択できます。
  95. メッセージ発信サーバのためのマニュアルを読んでください。
  96. </para>
  97. </listitem>
  98. <listitem>
  99. <para>
  100. <emphasis>$options['driverOptions']['password'] = 'password';</emphasis>
  101. </para>
  102. <para>
  103. 一部のメッセージ発信サーバのために選択できます。
  104. メッセージ発信サーバのためのマニュアルを読んでください。
  105. </para>
  106. </listitem>
  107. <listitem>
  108. <para>
  109. <emphasis>$options['driverOptions']['timeout_sec'] = 2;</emphasis>
  110. </para>
  111. <para>
  112. <emphasis>$options['driverOptions']['timeout_usec'] = 0;</emphasis>
  113. </para>
  114. <para>
  115. これは、<classname>Zend_Queue_Adapter_Activemq</classname>がメッセージを返さない前に
  116. ソケットで読み取り活動を待つ時間です。
  117. </para>
  118. </listitem>
  119. </itemizedlist>
  120. </sect3>
  121. <sect3 id="zend.queue.adapters.configuration.Db">
  122. <title>Db - Zend_Queue_Adapter_Db</title>
  123. <para>
  124. ドライバオプションは、多少の必須のオプションのためにチェックされます。
  125. (例えば<emphasis>type</emphasis>、<emphasis>host</emphasis>、<emphasis>username</emphasis>、
  126. <emphasis>password</emphasis>と<emphasis>dbname</emphasis>)
  127. <varname>$options['driverOptions']</varname>でパラメータとして、
  128. <methodname>Zend_DB::factory()</methodname>のために付加パラメータに沿って渡すかもしれません。
  129. ここでは一覧に示されていませんが、
  130. 渡すことができる付加的なオプションは<emphasis>port</emphasis>でしょう。
  131. </para>
  132. <programlisting language="php"><![CDATA[
  133. $options = array(
  134. 'driverOptions' => array(
  135. 'host' => 'db1.domain.tld',
  136. 'username' => 'my_username',
  137. 'password' => 'my_password',
  138. 'dbname' => 'messaging',
  139. 'type' => 'pdo_mysql',
  140. 'port' => 3306, // optional parameter.
  141. ),
  142. 'options' => array(
  143. // 更新のためにZend_Db_Selectを使います。
  144. // 全てのデータベースがこのフィーチャをサポートできるわけではありません。
  145. Zend_Db_Select::FOR_UPDATE => true
  146. )
  147. );
  148. // データベース待ち行列を作成
  149. $queue = new Zend_Queue('Db', $options);
  150. ]]></programlisting>
  151. <itemizedlist>
  152. <listitem>
  153. <para>
  154. <emphasis>$options['name'] = 'queue1';</emphasis>
  155. </para>
  156. <para>
  157. これは、使い始めたい待ち行列の名前です。(必須)
  158. </para>
  159. </listitem>
  160. <listitem>
  161. <para>
  162. <emphasis>$options['driverOptions']['type'] = 'Pdo';</emphasis>
  163. </para>
  164. <para>
  165. <emphasis>type</emphasis>は、
  166. <methodname>Zend_Db::factory()</methodname>を
  167. 使ってもらいたいアダプタです。
  168. これは、<methodname>Zend_Db::factory()</methodname>
  169. クラス・メソッド呼び出しの最初のパラメータです。
  170. </para>
  171. </listitem>
  172. <listitem>
  173. <para>
  174. <emphasis>$options['driverOptions']['host'] = 'host.domain.tld';</emphasis>
  175. </para>
  176. <para>
  177. <emphasis>$options['driverOptions']['host'] = '127.0.0.1';</emphasis>
  178. </para>
  179. <para>ホストをIPアドレスまたはホスト名にセットするかもしれません。</para>
  180. <para>ホストのデフォルトの設定は '127.0.0.1' です。</para>
  181. </listitem>
  182. <listitem>
  183. <para>
  184. <emphasis>$options['driverOptions']['username'] = 'username';</emphasis>
  185. </para>
  186. </listitem>
  187. <listitem>
  188. <para>
  189. <emphasis>$options['driverOptions']['password'] = 'password';</emphasis>
  190. </para>
  191. </listitem>
  192. <listitem>
  193. <para>
  194. <emphasis>$options['driverOptions']['dbname'] = 'dbname';</emphasis>
  195. </para>
  196. <para>
  197. 必須のテーブルを作成したデータベース名。
  198. 下記の注意部分を見てください。
  199. </para>
  200. </listitem>
  201. </itemizedlist>
  202. </sect3>
  203. <sect3 id="zend.queue.adapters.configuration.memcacheq">
  204. <title>MemcacheQ - Zend_Queue_Adapter_Memcacheq</title>
  205. <itemizedlist>
  206. <listitem>
  207. <para>
  208. <emphasis>$options['name'] = 'queue1';</emphasis>
  209. </para>
  210. <para>
  211. これは、使い始めたい待ち行列の名前です。(必須)
  212. </para>
  213. </listitem>
  214. <listitem>
  215. <para>
  216. <emphasis>$options['driverOptions']['host'] = 'host.domain.tld';</emphasis>
  217. </para>
  218. <para>
  219. <emphasis>$options['driverOptions']['host'] = '127.0.0.1;'</emphasis>
  220. </para>
  221. <para>ホストをIPアドレスまたはホスト名にセットするかもしれません。</para>
  222. <para>ホストのデフォルトの設定は '127.0.0.1' です。</para>
  223. </listitem>
  224. <listitem>
  225. <para>
  226. <emphasis>$options['driverOptions']['port'] = 22201;</emphasis>
  227. </para>
  228. <para>ポートのデフォルトの設定は 22201 です。</para>
  229. </listitem>
  230. </itemizedlist>
  231. </sect3>
  232. <sect3 id="zend.queue.adapters.configuration.platformjq">
  233. <title>Zend Platform ジョブキュー - Zend_Queue_Adapter_PlatformJobQueue</title>
  234. <itemizedlist>
  235. <listitem>
  236. <para>
  237. <emphasis>$options['daemonOptions']['host'] = '127.0.0.1:10003';</emphasis>
  238. </para>
  239. <para>
  240. 利用したい Zend Platform ジョブキューデーモンに対応するホスト名とポート。(必須)
  241. </para>
  242. </listitem>
  243. <listitem>
  244. <para>
  245. <emphasis>$options['daemonOptions']['password'] = '1234';</emphasis>
  246. </para>
  247. <para>
  248. Zend Platform ジョブキューデーモンにアクセスするために必要なパスワード。(必須)
  249. </para>
  250. </listitem>
  251. </itemizedlist>
  252. </sect3>
  253. <sect3 id="zend.queue.adapters.configuration.array">
  254. <title>配列 - Zend_Queue_Adapter_Array</title>
  255. <itemizedlist>
  256. <listitem>
  257. <para>
  258. <emphasis>$options['name'] = 'queue1';</emphasis>
  259. </para>
  260. <para>
  261. これは、使い始めたい待ち行列の名前です。(必須)
  262. </para>
  263. </listitem>
  264. </itemizedlist>
  265. </sect3>
  266. </sect2>
  267. <sect2 id="zend.queue.adapters.notes">
  268. <title>アダプタ固有の注意</title>
  269. <para>下記のアダプタには注意があります:</para>
  270. <sect3 id="zend.queue.adapters.notes.activemq">
  271. <title>Apache ActiveMQ</title>
  272. <para>
  273. <classname>Zend_Queue_Adapter_Activemq</classname>のための可視性期間は利用できません。
  274. </para>
  275. <para>
  276. ApacheのActiveMQが複数のサブスクリプションをサポートするのに対して、
  277. <classname>Zend_Queue</classname>はそうしません。
  278. それぞれのサブスクリプションのために
  279. 新しい<classname>Zend_Queue</classname>オブジェクトを作成しなければなりません。
  280. </para>
  281. <para>
  282. ActiveMQの待ち行列または項目の名前は下記のうちの一つで始めなくてはいけません:
  283. </para>
  284. <itemizedlist>
  285. <listitem>
  286. <para>
  287. <filename>/queue/</filename>
  288. </para>
  289. </listitem>
  290. <listitem>
  291. <para>
  292. <filename>/topic/</filename>
  293. </para>
  294. </listitem>
  295. <listitem>
  296. <para>
  297. <filename>/temp-queue/</filename>
  298. </para>
  299. </listitem>
  300. <listitem>
  301. <para>
  302. <filename>/temp-topic/</filename>
  303. </para>
  304. </listitem>
  305. </itemizedlist>
  306. <para>
  307. 例えば: <filename>/queue/testing</filename>
  308. </para>
  309. <para>
  310. 下記の関数はサポートされません:
  311. </para>
  312. <itemizedlist>
  313. <listitem>
  314. <para>
  315. <methodname>create()</methodname> - 待ち行列の作成。
  316. この関数を呼ぶと例外を発生します。
  317. </para>
  318. </listitem>
  319. <listitem>
  320. <para>
  321. <methodname>delete()</methodname> - 待ち行列の削除。
  322. この関数を呼ぶと例外を発生します。
  323. </para>
  324. </listitem>
  325. <listitem>
  326. <para>
  327. <methodname>getQueues()</methodname> - 待ち行列の一覧。
  328. この関数を呼ぶと例外を発生します。
  329. </para>
  330. </listitem>
  331. </itemizedlist>
  332. </sect3>
  333. <sect3 id="zend.queue.adapters.notes.zend_db">
  334. <title>Zend_Db</title>
  335. <para>
  336. データベース<emphasis>CREATE TABLE ( ... )</emphasis> <acronym>SQL</acronym>
  337. 文が<filename>Zend/Queue/Adapter/Db/mysql.sql</filename>にあります。
  338. </para>
  339. </sect3>
  340. <sect3 id="zend.queue.adapters.notes.memcacheQ">
  341. <title>MemcacheQ</title>
  342. <para>
  343. Memcacheは<ulink
  344. url="http://www.danga.com/memcached/">http://www.danga.com/memcached/</ulink>
  345. からダウンロードできます。
  346. </para>
  347. <para>
  348. MemcacheQは<ulink
  349. url="http://memcachedb.org/memcacheq/">http://memcachedb.org/memcacheq/</ulink>
  350. からダウンロードできます。
  351. </para>
  352. <itemizedlist>
  353. <listitem>
  354. <para>
  355. <methodname>deleteMessage()</methodname> -
  356. メッセージは、待ち行列から受信と同時に削除されます。
  357. この関数を呼んでも効果がありません。
  358. この関数を呼ぶとエラーを発生します。
  359. </para>
  360. </listitem>
  361. <listitem>
  362. <para>
  363. <methodname>count()</methodname>または<methodname>count($adapter)</methodname>
  364. - MemcacheQは、待ち行列で件数を数えるためのメソッドをサポートしません。
  365. この関数を呼ぶとエラーを発生します。
  366. </para>
  367. </listitem>
  368. </itemizedlist>
  369. </sect3>
  370. <sect3 id="zend.queue.adapters.notes.platformjq">
  371. <title>Zend Platform ジョブキュー</title>
  372. <para>
  373. ジョブキューは、企業ソリューション商品 Zend Platform のフィーチャーです。
  374. それは伝統的なメッセージキューではなく、その代わりに渡したいパラメータと一緒に、
  375. 実行するスクリプトを待ち行列に入れることができます。
  376. <ulink url="http://www.zend.co.jp/product/zendplatform.html">zend.co.jpウェブサイト</ulink>
  377. でジョブ・キューについてもっと知ることができます。
  378. </para>
  379. <para>
  380. 以下は、このアダプターの動作が標準的な提供物と相違するメソッドの一覧です:
  381. </para>
  382. <itemizedlist>
  383. <listitem>
  384. <para>
  385. <methodname>create()</methodname> - Zend Platformには、
  386. 個別のキューの概念がありません。
  387. その代わりに、管理者が実行段階ジョブにスクリプトを与えることができます。
  388. 新しいスクリプトを加えることは管理画面に制限されるので、
  389. このメソッドは、単にアクションが禁じられていることを示す例外を投げます。
  390. </para>
  391. </listitem>
  392. <listitem>
  393. <para>
  394. <methodname>isExists()</methodname> - <methodname>create()</methodname>
  395. と同様に、ジョブキューには命名されたキューの概念がないので、
  396. このメソッドは呼び出されると例外を投げます。
  397. </para>
  398. </listitem>
  399. <listitem>
  400. <para>
  401. <methodname>delete()</methodname> - <methodname>create()</methodname>
  402. と同様に、管理画面以外ではジョブキューのスクリプトの削除はできません。
  403. このメソッドは、例外を発生します。
  404. </para>
  405. </listitem>
  406. <listitem>
  407. <para>
  408. <methodname>getQueues()</methodname> - Zend Platformは、
  409. <acronym>API</acronym> によってスクリプトを取り扱う、タスク生成されたジョブを参照できません。
  410. このメソッドは、例外を投げます。
  411. </para>
  412. </listitem>
  413. <listitem>
  414. <para>
  415. <methodname>count()</methodname> - ジョブキューで現在アクティブなジョブの
  416. 数を返します。
  417. </para>
  418. </listitem>
  419. <listitem>
  420. <para>
  421. <methodname>send()</methodname> - このメソッドは、恐らく最も他のアダプターと
  422. 異なるメソッドの一つです。<varname>$message</varname>引数は3種類のどれか1つで、
  423. 渡された値によって異なる動作をします。
  424. </para>
  425. <itemizedlist>
  426. <listitem>
  427. <para>
  428. <acronym>string</acronym> - 実行するジョブキューに登録されるスクリプト名
  429. このように渡されると、引数はスクリプトに与えられません。
  430. </para>
  431. </listitem>
  432. <listitem>
  433. <para>
  434. <acronym>array</acronym> - <classname>ZendApi_Job</classname>オブジェクトを
  435. 設定する配列。これらは、以下を含むかもしれません。
  436. </para>
  437. <itemizedlist>
  438. <listitem>
  439. <para>
  440. <varname>script</varname> - 実行するジョブキュースクリプト名
  441. (必須)
  442. </para>
  443. </listitem>
  444. <listitem>
  445. <para>
  446. <varname>priority</varname> - キューに名前を登録するときに使う
  447. ジョブ優先順位
  448. </para>
  449. </listitem>
  450. <listitem>
  451. <para>
  452. <varname>name</varname> - ジョブを記述する短い文字列
  453. </para>
  454. </listitem>
  455. <listitem>
  456. <para>
  457. <varname>predecessor</varname> - これが始まるであろう前に
  458. 実行されなければいけない、これがそれによって左右される
  459. ジョブのID
  460. </para>
  461. </listitem>
  462. <listitem>
  463. <para>
  464. <varname>preserved</varname> - ジョブ・キュー・ヒストリの
  465. 内部でジョブを保持するべきかどうか。デフォルトはoff。
  466. 保持するためには、 <constant>TRUE</constant> を渡します。
  467. </para>
  468. </listitem>
  469. <listitem>
  470. <para>
  471. <varname>user_variables</varname> - ジョブの実行中に、
  472. (命名された引数と同様に)保持したい変数すべての連想配列
  473. </para>
  474. </listitem>
  475. <listitem>
  476. <para>
  477. <varname>interval</varname> - ジョブは、しばしば数秒単位で、
  478. 実行しなければならないでしょう。デフォルトは0で、
  479. 一度だけ実行されることを示します。
  480. </para>
  481. </listitem>
  482. <listitem>
  483. <para>
  484. <varname>end_time</varname> - 期限満了時刻。それを過ぎると
  485. ジョブは動作しません。もしジョブが一回だけ実行するよう設定
  486. されているか、または<varname>end_time</varname>を過ぎると、
  487. ジョブは実行されません。ジョブが一定間隔ごとに実行するように
  488. 設定されている場合、<varname>end_time</varname>を過ぎると
  489. 実行されません。
  490. </para>
  491. </listitem>
  492. <listitem>
  493. <para>
  494. <varname>schedule_time</varname> - いつジョブを実行させるべきかを
  495. 示す<acronym>UNIX</acronym>タイムスタンプ。デフォルトは0で、
  496. ジョブはできるだけ早く実行しなければならないことを示します。
  497. </para>
  498. </listitem>
  499. <listitem>
  500. <para>
  501. <varname>application_id</varname> - ジョブのアプリケーション識別子。
  502. デフォルトは <constant>NULL</constant> で、キューがアプリケーションIDを割り当てられたら、
  503. アプリケーションIDがキューによって自動的に割り当てられることを
  504. 示します。
  505. </para>
  506. </listitem>
  507. </itemizedlist>
  508. <para>
  509. 前述のように、<varname>script</varname>引数のみ必須です。他のすべては、
  510. どのように、そして、いつジョブを走らせるべきかというような、
  511. よりきめ細かい詳細を渡すために利用します。
  512. </para>
  513. </listitem>
  514. <listitem>
  515. <para>
  516. <classname>ZendApi_Job</classname> - 結局、
  517. 単に<classname>ZendApi_Job</classname>のインスタンスを渡すかもしれません。
  518. そして、それはPlatformのジョブキューに一緒に渡されます。
  519. </para>
  520. </listitem>
  521. </itemizedlist>
  522. <para>
  523. <methodname>send()</methodname>は、インスタンスの全てで
  524. <classname>Zend_Queue_Message_PlatformJob</classname>オブジェクトを返します。
  525. そして、ジョブキューと通信するために使う<classname>ZendApi_Job</classname>
  526. オブジェクトへのアクセスを提供します。
  527. </para>
  528. </listitem>
  529. <listitem>
  530. <para>
  531. <methodname>receive()</methodname> - ジョブキューから実行中のジョブのリストを
  532. 取得します。返されたセットの各々のジョブは、
  533. <classname>Zend_Queue_Message_PlatformJob</classname>のインスタンスです。
  534. </para>
  535. </listitem>
  536. <listitem>
  537. <para>
  538. <methodname>deleteMessage()</methodname> - このアダプターはジョブキューだけで
  539. 機能するので、このメソッドは、与えられた<varname>$message</varname>が
  540. <classname>Zend_Queue_Message_PlatformJob</classname>のインスタンスであること
  541. を期待します。
  542. さもなければ例外を発生します。
  543. </para>
  544. </listitem>
  545. </itemizedlist>
  546. </sect3>
  547. <sect3 id="zend.queue.adapters.notes.array">
  548. <title>配列 (内部)</title>
  549. <para>
  550. 配列待ち行列はローカルメモリ上の<acronym>PHP</acronym> <methodname>array()</methodname>です。
  551. <classname>Zend_Queue_Adapter_Array</classname>はユニットテスト用に適しています。
  552. </para>
  553. </sect3>
  554. </sect2>
  555. </sect1>