JP2005174210A - 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム - Google Patents

情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム Download PDF

Info

Publication number
JP2005174210A
JP2005174210A JP2003416617A JP2003416617A JP2005174210A JP 2005174210 A JP2005174210 A JP 2005174210A JP 2003416617 A JP2003416617 A JP 2003416617A JP 2003416617 A JP2003416617 A JP 2003416617A JP 2005174210 A JP2005174210 A JP 2005174210A
Authority
JP
Japan
Prior art keywords
print
job information
job
backup
printing
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2003416617A
Other languages
English (en)
Other versions
JP3854963B2 (ja
Inventor
Nakakatsu Kurotsu
中克 黒津
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Canon Inc filed Critical Canon Inc
Priority to JP2003416617A priority Critical patent/JP3854963B2/ja
Priority to US10/999,922 priority patent/US7916315B2/en
Publication of JP2005174210A publication Critical patent/JP2005174210A/ja
Application granted granted Critical
Publication of JP3854963B2 publication Critical patent/JP3854963B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00127Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture
    • H04N1/00278Connection or combination of a still picture apparatus with another apparatus, e.g. for storage, processing or transmission of still picture signals or of information associated with a still picture with a printing apparatus, e.g. a laser beam printer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/00912Arrangements for controlling a still picture apparatus or components thereof not otherwise provided for
    • H04N1/00915Assigning priority to, or interrupting, a particular operation
    • H04N1/00923Variably assigning priority
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32609Fault detection or counter-measures, e.g. original mis-positioned, shortage of paper
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/32Circuits or arrangements for control or supervision between transmitter and receiver or between image input and image output device, e.g. between a still-image camera and its memory or between a still-image camera and a printer device
    • H04N1/32609Fault detection or counter-measures, e.g. original mis-positioned, shortage of paper
    • H04N1/32646Counter-measures
    • H04N1/32678Performing substitution, e.g. substitute reception or substituting a corrupted line of data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N2201/00Indexing scheme relating to scanning, transmission or reproduction of documents or the like, and to details thereof
    • H04N2201/0008Connection or combination of a still picture apparatus with another apparatus
    • H04N2201/0034Details of the connection, e.g. connector, interface
    • H04N2201/0048Type of connection
    • H04N2201/0049By wire, cable or the like

Abstract

【課題】 印刷装置でエラーが発生した場合にも、効率的かつ効果的な印刷を行なうこと。
【解決手段】 負荷分散印刷を行なうため、実ジョブに対応する仮想ジョブ7'、8'、9'を登録する。実ジョブの送信が開始されると、これらの仮想ジョブを停止状態で保持しておき、プリントデバイスにおいて、実ジョブ9についてエラーが発生すると、プリントキュー701、701A内の仮想ジョブを送信待ち状態にする。プリントデバイスが復旧する前に、仮想ジョブ7'、8'のスケジュールアップがあれば、エラーのあったプリントデバイスでの処理を停止し、実ジョブ9を削除する。仮想ジョブ7'、8'のスケジュールアップがある前にエラーのあったプリントデバイスが復旧し、印刷を完了すれば、仮想ジョブ7'、8'、9'を削除する。
【選択図】 図20

Description

本発明は、複数の印刷装置を効率よく利用するための印刷処理技術に関するものである。
従来から、文書を大量に印刷する必要のある状況において、1つの高速大量印刷装置を使用して大量印刷を行うのではなく、複数の低価格中速印刷装置に印刷負荷を分散し、それら並列に動作させることにより安価に高速印刷を実現する負荷分散印刷システムが存在する。
そして、このように複数の印刷装置を並列に動作させる場合、特定の印刷装置に負荷が偏るという問題があり、この問題を解決するために、複数の印刷装置を効率よく利用するための様々な技術が提案されている(例えば、特許文献1参照)。
特開平06−259206号公報
しかしながら、特許文献1に代表される従来のプリントシステムでは、印刷ジョブを印刷装置に送信した後で、その印刷装置でエラーが発生した場合を考慮していなかった。また、プリントデバイスにエラーが発生した際には、該デバイスに投入済みの印刷ジョブはオペレータの手による復旧を待つまで印刷されないか、或いは、別のデバイスに自動代行される場合には印刷順序が保証されないという問題があった。
本発明は上記従来の課題を解決するためになされたもので、印刷装置でエラーが発生した場合にも、効率的かつ効果的な印刷を行なうことを目的とする。
上記目的を達成するため、本発明に係る装置は、
複数の印刷装置に夫々対応した複数のプリントキューを備える情報処理装置であって、
前記複数のプリントキューに、直接的或いは間接的に印刷データとリンク可能な情報を含むジョブ情報を登録する登録手段と、
プリントキューの空きに応じて最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にし、スケジュールアップしたジョブ情報に基づく印刷ジョブが出力された印刷装置において印刷中断が発生した場合には前記スケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とする手段とを備えることを特徴とする。
前記プリントキューは基本プリントキュー或いはバックアッププリントキューとして機能し、前記登録手段は印刷指示に応じて前記基本プリントキューに印刷ジョブ情報を、前記バックアッププリントキューにバックアッププリント印刷ジョブ情報を、それぞれ登録することを特徴とし、更に、バックアップ印刷ジョブ情報よりも優先された印刷ジョブ情報のスケジュールアップを検知する検知手段と、
スケジュールアップした印刷ジョブ情報に基づく印刷ジョブの印刷装置への出力を行なう出力手段と、
前記印刷装置へ出力された印刷ジョブに対応する印刷ジョブ情報に関連付けられたバックアップ印刷ジョブ情報を、スケジュールアップ対象外にする変更手段と、
印刷装置における印刷中断を認識する認識手段と、
を備え、
前記変更手段は、印刷ジョブの出力先の印刷装置での印刷中断が前記認識手段により認識された場合に、スケジュールアップ対象外とされたバックアップジョブ情報をスケジュールアップ対象に変更することを特徴とする。
前記検知手段は前記印刷中断が検知された印刷装置の復旧を検知し、前記変更手段は、前記検知手段により前記復旧が検知されたことに応じて前記バックアップジョブ情報を再度スケジュールアップの対象外にすることを特徴とする。
前記登録手段は、バックアップ印刷ジョブ情報の登録を、登録順番を付して行なうことを特徴とする。
複数の印刷装置に印刷データを送信可能な情報処理装置であって、
前記複数の印刷装置に対応する複数のプリントキューについて、前記複数のプリントキューのうち、いずれか1つを基本プリントキューとして設定し、前記基本プリントキュー以外のプリントキューをバックアッププリントキューとして設定するプリントキュー設定手段と、
印刷ジョブ情報を前記基本プリントキューに登録する印刷ジョブ登録手段と、
前記基本プリントキューに登録された前記印刷ジョブ情報に対応するバックアップジョブ情報を生成して、出力対象として前記バックアッププリントキューに登録するバックアップジョブ登録手段と、
前記基本プリントキュー及び前記バックアッププリントキューのそれぞれにおいて、印刷ジョブ情報が登録されている場合には、優先的に該印刷ジョブ情報に対応する印刷データを、対応する印刷装置に対して出力し、印刷ジョブ情報が登録されておらず、出力対象のバックアップジョブ情報が登録されている場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始するジョブ制御手段と、
前記基本プリントキュー及び前記バックアッププリントキューにおいて、登録されている前記印刷ジョブ情報及びそれに対応するバックアップジョブ情報のいずれか1つが印刷装置への出力開始の対象となった場合に、出力開始の対象とならなかった前記バックアップジョブ情報を、出力対象ではないバックアップジョブ情報として前記バックアッププリントキューに保持する保持手段と、
前記印刷装置で印刷中断が発生したことを検知する手段と、
を有し、
前記保持手段は、前記印刷装置で印刷中断が発生した場合に、印刷中断の対象となった印刷データに対応するバックアップジョブ情報を、出力対象とすることを特徴とする。
前記ジョブ制御手段は、前記印刷装置の印刷中断が復旧する前に、前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷データに対応するバックアップジョブ情報が出力対象として登録された状態となった場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始し、前記印刷装置において印刷中断対象の印刷データの処理をキャンセルすることを特徴とする。
前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷ジョブ情報に対応するバックアップジョブ情報が出力対象として登録された状態となる前に、前記印刷装置の印刷中断が復旧した場合には、復旧した印刷装置に存在する印刷データの印刷を実行し、印刷完了後、前記保持手段で保持された前記バックアップジョブ情報を削除することを特徴とする。
上記目的を達成するため、本発明に係る方法は、
複数の印刷装置に夫々対応した複数のプリントキューを備える情報処理装置における負荷分散印刷方法であって、
前記複数のプリントキューに、直接的或いは間接的に印刷データとリンク可能な情報を含むジョブ情報を登録する登録ステップと、
プリントキューの空きに応じて最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にし、スケジュールアップしたジョブ情報に基づく印刷ジョブが出力された印刷装置において印刷中断が発生した場合には前記スケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とするステップとを備えることを特徴とする。
前記プリントキューは基本プリントキュー或いはバックアッププリントキューとして機能し、前記登録ステップは印刷指示に応じて前記基本プリントキューに印刷ジョブ情報を、前記バックアッププリントキューにバックアッププリント印刷ジョブ情報を、それぞれ登録することを特徴とし、更に、バックアップ印刷ジョブ情報よりも優先された印刷ジョブ情報のスケジュールアップを検知する検知ステップと、
スケジュールアップした印刷ジョブ情報に基づく印刷ジョブの印刷装置への出力を行なう出力ステップと、
前記印刷装置へ出力された印刷ジョブに対応する印刷ジョブ情報に関連付けられたバックアップ印刷ジョブ情報を、スケジュールアップ対象外にする変更ステップと、
印刷装置における印刷中断を認識する認識ステップと、
を備え、
前記変更ステップは、印刷ジョブの出力先の印刷装置での印刷中断が前記認識ステップにより認識された場合に、スケジュールアップ対象外とされたバックアップジョブ情報をスケジュールアップ対象に変更することを特徴とする。
前記印刷中断が検知された印刷装置の復旧を検知する第2検知ステップと、前記第2検知ステップにおいて前記復旧が検知されたことに応じて前記バックアップジョブ情報を再度スケジュールアップの対象外にする第2変更ステップとを備えることを特徴とする。
前記登録ステップは、バックアップ印刷ジョブ情報の登録を登録順番を付して行なうことを特徴とする。
複数の印刷装置に印刷データを送信することにより負荷を分散して印刷を行なう負荷分散印刷方法であって、
前記複数の印刷装置に対応する複数のプリントキューについて、前記複数のプリントキューのうち、いずれか1つを基本プリントキューとして設定し、前記基本プリントキュー以外のプリントキューをバックアッププリントキューとして設定するプリントキュー設定ステップと、
印刷ジョブ情報を前記基本プリントキューに登録する印刷ジョブ登録ステップと、
前記基本プリントキューに登録された前記印刷ジョブ情報に対応するバックアップジョブ情報を生成して、出力対象として前記バックアッププリントキューに登録するバックアップジョブ登録ステップと、
前記基本プリントキュー及び前記バックアッププリントキューのそれぞれにおいて、印刷ジョブ情報が登録されている場合には、優先的に該印刷ジョブ情報に対応する印刷データを、対応する印刷装置に対して出力し、印刷ジョブ情報が登録されておらず、出力対象のバックアップジョブ情報が登録されている場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始するジョブ制御ステップと、
前記基本プリントキュー及び前記バックアッププリントキューにおいて、登録されている前記印刷ジョブ情報及びそれに対応するバックアップジョブ情報のいずれか1つが印刷装置への出力開始の対象となった場合に、出力開始の対象とならなかった前記バックアップジョブ情報を、出力対象ではないバックアップジョブ情報として前記バックアッププリントキューに保持させる第1保持制御ステップと、
前記印刷装置で印刷中断が発生したことを検知するステップと、
前記印刷装置で印刷中断が発生した場合に、印刷中断の対象となった印刷データに対応するバックアップジョブ情報を、出力対象としてバックアッププリントキューに保持させる第2保持制御ステップと、
を含むことを特徴とする。
前記印刷装置の印刷中断が復旧する前に、前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷データに対応するバックアップジョブ情報が出力対象として登録された状態となった場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始し、前記印刷装置において印刷中断対象の印刷データの処理をキャンセルする第2ジョブ制御ステップを有することを特徴とする。
前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷ジョブ情報に対応するバックアップジョブ情報が出力対象として登録された状態となる前に、前記印刷装置の印刷中断が復旧した場合には、復旧した印刷装置に存在する印刷データの印刷を実行し、印刷完了後、前記第2保持制御ステップで保持された前記バックアップジョブ情報を削除することを特徴とする。
上記目的を達成するため、本発明に係るプログラムは、上記負荷分散印刷方法をコンピュータに実行させる。
上記目的を達成するため、本発明に係る記憶媒体は、上記プログラムをコンピュータ可読の形態で記憶する。
本発明によれば、印刷装置でエラーが発生した場合にも、効率的かつ効果的な印刷を行なうことができる。
以下に、図面を参照して、この発明の好適な実施の形態を例示的に詳しく説明する。ただし、この実施の形態に記載されている構成要素はあくまで例示であり、この発明の範囲をそれらのみに限定する趣旨のものではない。
なお、本明細書において、印刷データとはPDL等で記述された画像データであり、印刷ジョブ情報は、印刷データを出力したいプリンタ、印刷データの格納場所(リンク情報)、及び印刷方法に関する情報であり、印刷ジョブは、印刷データと印刷ジョブ情報とを組み合わせたものである。
[第1実施形態]
<概要>
本実施形態に係るプリントシステムは、特開平06−259206号公報に開示されているシステムと異なり、共有プリントキューをもたず、プリントデバイスに対応するプリントキューのみを備える。そして、複数のプリントデバイスに対応するプリントキューのいずれか1つが基本プリントキューとして設定され、それ以外のプリントキューはバックアッププリントキューとして設定される。本実施形態では、基本プリントキューに対応するプリントデバイスを基本プリントデバイスと称する。また、バックアッププリントキューに対応するプリントデバイスをバックアッププリントデバイスと称する。
プリンタドライバで生成された印刷ジョブの印刷ジョブ情報は、優先的に基本プリントキューに登録され、同時にその印刷ジョブ情報のバックアップとしてのジョブ情報がバックアッププリントキューに生成される。この印刷ジョブ情報に対応するバックアップジョブ情報のことを、本実施形態では仮想ジョブ情報と称し、これと比較する意味で、バックアップを目的としない通常の印刷ジョブ情報を実ジョブ情報と称する。実ジョブ情報は、印刷データの格納場所(リンク情報)を含むが、仮想ジョブは、印刷データとの直接の関連性はなく、その代わりに実ジョブ情報の識別情報(実ジョブID)を含む。これにより、仮想ジョブ情報から実ジョブ情報を導き出すことができる。
バックアッププリントキューを含むすべてのプリントキューは、概念的に実ジョブ情報用のキュー(実ジョブキュー)と仮想ジョブ情報用のキュー(仮想ジョブキュー)に分かれている。ユーザが印刷ジョブの状態を確認するために一般的な方法でプリントキューを参照した場合には、仮想ジョブキューはユーザインタフェースには表示されず、実ジョブキューのみが表示される。従って、ユーザは通常、実ジョブ情報の状態のみを認識可能である。
負荷分散印刷ではない通常の印刷指示があると、印刷指示に対応するプリントキュー内の実ジョブキューに、その印刷指示の内容を含む実ジョブ情報を登録する。そして、実ジョブキュー内の実ジョブ情報は、登録された順序に従ってプリントデバイスへの出力対象となり、その実ジョブ情報に含まれる格納場所(リンク情報)に格納された印刷データを、対応するプリントデバイスへ出力する。プリントデバイスでその印刷データの印刷が完了すれば、対応する実ジョブ情報は実ジョブキューから削除され、次に登録された他の実ジョブ情報が出力対象となる。以下、印刷ジョブ情報をプリントデバイスへの出力開始の対象とすることを、「印刷ジョブ情報をスケジュールアップする」と称する。
一方、負荷分散印刷の指示があると、印刷データと直接的或いは間接的にリンクした印刷ジョブ情報を、複数のプリントキューに登録する。より具体的には、その印刷指示に含まれる印刷ジョブ情報を、その指示によって指定された論理プリンタに対応するプリントキュー内の実ジョブキューに実ジョブ情報として登録し、同じプリントキュー内の仮想ジョブキューにその実ジョブ情報に対応する仮想ジョブ情報を登録する。また、他の全バックアッププリントキュー内の仮想ジョブキューにも、同様に、その実ジョブ情報に対応する仮想ジョブ情報を登録する。
ここで、プリントキュー内の実ジョブキューにおいて、先に登録されたすべての実ジョブ情報が、そのプリントキューに対応するプリントデバイスへの出力されてしまう前に、いずれかのバックアッププリントキュー内の実ジョブキューが空になると、そのバックアッププリントキュー内の仮想ジョブキューに登録された仮想ジョブ情報がスケジュールアップされる。そして、スケジュールアップされた仮想ジョブ情報に対応する実ジョブ情報を、そのバックアッププリントキュー内の実ジョブキューに生成し、元の実ジョブ情報の内容を新たに生成した実ジョブ情報にコピーし、元の実ジョブ情報を削除する。更に、新たな実ジョブ情報に含まれる格納場所(リンク情報)に格納された印刷データを、プリントデバイスに送信する。プリントデバイスでの印刷が完了して、それがシステムに通知されると、印刷が完了した印刷ジョブに対応するすべての実ジョブ情報及び仮想ジョブ情報を削除する。なお、本実施形態では、負荷分散印刷の指示に応じて基本プリントキューに実ジョブ情報を登録する際に、同じ基本プリントキュー内に仮想ジョブ情報も登録することとしたが、前述のように元の実ジョブ情報を削除する際に、同じプリントキュー内に仮想ジョブ情報を登録してもよい。
つまり、負荷分散印刷に対応する印刷ジョブ情報は、一旦基本プリントキューに登録され、その後、最も早いタイミングで印刷可能となった、いずれかのプリントデバイスに送信される。従って、複数の同じ印刷データを重複登録することなく効率的に負荷分散印刷を行うことができる。
また、プリントキューに登録されたジョブ情報を閲覧するユーザインタフェースにおいては、負荷分散印刷指示を行うと、まず、基本プリントキューに印刷ジョブ情報を示すオブジェクトが現われ、その後、最先に印刷可能となったバックアッププリントデバイスのプリントキューにその印刷ジョブ情報が移動して印刷が開始したように見える。即ち、1つの印刷データに対応する印刷ジョブのオブジェクトは1つしか表示されないため、ユーザが混乱することもない。
上記のような負荷分散印刷によって、あるプリントデバイスに印刷データが送信された後、そのプリントデバイスに印刷を実行できない事態(例えばエラー)が発生した場合、エラーが発生したプリントデバイスを含む、すべてのプリントデバイス(基本プリントデバイス及びバックアッププリントデバイス)の仮想ジョブキューに仮想ジョブ情報が残存している。そして、エラーが発生したプリントデバイスが復帰するよりも前に、他のプリントキューのいずれかにおいて、仮想ジョブ情報がスケジュールアップされた場合には、スケジュールアップされた仮想ジョブ情報に対応する新たな実ジョブ情報が実ジョブキューに登録され、元の実ジョブ情報が削除される。そして、新たな実ジョブ情報に含まれる格納場所(リンク情報)に格納された印刷データが、新たな実ジョブキューが登録されたプリントキューに対応するプリントデバイスに送信される。エラーが発生したプリントデバイスの復帰が、他のプリントキューにおける仮想ジョブ情報のスケジュールアップよりも早い場合には、復帰したプリントデバイスで印刷を再開する。そして、復帰したプリントデバイスでの印刷が完了して、それがシステムに通知されると、印刷が完了した印刷ジョブに対応するすべての実ジョブ情報及び仮想ジョブ情報を削除する。
つまり、プリントデバイスでエラーが発生し、出力が中断した印刷データは、エラーが発生したプリントデバイスも含めた全プリントデバイスのうち、エラー発生時点から最も早いタイミングでその印刷データを印刷可能となったいずれかのプリントデバイスにおいて出力される。負荷分散印刷の指示があった時点で登録された仮想ジョブ情報に基づいて、エラー後の代行印刷が行なわれるため、最初からプリントキューへの登録を行なわなくても、エラー発生時にも印刷順序が保証される。
<システム構成>
図1は、本発明の実施形態に係るプリントシステムの全体構成を示すブロック図である。本プリントシステムは、情報処理装置としてのプリントサーバ101と、印刷装置(プリントデバイス)としてのネットワークプリンタ102〜105と、クライアント(コンピュータ)107、108とを含み、これらが互いに接続されていることにより、全体としてネットワークを構成している。
プリントサーバ101には、印刷制御プログラムが実行可能に格納されており、本プリントシステムに含まれるネットワークプリンタ102〜105を管理する機能のほか、ネットワークで使用されるファイルを蓄積したり、ネットワークの使用状態を監視したりする機能を有する。具体的には、プリントサーバ101は、自身により印刷ジョブを作成し、ネットワークプリンタ102〜105に転送する機能と、クライアント107で生成された印刷データを受信し、その印刷データを含む印刷ジョブを生成してスケジューリング処理によりネットワークプリンタ102〜105に転送する機能と、クライアント107、108で作成され、そこにスプールされている印刷ジョブに対してスケジューリング処理を行いクライアント107、108からネットワークプリンタ102〜105に直接印刷ジョブを転送するよう指示する機能とを有する。プリントサーバ101は、必ずしもプリンタの管理に特化したコンピュータである必要はなく、プリント管理機能を備えた汎用のコンピュータであればよく、他のコンピュータとの関係でクライアントとして機能してもよい。
ネットワークプリンタ102〜105は、プリントサーバ101やクライアント107から、印刷データを含む印刷ジョブを受信し、受信した印刷ジョブを解析して印刷する物理的な装置としてのプリントデバイスである。ネットワークプリンタ102〜105としては、電子写真方式を採用したレーザービームプリンタやインクジェット方式を採用したインクジェットプリンタや熱転写方式を利用したプリンタ等、あらゆる方式の印刷装置を採用することができる。
クライアント107、108は、プリントサーバ101との関係でクライアントとして機能するコンピュータである。
なお、本プリントシステムに含まれる装置間の通信は、イーサネット(登録商標)ケーブルなどを利用した有線通信でもよいし、電波や光などを利用した無線通信でもよい。
<プリントサーバ及びクライアントの構成>
図2は、図1に示したプリントサーバ101及びクライアント107、108のハードウェア構成を説明するブロック図である。プリントサーバ101及びクライアント107、108は、ハードウェア構成上、特別な差異はないため、ここでは代表的に、プリントサーバ101の構成について説明する。
図2において、CPU200は、HD(ハードディスク)205に格納されているアプリケーションプログラム、プリンタドライバプログラム、OSや印刷制御プログラム等を読出して実行し、RAM202にプログラムの実行に必要な情報、ファイル等を一時的に格納制御を行うための制御手段である。
ROM201は、基本I/Oプログラム等のプログラム、文書処理の際に使用するフォントデータ、テンプレート用データ等の各種データを記憶する記憶手段である。RAM202は、CPU200の主メモリやワークエリア等として機能する一時記憶手段である。
FD(フロッピー(登録商標)ディスク)ドライブ203は、後述する図5に示すように記憶媒体としてのFD204に記憶されたプログラム等を本コンピュータシステムにロードするための記憶媒体読み込み手段である。
HD205は、大容量メモリとして機能する外部記憶手段であり、アプリケーションプログラム、プリンタドライバプログラム、OS、印刷制御プログラム、及び関係プログラム等を格納している。更に、スプール手段であるスプーラはここに確保される。なお、プリントサーバ101ではスプール手段としてサーバスプーラが確保され、クライアントではスプール手段としてクライアントスプーラが確保される。
キーボード206は、ユーザがプリントサーバ101やクライアント107、108に対して、デバイスの制御コマンドの命令等を入力指示するための指示入力手段である。
ディスプレイ207は、キーボード206から入力したコマンドや、プリンタ102〜105の状態等を表示する表示手段である。なお、実際にはプリントサーバ101及びクライアント107、108上で稼動するオペレーティングシステムを介して表示手段に表示指示がなされ、このオペレーティングシステムに本印刷処理プログラムによりリソースファイルの表示指示が行われ、後述する各表示が実現される。208はシステムバスであり、プリントサーバ101またはクライアント107、108としてのコンピュータ内の、データの流れをつかさどるものである。
またインタフェース209は、入出力手段であり、プリントサーバ101またはクライアント107,108は、インタフェース209を介してネットワーク上の他の装置とのデータのやり取りを行う。
<メモリマップ等の説明>
図3は、図2に示したRAM202のメモリマップの一例を示す図であり、印刷制御プログラムが、RAM202にロードされ実行可能となった状態のメモリマップである。図5は、図2に示したFDドライブ203に対して挿入されるFD204との関係を示す図であり、図2と同一のものには同一の符号を付してある。同図において、FD204には、印刷制御プログラム及び関係データを格納している。
印刷制御プログラム及び関係データは、予めFD204からHD205にインストールされて、HD205からRAM202にロードするようにしてもよいしFD204から直接RAM202にロードして実行させてもよい。更に、印刷制御プログラムをROM201に記憶しておき、これをメモリマップの一部となすように構成し、直接CPU200で実行することも可能である。また、以上の各装置と同等の機能を実現するソフトウェアをもって、ハードウェア装置の代替として構成することもできる。
印刷制御プログラムは、クライアントにおいては、印刷ジョブの印刷先の変更を指示したり、印刷順序を変更したりする指示をするための制御を行う。一方、プリントサーバにおいては、印刷ジョブの順序制御を行ったり、印刷ジョブの印刷終了や印刷先変更要求などを通知したりする。また、印刷制御プログラムは、クライアントにインストールされるモジュールと、プリントサーバにインストールされるモジュールとを別々に含んでいてもよいし、ひとつの印刷制御プログラムが、実行される環境によりクライアント用として機能したり、プリントサーバ用として機能したりするようにしてもよい。あるいは、一台のコンピュータに、クライアント用の機能を持つモジュールとプリントサーバ用として機能するモジュールとをともにインストールし、同時にあるいは時分割で、擬似的に平行動作させる構成も可能である。
301は基本I/Oプログラムを記憶するための領域である。基本I/Oプログラムは、装置(プリントサーバ101またはクライアント107,108)の電源がONされたときに、HD205からOSがRAM202に読み込まれ、OSの動作を開始させるIPL(イニシャルプログラムローデイング)機能などを有しているプログラムである。
302はOS(オペレーティングシステム)を記憶する領域であり、303は印刷制御プログラムを記憶する領域である。304は、関係データを記憶する領域である。305はワークエリアで、CPU200が各種のプログラムを実行するための領域である。
図4は、図2に示したFD204のメモリマップの一例を示す図である。図4において、400はFD204のデータ内容であり、データの情報を示すボリューム情報401と、ディレクトリ情報402と、印刷制御プログラム403と、その関係データ404を含んでいる。
<プリントシステムのソフトウェア構成>
次に、本プリントシステムのソフトウェア構成について説明する。図6Aは、サーバ101あるいはクライアント107,108におけるソフトウェア構成の一例を示す図である。それぞれの構成間の矢印は、アプリケーションから発行された描画コマンドを含む印刷ジョブが、どのように処理されるかを示したものである。また、各ブロックで示されたソフトウェア構成は、図2のCPU200によって実行され、所望の機能を実現する。
通常、Microsoft Word(登録商標)などの一般的なアプリケーションプログラム601は印刷の指示を受け付けると、一連の描画コマンドを、OSを介して生成する。OSを介して生成された描画コマンドを受け取ったPDLドライバ602は、一連の描画コマンドに基づいてネットワークプリンタ102〜104で解釈可能なPDLファイルを含む印刷ジョブを生成する。なお、以下の説明ではPDLドライバを例に説明を行うが、これに限定されるものではなく、例えば、BDL(Band description Language)や、圧縮ビットマップを作成するプリンタドライバ、あるいは、アプリケーション及びOSによりプリンタドライバを介さずに印刷データを生成する形態などにも適用可能であることはいうまでもない。
PDLドライバ602は、プリントデバイスへ印刷ジョブを送信するためにOSが用意したジョブ制御ポートモニタ608ではなく、ジョブ制御ポートモニタ604に送信すべく、生成した印刷ジョブをスプーラ603に渡す。ジョブ制御ポートモニタ604は、ジョブ制御プリントサービス605が印刷データを受け取るために必要なモジュールである。ジョブ制御ポートモニタ608は、ジョブ制御プリントサービスにプリントデータを渡さず、プリントデバイスにデータを転送するモジュールであり、OSに組み込まれている。ジョブ制御ポートモニタ608に印刷ジョブが投入されると、ジョブ制御プリントサービスにジョブが引き継がれず、直接プリントデバイスに印刷ジョブが転送される。
ここではOSをウィンドウズ(登録商標)と仮定しているのでスプーラ603はウィンドウズ(登録商標)スプーラである。ただし、本発明を適用するコンピュータのOSはウィンドウズ(登録商標)に限定されるものではなく、描画命令を備えるものであれば他のOSも適用可能であることはいうまでもない。
スプーラ603は、ユーザがユーザインタフェースを介して選択し指示したポートモニタ604、608に印刷ジョブを渡して、ネットワークプリンタ102〜104等のプリントデバイスに送信させる手順をとる(矢印a)。ここでは、ユーザはあらかじめ負荷分散印刷用のポートモニタ604(以降、ジョブ制御ポートモニタと略記)を指定して印刷を指示したものとして説明を進める。
また、プリンタドライバインタフェースを介して設定された用紙サイズ、ステープル指示等の印刷設定情報も、ジョブ制御ポートモニタ604に送信される。
ジョブ制御ポートモニタ604は、印刷ジョブをそのままプリントデバイス102〜104に送信するのではなく、負荷分散印刷用のプリントサービス605(以降、ジョブ制御プリントサービスと称する)に送信する(矢印b)。
ジョブ制御プリントサービス605は、転送された印刷ジョブ及びデバイスの状態を管理する機能を備える。特にプリントデバイスとデータ転送元とがピアツーピアで接続され直接印刷ジョブをプリントデバイスに投入する場合には、プリントデバイスから通知されるデバイス状態やジョブの状態などの情報を管理したり、また、プリントデバイスに対して所定の命令を行なったりする機能も備える。これは、複数のネットワークプリンタ102〜104のデバイス情報やジョブ情報を管理する機能に相当する。そして、印刷ジョブの順序管理機能(負荷分散印刷機能)に基づき順番が到来した印刷ジョブをネットワークプリンタ102〜104に転送する(矢印c、d)。
ここで、ジョブ制御プリントサービス605が実現する印刷ジョブの順序管理機能について詳しく説明する。この順序管理機能には、以下の機能が含まれる。
・複数のプリントデバイスに対応する複数のプリントキューのうち、負荷分散印刷用として設定されたプリントデバイスに対応するプリントキュー以外のプリントキューをバックアッププリントキューとして設定するプリントキュー設定機能
・ジョブ制御ポートモニタ604から転送された印刷ジョブ情報を負荷分散印刷用プリントキュー(基本プリントキュー)に登録する印刷ジョブ登録機能と、負荷分散印刷用プリントキューに登録された印刷ジョブ情報に対応するバックアップジョブ情報を生成して、バックアッププリントキューに登録するバックアップジョブ登録機能
・負荷分散印刷用プリントキュー及びバックアッププリントキューのそれぞれを管理し、印刷ジョブ情報が登録されているプリントキューにおいては、優先的に印刷ジョブ情報をスケジュールアップ(その印刷ジョブ情報に対応する印刷データを、プリントキューに対応するプリントデバイスに送信)し、送信完了前の印刷ジョブ情報が登録されておらず、バックアップジョブ情報のみが登録されているプリントキューでは、そのバックアップジョブ情報を印刷ジョブ情報に変更して、対応するプリントデバイスに印刷データを送信するジョブ制御機能
・負荷分散印刷用プリントキュー及びバックアッププリントキューにおいて、登録されている印刷ジョブ情報及びそれに対応するバックアップジョブ情報のいずれか1つがプリントデバイスに送信された場合には、送信の対象とならなかった印刷ジョブ情報またはそれに対応するバックアップジョブ情報をすべてのプリントキューから削除する削除機能
プリントマネージャ609は、ユーザが、ジョブ制御プリントサービス605内部でプリントジョブがどのような状態にあるかを調べたり、プリントジョブを操作したりするためのユーザインタフェース(例えば図22参照)を提供するプログラムである。プリントマネージャ609は、ジョブ制御プリントサービス605のソフトウェアのインタフェース(API:Application Program Interface)を介して、ジョブ制御プリントサービス605と情報・指示をやり取りしている。
そして、主に、ジョブ制御プリントサービス605が管理するネットワークプリンタ102〜104の状態情報をイベントとして取得する機能を備える。イベントの通知の種別としては、トナー残量が少なくなった警告、クライアントとデバイスとの通信障害、メモリ不足、排紙トレイ満載などのエラー/警告情報の通知や、エラー状態から正常状態に復帰した正常情報の通知などが想定される。ここでのジョブ制御プリントサービス605はネットワークを介して通信可能な各プリントデバイスの印刷実行中、電力制御状態、障害情報(紙ジャム)等のステータスを監視する機能を備える。
更に詳細な処理としては、プリントマネージャ609がジョブ制御プリントサービス605に対してデバイスを指定したイベントを発行し、ジョブ制御プリントサービス605は発行されたイベントに基づくデバイスのステータスを監視して、監視に基づく結果をプリントマネージャ609に通知する。
マネージメントコンソール610は、ソフトウェアがアクセスするためのAPIを介して、ジョブ制御プリントサービス605と情報・指示をやり取りすることで、サーバ101またはクライアント107,108の全体を監視することができる。
また、ジョブ制御プリントサービス605は、デバイス情報コントロールモジュール606を用いて各ネットワークプリンタ102〜104と通信を行い、各プリンタ内の印刷ジョブや動作状態に関する情報を入手したりする機能を明示したものでありジョブ制御プリントサービス605に含めるように考えても良い。
一方、負荷分散印刷を行なわず、一般的なオペレーティングシステムに標準で搭載されるようなプリント機能を利用する場合においては、PDLプリンタドライバ602で生成されたPDLファイルはスプーラ603からジョブ制御ポートモニタ608をへて(矢印e)、ネットワークプリンタ102〜104に転送される(矢印f)。
次に、図6Aを用いて説明したシステムの変形例について、図6Bを参照して説明する。図6Bは、負荷分散印刷に必要な機能を、クライアント107,108とサーバ101とが分担し、それぞれが協力し合って実現する場合について表わしたものである。具体的には、クライアント107、108で作成し、サーバ101側のプリントキューに登録された印刷ジョブ情報に対し、プリントサーバ101がスケジューリングを行う場合のデータの流れを示している。なお、図6Aと同じ構成は同じ符号で表わしている。
図6Bのシステムでは、クライアント107,108は、マネージメントコンソール610やデバイス情報コントロールモジュール606をもつ必要はなく、サーバ101がそれらを有することにより、一括してプリントデバイスのデバイス情報を管理する。また、サーバ101は、ジョブ制御サーバ612を有し、デバイス情報コントロールモジュール606を用いて各プリントデバイス102〜104と通信を行い、各プリンタ内の印刷ジョブや動作状態に関する情報を入手したり、操作を行ったりする。入手した情報は、ジョブ制御プリントサービス605に渡し共有することができる。
また、ジョブ制御サーバ612は、個々のクライアント107、108上のジョブ制御プリントサービス605がプリントデバイス102〜104に印刷ジョブを送信するタイミングを集中制御(スケジューリング)する。ジョブ制御サーバ612は基本的にジョブ制御プリントサービス605と同様の機能を備えており、論理的にジョブ制御プリントサービス605とジョブ情報を共有している。ここでジョブ情報とは、印刷対象となるドキュメント名や、印刷ジョブのIDや、印刷ジョブが投入されたプリンタ名など、印刷ジョブの各種属性情報である。
つまり、図6Aで説明した、印刷ジョブの順序管理機能(負荷分散印刷制御機能)は図6Bではサーバ101のみに設けられていてもよく、クライアント107,108で生成された一旦保持される印刷ジョブを、どういう順序でどのプリントデバイスへ投入すべきかが、ジョブ制御サーバ612からジョブ制御プリントサービス605に通知される。ジョブ制御プリントサービス605ではジョブ制御サーバ612からの指示に従い、印刷ジョブをネットワークプリンタ102〜104に対して転送する。
以上のソフトウェア構成において、図6Aのプリントシステムでは、ジョブ制御ポートモニタ604、ジョブ制御プリントサービス605、プリントマネージャ609、マネージメントコンソール610が印刷制御プログラムに含まれる。また、図6Bのクライアント107、108では、ジョブ制御ポートモニタ604、ジョブ制御プリントサービス605、プリントマネージャ609が印刷制御プログラムに含まれ、プリントサーバ101では、デバイス情報コントロールモジュール606、マネージメントコンソール610、ジョブ制御サーバ612が印刷制御プログラムに含まれる。
なお、プリントシステムのソフトウェア構成は、図6A、図6Bに限定されるものではなく、その他の様々な構成でも本発明を実現可能である。例えば、クライアントが、アプリケーション601からジョブ制御サポートモニタ604までの構成のみを備え、ジョブ制御プリントサービス605、プリントマネージャ609、マネージメントコンソール610、デバイス情報コントロールモジュール606をサーバ101が備えていてもよい。
<印刷ジョブの流れ>
次に、図7を用いてアプリケーション601からプリントデバイスまでの印刷ジョブの流れについて説明する。ここで、図6Aと同じソフトウェア構成について同じ参照番号を付与しており、その機能については詳説しない。
図7に示すように、概念的には、PDLドライバ602、スプーラ603、ジョブ制御ポートモニタ604は、プリントデバイス102〜104ごとに用意されている。OSがウィンドウズ(登録商標)の場合には、これらをまとめてウィンドウズ(登録商標)プリントシステム700と称する場合もある。
ジョブ制御プリントサービス605には、プリントデバイス102〜104に対応する数のプリントキュー701、701A、701B及び出力ポート702、702A、702Bが含まれている。この出力ポートには対応するプリントデバイスのIPアドレス又は名前解決で使用されるネーム(DNS:Domain Name System)が関連付けられている。そして、このIPアドレス又はDNSに基づきジョブの送信先が特定されジョブの送信(出力)が行なわれる。プリントキューは、ある所定のジョブが投入された1つの基本プリントキュー701と複数のバックアッププリントキュー701A、701Bとに分類されている。なお、本実施形態では、物理的な装置であるプリントデバイス単位にプリントキューを設定することとしているが、本願発明はこれに限定されるものではなく、論理プリンタ単位にプリントキューを設定してもよい。つまり、複数のプリントデバイスに対して1つの論理プリンタを設定して、その論理プリンタについて1つのプリントキューを設定しても良いし、更には、1つのプリントデバイスに対して複数の論理プリンタを設定して、その複数の論理プリンタのそれぞれに対してプリントキューを設定してもよい。
負荷分散印刷を行う場合、アプリケーション601は、負荷分散印刷の設定を持つ論理プリンタを指定して印刷指示を発行する。この印刷指示に基づいてPDLドライバ602によって生成された印刷ジョブがジョブ制御ポートモニタ604からジョブ制御プリントサービス605に渡されると、その印刷ジョブ情報は、まずプリントキュー701に保持され、同時に、その印刷ジョブ情報に対応する仮想ジョブ情報がバックアッププリントキュー701A、701Bに生成される。そして、それらのジョブのうちいずれか1つがプリントデバイス102〜104に送られる。バックアッププリントキューに対応するプリントデバイスは、バックアッププリンタと呼ばれ、ユーザが指定したプリントデバイスが混雑している場合などに利用される予備的なプリントデバイスを指す。
<各種の情報の内容>
I.プリントキューの実ジョブキューと仮想ジョブキュー
図8は、プリントキュー701内の実ジョブキュー801と仮想ジョブキュー802を示す図である。実ジョブキュー及び仮想ジョブキューは、印刷ジョブ情報が、実ジョブ情報または仮想ジョブ情報であることを示す属性情報(1006、1103)を含むことにより、論理的に構築されるものであっても良い。また、実ジョブキュー及び仮想ジョブキューを、別の変数として実態的に構築しても良い。実ジョブキュー801と仮想ジョブキュー802は、負荷分散印刷処理を行う場合に使用する、印刷ジョブ情報を管理するキューである。そして、各論理プリンタ毎に図8に示されるような実ジョブキューと仮想ジョブキューとを含むプリントキューが対応付けられることとなる。また、1つのプリントデバイスに対して論理プリンタが1つの場合には、図8に示されるプリントキューはプリントデバイスに対応するプリントキューに相当することとなる。そしてこのプリントキューがある時は基本プリントキューとなり、ある時はバックアッププリントキューとして機能する。
上述したように、実ジョブ情報は、印刷データそのものは含まないが、スプールファイル名などの印刷データへのリンクを含む印刷ジョブ情報で、実ジョブキューで管理される。また、仮想ジョブ情報は、実ジョブ情報と同様に印刷データを含まず、実ジョブ情報へのリンク(実ジョブ情報のID)を含む。これにより実ジョブ情報に設定された情報を利用することができ、間接的に印刷データとリンクされる。そして、仮想ジョブ情報は、仮想ジョブキューで管理される。
II.プリントキュー情報
図9は、プリントキュー701で受け付けた印刷ジョブの動作を決めるプリントキュー情報を示す図である。ここで、プリントキュー情報の設定内容の、プリンタ名、プリンタドライバ名、プリントタイプ、及びバックアッププリンタ名について説明する。なお、図9の情報は図6Aのようなシステム形態では、ジョブ制御プリントサービス605において保持され、図6Bのようなシステム形態ではジョブ制御プリントサービス605及びジョブ制御サーバ612の双方において共有して保持されるものとする。
プリンタ名は、ウィンドウズ(登録商標)のプリンタオブジェクトの名前を示しており、プリンタオブジェクト毎に異なる名前であり、プリンタオブジェクトを識別することができる。プリンタ名は、厳密に言えば、論理プリンタを特定する文字列であるが、一般的には論理プリンタから物理的なプリントデバイスを特定できるので、結果的に、ここでのプリンタ名がプリントデバイスを特定したものとなる。
プリンタドライバ名は、プリンタオブジェクトに設定されているプリンタドライバの名前である。プリントタイプは、プリントキューで受け付けた印刷ジョブの動作を決定する設定である。バックアッププリンタ名は、負荷分散印刷をする際の負荷分散先となるプリンタオブジェクト(論理プリンタ)の名前である。
III.実ジョブ情報
図10は、プリントキュー701の実ジョブキューに登録される印刷ジョブ情報を示す図である。図10の情報は図9と同様に図6Aのようなシステム形態では、ジョブ制御プリントサービス605において保持され、図6Bのようなシステム形態ではジョブ制御プリントサービス605及びジョブ制御サーバ612の双方において共有して保持される。また、保持される実ジョブ情報は、関連する仮想ジョブ情報がスケジュールアップした場合や、当該実ジョブ情報に対応する印刷ジョブの出力が印刷装置で完了した場合に削除される。
実ジョブは、所定の記憶領域にスプールされた印刷データを含む印刷ジョブであり、出力ポートに送られて実際に転送処理が行われプリンタで出力される印刷ジョブである。実ジョブ情報は、実ジョブに含まれる各種の設定情報であり、プリントキュー701に登録される。
以下、実ジョブ情報の設定内容(ドキュメント名、ジョブID、プリントタイプ、実行タイプ、仮想ジョブID、先頭ジョブマーク、送信済みプリンタリスト)、スプールファイル名について説明する。
ドキュメント名はアプリケーション701が印刷するジョブ(印刷データファイル)の名前である。
図10におけるジョブID1002は実ジョブ情報に割り振られる任意のIDでジョブを識別するためのIDである。プリントキュー701が印刷ジョブを受け付けるとそのジョブにジョブIDを割り当てる。
プリントタイプ1006は、図9と同様であり実ジョブの動作を決定する情報で、負荷分散印刷などの情報が設定される。プリントキュー701が実ジョブ情報を受け付けると、プリントタイプから情報を取得し実ジョブ情報のプリントタイプに設定する。また実ジョブ情報であることを示す属性も含まれている。
実行タイプには、印刷ジョブのタイプを表す情報で、(1)ネットワークプリンタ102〜104でパスワードを入力しなければ印刷できないパスワード入力ジョブ、(2)暗号化されたセキュアジョブ、(3)ネットワークプリンタ102〜104で出力する直前にオフラインになるオフラインジョブ、(4)ネットワークプリンタ102〜104のHDに保存される保存ジョブ、(5)負荷分散印刷などのタイプが設定される。これは、プリンタドライバからジョブのタイプの通知を受け付けたり、アプリケーションからジョブのタイプの通知を受け付けたりした場合に設定する項目である。また、ジョブのタイプを判別し設定する場合もある。また、プリントタイプ1006に含めるようにしても良い。
仮想ジョブID1003は、負荷分散印刷処理を行う場合に作成される仮想ジョブ情報のジョブIDである。複数の仮想ジョブ情報が発生する場合には、仮想ジョブIDは1003〜1005のように複数設定される。
先頭ジョブマークは、ネットワークプリンタ102〜104で管理されている印刷ジョブの先頭を現すマークである。
送信済みプリンタリストは、実ジョブを送信したプリンタの名前を設定するリストである。
スプールファイル名は、アプリケーションデータに基づき作成された印刷データに対応するスプールファイルの名前であり印刷データの格納場所(リンク情報)に相当する。そしてこのスプールファイル名は所定の記憶部に記憶されたスプールファイルを特定するために利用される。スプールファイル名の代わりにスプールファイルIDを採用するようにしても良い。実ジョブ情報に基づくジョブ出力が対応するプリントデバイスに対して行なわれる場合に、前記実ジョブ情報に関連付けられたスプールファイル名に基づき特定される印刷データがプリントデバイスに対して出力されるべく出力ポートに書きこまれる。
IV.仮想ジョブ情報
図11は、プリントキュー701の仮想ジョブキューに登録される仮想ジョブ情報を示す図である。図11の情報は図9、10と同様に図6Aのようなシステム形態では、ジョブ制御プリントサービス605において保持され、図6Bのようなシステム形態ではジョブ制御プリントサービス605及びジョブ制御サーバ612の双方において共有して保持される。仮想ジョブ情報は、仮想ジョブ情報であると識別でき、実ジョブ情報に対して非優先的にスケジュールアップされるという特徴を有する。仮想ジョブ情報には、実ジョブ情報に含まれる各種情報(図10参照)をすべて設定しても構わない。しかし、以下では最良の形態として、必要最低限の情報を仮想ジョブ情報に持たせる形態について説明する。
仮想ジョブ情報は、負荷分散の実ジョブ情報と関連する情報で、負荷分散印刷処理でスケジュール管理するために必要な情報である。
以下、仮想ジョブ情報の設定内容のドキュメント名、ジョブID、プリントタイプ、実ジョブIDについて説明する。
ドキュメント名は、仮想ジョブ情報に対応する実ジョブ情報の印刷対象ドキュメント名であり、仮想ジョブ情報が作られるときに、実ジョブ情報からコピーされる。
ジョブID1102は仮想ジョブ情報を識別するためのIDで、仮想ジョブ情報が作成されるときに設定される情報である。そして、ジョブID1102は、図10の仮想ジョブID1003〜1005の何れかに対応する。
プリントタイプ1103は、仮想ジョブ情報に対応する実ジョブのプリントタイプであり、仮想ジョブが作成されるときに、実ジョブ情報のプリントタイプからコピーされる。また、コピー内容の他に仮想ジョブ情報であることを示す属性も含まれている。
実ジョブID1104は、仮想ジョブ情報と関連する実ジョブ情報のIDであり、仮想ジョブ情報が作成されるときに設定される情報である。これは、図10のジョブID1102に対応する。
なお、図11中には、図10において説明した印刷データを特定するためのスプールファイル名が含まれていないが、事前に仮想ジョブ情報にスプールファイル名を含めるようにして、後述する実ジョブ情報の変更の際に、この事前に関連付けられたスプールファイル名を用いるようにしても良い。
<負荷分散処理>
本実施形態の負荷分散印刷処理では、アプリケーションが印刷指示を行った論理プリンタの負荷分散印刷設定に従って、基本プリントキューに実ジョブ情報を、バックアッププリントキューに仮想ジョブ情報を生成し、その中で、転送開始指示(スケジュールアップ要求)の早い印刷ジョブ情報に対応する印刷データがプリントデバイスに転送される。
図12は、本実施形態の負荷分散印刷処理のジョブ受付処理から仮想ジョブ作成までの処理を示すフローチャートである。
図13は、図12のフローチャートの処理を説明した図である。ここで、ジョブIDが「N」の印刷ジョブ情報を印刷ジョブ情報Nと表現すると、図13では、プリントキュー701の実ジョブキュー801に実ジョブ情報1、別のプリントデバイスに対応するバックアッププリントキュー701Aの実ジョブキュー801Aに実ジョブ情報5があり、それぞれの実ジョブ情報に対応する印刷データを、プリントデバイスへ転送中であるという前提で説明している。なお、実ジョブ情報5は、例えば他のクライアントから発行された印刷ジョブがバックアッププリントキュー701Aに対応するプリントデバイスを基本プリントデバイスとして負荷分散印刷指示を行った場合に登録されたものと考えることができる。その場合には、プリントキュー701および701Bなどの他のプリントキューがそれぞれバックアッププリントキューとされ、それぞれのバックアッププリントキューにおける仮想ジョブキューに仮想ジョブ情報が登録される。
アプリケーション601が印刷を開始すると、ステップS1201において、プリントキュー701はスプーラ603、ジョブ制御ポートモニタ604経由で印刷ジョブを受け付ける。
次に、ステップS1213において、印刷ジョブの種別を判断する。実ジョブ情報の実行タイプにより仮想ジョブ情報を作成するかどうかを判断する。ネットワークプリンタ102〜104でパスワードを入力しなければ印刷できないパスワード入力ジョブ、暗号化されネットワークプリンタ102〜104の内、特定のプリンタでのみ印刷可能なセキュアジョブ、プリントデバイスで出力する直前にオフラインになるオフラインジョブ、プリントデバイスのHDに保存される保存ジョブなど、特定のプリントデバイスでのみ受付可能な場合には、ステップS1211に処理を移行する。そうでない場合には、ステップS1202に処理を移行する。このステップS1213のステップの処理により、セキュリティーが考慮され決められたプリントデバイス及び量だけ印刷出力する印刷ジョブについて、他のプリントデバイスで出力させたり、重複したページを出力させたりすることを防げる。
ステップS1202において、図9中のプリントキュー情報のプリントタイプを参照し、負荷分散印刷であるかを確認する。負荷分散印刷であれば、ステップ1203に処理を移行する。負荷分散印刷でなければ、ステップS1211に進む。ステップS1203では、複数のプリントキューのうち、印刷ジョブの第1出力対象とされたプリントデバイスに対応するプリントキューが基本プリントキューとして設定され、この基本プリントキューに含まれる実ジョブキューに、受け付けた印刷ジョブの実ジョブ情報を登録する。
ドキュメント名としては、スプーラ603からジョブを受け付けるときに取得したものを設定する。ジョブIDはジョブ情報を作成するときに生成し設定する。プリントタイプは、プリントキュー情報のプリントタイプの情報を設定する。
本実施の形態の場合には、プリントキュー情報のプリントタイプは負荷分散印刷であるため、実ジョブ情報のプリントタイプには、負荷分散印刷が設定される。次に、ステップS1204において、作成された実ジョブ情報をプリントキュー701の実ジョブキュー801に登録する(図13の実ジョブ情報7)。更に仮想ジョブキュー802に実ジョブ情報に対応した仮想ジョブ情報を停止状態で登録する(図13の仮想ジョブ情報7´)。ここで停止状態とは、仮想ジョブ情報が出力対象ではないことを示すステータスである。プリンタ701に実ジョブが存在する間は、同じプリンタの仮想ジョブキューにある仮想ジョブ情報はスケジュールアップの対象としないように抑止するため、ここでは停止状態として登録する。また、図10、11には図示されていないが、ステップS1204における実ジョブ情報及び仮想ジョブ情報には、時刻等の登録順番の属性が付されているものとする。
仮想ジョブキューに登録された仮想ジョブ情報は、印刷が完了するかキャンセルされるまで保持され、エラー発生時の代行印刷等やジョブの移動時における印刷順序の保証をしている。なお、本印刷システムにおいては仮想ジョブと実ジョブのIDは同じものが使用されているが、別途対応を管理するデータを保持することにより異なるIDを用いても良い。ここでは、仮想ジョブ情報のジョブIDをN´(ダッシュ)で示す。つまり、例えば、実ジョブ9と仮想ジョブ9´とは対応している。
つぎに、ステップS1205において、図9のプリントキュー情報のバックアッププリンタ名を取得する。複数設定されている場合には、複数のバックアッププリンタ名を取得する。そして、バックアッププリンタ名に対応するプリントキューがバックアッププリントキューとして設定される。
さらに、ステップS1206において、取得した複数のバックアッププリンタ名の各々から特定されるバックアッププリントキューに、仮想ジョブ情報を作成し、各情報を設定する。
図11に示される仮想ジョブ情報の各項目で、ドキュメント名は、実ジョブ情報のドキュメント名から情報を取得し設定する。仮想ジョブのジョブID1102は仮想ジョブ情報を作成するときに生成し設定する。プリントタイプ1103は、実ジョブ情報のプリントタイプの情報から取得し設定する。実ジョブのジョブID1104は実ジョブ情報のジョブID1102から取得し設定する。
ステップS1207において、実ジョブ情報の仮想ジョブIDに仮想ジョブ情報のジョブIDを設定する。仮想ジョブは複数発生する場合があるため、仮想ジョブが作成される順に仮想ジョブID1、仮想ジョブID2、...と設定していく。
ステップ1208において仮想ジョブ情報を仮想ジョブキュー802Aに登録する(図13の仮想ジョブ情報8´)。図11には図示されていないが、ステップS1208で登録される仮想ジョブ情報には、時刻等の登録順番の属性が付されているものとする。
ステップ1209において、ステップS1205で取得したバックアッププリンタ名(バックアッププリントキュー)が残っていれば、ステップS1206に処理を移行する。そしてステップS1206から1208における処理を繰り返した結果、図13中の仮想ジョブ情報9´が登録される。
図13では、ステップS1205で取得したバックアッププリンタ名が2つある場合を想定して説明しているため、仮想ジョブ情報は、2つ作成される。すなわち、仮想ジョブキュー802A、802Bに仮想ジョブ情報8´、9´が作成され、実ジョブ情報7の仮想ジョブID欄に8´と9´が設定される。また、ジョブIDが8´と9´の仮想ジョブ情報には、その実ジョブID欄に、7が設定される。また本実施形態では、同じプリントキューに存在する実ジョブ情報とそれに対応する仮想ジョブ情報とは同じIDを割り当てられるため、実ジョブジョブ情報7内に、これに対応する仮想ジョブキュー802内の仮想ジョブのジョブID(7´)を設定する必要はない。実ジョブ情報7は、自身のIDを参照すれば、容易に仮想ジョブ情報7´を見つけだすことができるからである。
ステップS1209において、ステップS1205で取得したバックアッププリンタ名が残っていなければ、ステップS1210に移行し、作成した実ジョブとすべての仮想ジョブのスケジュール要求を発行する。
図14は、各プリントキュー701、701A、701Bの各々において発行されるアクションに対するスケジュール処理を示す図である。この処理は、ジョブ制御プリントサービス605における処理に相当する。
ステップS1401では、各プリントキューのスケジュールの管理を行い、アクションの発生を認識する。この認識は外部からのイベントの検知によるものであっても、アクションの発生元をポーリングし応答を検知するものでも良い。さらに具体的には、いずれかのプリントキューに印刷ジョブを登録したモジュール(例えばジョブ制御ポートモニタ)からのスケジュール要求、印刷ジョブの送信完了(出力ポートからプリントデバイスへの印刷データの送信を終了したことを示す情報)、印刷ジョブの削除、印刷ジョブの完了(最終ページ排紙通知)、デバイス復帰通知(例えば電源OFFからON状態になった場合になど、動作不可能な状態から動作可能な状態に移行したことを示すイベント)などのアクションを監視する。各プリントキューに対する、上記アクションが発生すると、ステップS1402に処理を移行し、アクションが発生しない場合は、ステップS1401で待機処理を行う。ここで、スケジュール要求のアクションは例えばジョブ制御ポートモニタから発生する。また印刷ジョブの削除は、プリントマネージャ609から発生される。また、印刷ジョブの送信完了及び印刷ジョブの完了はプリントデバイスにおいて発生し、出力ポートを介して通知される。ただし、これらのアクションの発生ルートはこれに限定されるものではない。
ステップS1402において、上記アクションが発生したプリントキュー701、701A、701Bを確認し、実ジョブキュー801、801A、801B、仮想ジョブキュー802、802A、802Bの順に検索し、いずれかのプリントキューに何らかの印刷ジョブ情報が存在していればステップS1403に処理を移行し、印刷ジョブ情報が無ければステップS1401に移行する。なお、対象ジョブを検索する際には、停止状態のジョブ、削除中状態のジョブはスケジュールアップの対象からは除外される。
ステップS1403において、プリントデバイスのうち、ステップS1401において所定のアクションが発生したプリントキューに対応するプリントデバイスの動作ステータスを取得する。例えば、ステップS1401において発生したアクションがジョブ完了であれば、印刷ジョブの完了のアクションに応じてステータスを取得するようにする。
また、ステップS1403におけるデバイスステータスの取得で、デバイス制御コントロールモジュール606を介したポーリングを行い、このポーリングと所定のアクションの発生によるデバイスステータスの取得を併用するようにすれば、より迅速にプリントデバイスが転送可能な動作ステータスになったか否かを調べることができる。
ステップS1404において前のステップにおいて取得されたステータスに基づいて、現在対象となっているプリントキューに対応するプリントデバイスに印刷データを転送可能かどうか判断する。ここでデータ転送不可能と判断される動作ステータスとしては、例えば(1)紙無しやトナー無しなど消耗品が不足した状態や、(2)画像記録を継続できない例えばジャム(紙詰まり)などの障害が発生している状態や、(3)印刷データを送信するチャネルがオフラインである状態や、(4)プリントデバイス側(ネットワークボードも含む)でこれ以上受信バッファに余裕がなくビジーの状態などが挙げられる。また、この(1)乃至(4)のステータスを任意に組み合わせてそれをデータ転送可能でないと判断するステータスとするようにしても良い。
ステップS1404において、アクション発生の対象となっているプリントデバイスに印刷データを転送可能であれば、ステップS1405に処理を移行し、転送不可能であれば、処理をステップS1401に移行する。
ステップS1405において、ステップS1402で見つけたジョブに対して、スケジュールアップ要求を発行し、処理をステップS1401に移行する。この時、実ジョブが見つかっていれば、仮想ジョブよりも先に実ジョブに対してスケジュールアップ要求を発行する。つまり、登録の順番に係わらず、実ジョブを仮想ジョブよりも優先する。また実ジョブ及び仮想ジョブの中でプリントキューへの登録が早いものがステップS1402で優先的に確認される。
例えば、ステップS1401で印刷ジョブBのスケジュール要求が発生した時に、前の印刷ジョブ(印刷ジョブA)が転送中であるとした場合、S1404でNOの処理に移行し、ステップ1401で待機する。そしてその後、ステップS1401で、印刷ジョブAのジョブ送信完了やジョブ削除などを受け付けるとテップS1402からステップS1405に進み、ジョブBの転送が直ちに開始される。
次に、図14のフローチャートの処理に基づき特にプリントキュー701でスケジュールアップ要求を受け付けてから、プリントデバイスに印刷データを送信するまでの処理の流れについて説明する。図15は、プリントキュー701での負荷分散印刷処理について示すフローチャートである。また、図16、図17は、図15のフローチャートに関連した処理を表した図である。
負荷分散印刷では、印刷指示を受けたプリントデバイスに対応するプリントキューの実ジョブキューに実ジョブ情報が登録され、そのプリントデバイスに対してバックアッププリントデバイスとして動作するように予め設定されたプリントデバイスに対応するプリントキューの仮想ジョブキューに仮想ジョブ情報が登録される。1つのプリントキューにおいて、これらのジョブの中で早くスケジュールアップ要求を受け付けた印刷ジョブがネットワークプリンタ102〜104に転送される。
ステップS1501では、スケジュールアップ要求を受け付けたか判断する。スケジュールアップを受け付けると処理をS1502に移行し、スケジュールアップが来なければステップS1501で待機する。
ステップS1502では、スケジュールアップを受け付けた印刷ジョブが負荷分散ジョブかどうかを判断する。ジョブ情報のプリントタイプの情報を取得し、プリントタイプが負荷分散印刷であれば、ステップS1503に処理を移行する。負荷分散印刷でなければ、ステップS1511に処理を移行し、実ジョブキューに登録された実ジョブ情報に含まれる格納場所(リンク情報)より印刷データを特定し、特定した印刷データを含む印刷ジョブがネットワークプリンタに転送される。
ステップS1503では、スケジュールアップのジョブが仮想ジョブであるか、実ジョブであるかを判断する。仮想ジョブであれば、ステップ1504に処理を移行し、実ジョブであればステップS1513に処理を移行する。
ここで、仮想ジョブのスケジュールアップをユーザに通知してもよい。つまり、ユーザが指定した基本プリントデバイスではなく、バックアッププリントデバイスにおいて印刷が実行されることを通知すれば、ユーザは印刷結果が出力されるプリンタを特定することができ、利便性が高い。
ステップS1504において、実ジョブ情報を参照するために仮想ジョブ情報中の実ジョブIDを取得する。ステップS1505では、ステップS1504で取得した実ジョブIDを用いて実ジョブ情報を参照し、実ジョブ情報に含まれる単数或いは複数の仮想ジョブIDを取得する。
ステップS1506では、ステップS1505で取得した仮想ジョブIDから、スケジュールアップ要求が発生した仮想ジョブ以外の仮想ジョブを認識し、スケジュールアップ要求を受けていない送信の対象とならなかった他の仮想ジョブのステータスを、「停止」とする(図16の矢印g)。これにより、送信の対象とならなかった他の仮想ジョブは、ステータスが再度、「送信待ち」に変更されるまで、その後の出力対象(スケジュールアップの対象)から除外される。
ステップS1507において、ステップS1505で取得した仮想ジョブで、ステップS1506で停止していない仮想ジョブが残っていればステップS1506に処理を移行し、仮想ジョブが残っていなければ、ステップS1508に処理を移行する。これにより、スケジュールアップ要求が発生した仮想ジョブと同じ実ジョブIDに関連付けられた他のすべての仮想ジョブを「停止」する。
ステップS1508、S1509では、仮想ジョブから実ジョブを生成しプリントデバイスに送信するために、スケジュールアップ要求が発生した仮想ジョブを実ジョブに変更する処理を行う。すなわち、仮想ジョブ情報から実ジョブ情報を作成し、実ジョブキュー801Bに登録する(図16の矢印h)。そしてこの変更処理により仮想ジョブ情報が実ジョブ情報になり、変更前の実ジョブ情報に対応する印刷ジョブの送信は行わない。
まず、ステップS1508において、仮想ジョブ情報に対応する新たな実ジョブ情報を、実ジョブキュー801Bに生成する(図16の矢印h)。この際に実ジョブに変更される仮想ジョブ情報を停止状態にする(図17の9´)。更に、ステップS1509において、その仮想ジョブ情報中の実ジョブIDから、元の実ジョブ情報(ここではプリントキュー701に登録された実ジョブ情報7)を特定し、元のの実ジョブ情報の内容を取得し、新たな実ジョブ情報9にその内容をコピーする。ここで、例えば、図10のプリントタイプ、実行タイプ、先頭ジョブマーク、送信済みプリンタリスト、スプールファイル名などを、新たな実ジョブ情報に反映させる。また、新たに作成された実ジョブ情報の実ジョブIDは、前の実ジョブID(ジョブID7)を流用するようにしても良いし、新たな実ジョブIDを生成し用いるようにしても良い。新たな実ジョブIDを用いる場合には、関連する仮想ジョブ情報中に含まれる実ジョブIDを書き換える必要がある。
更にステップS1510において、スケジュールアップ要求が発生した仮想ジョブ情報の実ジョブIDに登録されていた元の実ジョブ(ここではプリントキュー701に登録された実ジョブ情報7)を削除する(図16の矢印i)。これらの処理の結果、図17のような状況となる。この図17には仮想ジョブ情報が各々のプリントキューに1つしか示されていないが、実際には複数のクライアントからの印刷要求に対応して複数の仮想ジョブ情報が夫々のプリントキューに登録されている場合がある。この場合でも、停止中の仮想ジョブ情報はスケジュールアップ対象外となり、対象外を除くスケジュールアップ対象のバックアップジョブ情報が登録順にスケジュールアップする。
例えば、図17の状態から実ジョブ情報5が出力済みとなった前提で、他の印刷ジョブの実ジョブ情報がプリントキュー701に、仮想ジョブ情報が701A、701Bのプリントキューに登録された場合でも、仮想ジョブ情報8´は停止中でありスケジュールアップ対象外なので、プリントキュー701Aに登録された仮想ジョブ情報を実ジョブ情報に変更し印刷ジョブを印刷装置へ出力することができる。このように、停止中の仮想ジョブ情報を、その登録順番を維持しつつ、スケジュールアップ対象外とする。これにより、仮想ジョブ情報が実ジョブ情報に変更された場合でも、その登録順番を維持できる。そして、後続して登録された他の仮想ジョブ情報のスケジュールアップを妨げることもない。
図15の説明に戻ると、ステップS1511において、元々実ジョブの印刷ジョブあるいは実ジョブに変更された印刷ジョブを対応するプリントデバイスに転送する。より具体的に説明すると、最終的に対象となる図10の実ジョブ情報(ステップS1503でNoと判断された実ジョブ情報、あるいは、ステップS1509において切り替えられた実ジョブ情報)から特定されるスプールファイル名の印刷データが、実ジョブ情報が登録されている実ジョブキュー(プリントキュー)に対応する論理プリンタの出力ポートに関連付けられたIPアドレス又は名前解決に利用するネームに基づき転送される。
そして、印刷ジョブの転送が終了したらステップS1512でジョブの送信終了の通知を行う。この通知は図14のステップS1401におけるジョブ送信完了のアクションとして確認される。
なお、図16の矢印iの処理が実行し終えるまで二つの実ジョブが存在するが、図16の矢印gから矢印iまでのの処理を一筆書きの(コンテキストチェンジを発生させない)プログラムで実現すれば問題は起こらない。また、図16の矢印iと矢印hの処理順序を逆にするようにしても良い。更に、上に説明では不要となった仮想ジョブ情報及び実ジョブ情報を削除するよう説明してきたが、例えば、不要になった印刷ジョブ情報にそれを示すフラグを付加して、付加後のジョブ情報を対応するプリントデバイスに送信するようにし、プリンタ側でフラグを参照し受信した印刷ジョブ情報を破棄するようにしても良い。
負荷分散処理により発生した実ジョブと複数の仮想ジョブの内、スケジュールアップを受けたジョブが実ジョブの場合には、ステップS1503からステップS1513に移行する。ステップ1513では、実ジョブ情報からすべての仮想ジョブ情報を取得し、ステップS1514においてすべての仮想ジョブを停止し、ステップS1511においてスケジュールアップを受け付けた実ジョブを対応するネットワークプリンタに転送する。
一方。ステップS1502においてスケジュールアップを受けた印刷ジョブのプリントタイプが負荷分散印刷でなければ、ステップS1511に処理を移行し、そのままネットワークプリンタに転送される。
なお、印刷ジョブ転送方法としては様々な方法を利用可能であり、独自に作成した送信出力ポートにスプールジョブを転送しても良いし、オペレーティングシステムに用意された送信出力ポートに対して印刷ジョブを転送させてもよい。
この図20の状態では、スケジュールアップ対象外のバックアップ印刷ジョブ情報を除くスケジュールアップ対象のバックアップ印刷ジョブ情報を登録順にスケジュールアップする。
図18に、基本プリントキューに対応する論理プリンタに対して、バックアッププリントキューに対応する論理プリンタを関連付けるための、設定画面を示す。この図18は新規に論理プリンタを作成あるいは追加する際に表示されるものであるが、既に作成された論理プリンタの設定を変更する場合などに表示させるようにしても良い。
1801は、プリンタ名を入力する入力欄である。キーボード等を介してユーザが任意に名前を指定することができる。ここに入力されるプリンタ名は、図12のS1203で第1出力対象となるプリントデバイスに対応する。
1802は、プリンタドライバ名を表示する表示欄である。「ドライバの選択」ボタンを選択することにより、ユーザが選択可能な複数のプリンタドライバのリストが表示され、そのリストから選択されたプリンタドライバの名前が表示欄1802に表示される。
1806はプリンタドライバに関連付けるポートを選択する選択画面を表示させるための「ポートの選択」ボタンである。「ポートの選択」ボタン1806が選択されると、システムに登録されている複数のポートが選択可能な形態で提示される。
1803はプリンタの出力方法を選択するための選択欄である。この選択欄において、出力方法として「負荷分散印刷」を指定することができる。
1804は、1801、1806で設定された論理プリンタに対するバックアッププリンタ(例えば図13のバックアッププリントキュー701A、701Bに対応)のリストを表示する表示欄である。1805は、バックアッププリンタを設定するための「バックアッププリンタ設定」ボタンである。「バックアッププリンタ設定」ボタン1805が選択されると、バックアッププリンタとして設定可能なプリンタのリストが表示される。そして、そのリスト中から選択されたプリンタがバックアッププリンタとして設定され、バックアッププリンタリスト表示欄1804に表示される。「バックアッププリンタ設定」ボタン1805が選択された場合に、指定されたプリンタドライバにより特定されるプリンタモデルやプリンタ言語に互換性のあるプリンタのみをリスト表示すれば、適切なバックアッププリンタをユーザに効率よく選択させることができる。また図18中の「プリンタオプション」中の「代行発生条件」の各欄では、どのような状態が発生した場合に代行印刷を行なうかを、指定することができる。
このように、図18に示す画面で設定された設定情報は、図9や、図10や、図11の情報の各項目に反映される。つまり、図18に示す画面は見かけ上、論理プリンタ同士の関係を設定するための設定画面であるが、その設定画面に対する設定内容は結果としてプリントキュー同士の関係を設定するものとなる。従って、図18は、基本プリントキューに対してバックアッププリントキューを対応付けるための設定画面と言い換えることができる。
<エラー発生時の処理>
次に、図19乃至図21を用いて、プリントデバイスに何らかのエラーが起こった場合の処理について説明する。
図19は、プリントデバイスに印刷データを送信した後にプリントデバイスで印刷ができない状態が発生した場合の、プリントキューでの処理を示すフローチャートである。ここでの印刷ができない状態としては、例えばステップS1404において説明した(1)〜(4)が挙げられるが、無論これに限定されるものではない。
ステップS1801では、プリントデバイスを監視してエラーが発生したか否か判定し、エラーが発生すると、ステップS1802に移行する。尚、ステップS1801ではエラーの発生を想定しているがこれに限定されるものではなく、印刷ができないことを余儀なくされる条件であればエラーに限らず様々な状態をステップS1802に移行する条件として適用できる。以下では「エラー」が発生した場合を例にして説明を行なう。
次に、ステップS1802において、エラーが発生したプリントデバイスに対応するプリントキュー内の実ジョブ情報が代行状態となる。そして、その実ジョブ情報に含まれる仮想ジョブIDを参照して、その仮想ジョブIDに対応する、仮想ジョブ情報の停止状態を解除する(図20において、実ジョブ情報9が代行状態となると、仮想ジョブ情報7´及び8´を送信待ち状態とする)。
続いてプリントデバイスの復旧或いは代行先でのスケジュールアップを待つ。プリントデバイスにおける復帰は、ステップS1401において説明したデバイス復帰通知を認識すれば良い。
ステップS1803でプリントデバイスが復旧していないと判定され、ステップS1804で、仮想ジョブ情報7´、8´のいずれかがスケジュールアップした場合には、ステップS1805に進み、仮想ジョブ情報のスケジュールアップ処理と実ジョブ情報9の削除処理を行う。この処理は、図15におけるステップS1504からステップS1511の処理と基本的に同様である。図21は、仮想ジョブ情報8´がスケジュールアップされ、実ジョブ情報9が削除される様子を示す図である。この時、同時に、対応する他の仮想ジョブ情報(図21では仮想ジョブ情報7´、9´)を停止状態にする。また、ステップS1508と同様に実ジョブ情報8に対応する仮想ジョブ情報8´を停止状態にする。
一方、仮想ジョブのスケジュールアップよりも早くステップS1803でプリントデバイスの復旧が検知された場合には、全ての仮想ジョブは停止状態に戻され、実ジョブ情報9の印刷処理は継続される。この時のプリンタキューの状態は図17と同様である。
そして、ステップS1401の処理によりプリンタデバイス内部での印刷出力の完了(ジョブ完了)が本情報処理装置によって検知されると、実ジョブ情報と共に、全ての対応する仮想ジョブが削除されて印刷処理が終了する。
このように本実施形態では、アプリケーションが負荷分散プリンタに対する印刷指示を送ると、負荷分散設定の基本プリントキューに実ジョブ情報及び仮想ジョブ情報が、バックアッププリントキューに仮想ジョブ情報が作成され、これらのジョブ情報の中で一番早くスケジュールアップを受け付けたジョブ情報が印刷ジョブとしてプリントデバイスに転送される。これにより、複数のプリントデバイスの内で最も早く転送可能になったプリンタデバイスに印刷ジョブが転送されることになる。その結果、大量の印刷ジョブを複数のプリンタデバイスで効率的に処理することができ、印刷ジョブが存在している間は複数のプリンタデバイスがフルに稼動することができる。
更に、プリンタデバイスへ印刷ジョブを送信した後で、印刷中断が発生した場合にも図18のフローチャートが実行されるので、図21の仮想ジョブ情報8´が実ジョブ情報8に変更することで代行印刷処理を行うことができ、図12のS1203から処理をやり直す無駄な処理及び時間を削減することができる。結果として、ステップS1203から再度処理する場合に比べて、早期に代行処理を実現できる。
更に、印刷中断が発生した場合にも図18のフローチャートが実行されるので、当初のジョブ受付順に従って代行処理が行われる。言い換えれば代行時に図12のS1203から処理をやり直す必要がないので、他のクライアントからの仮想ジョブ情報が仮想ジョブキューの後続して登録されていたとしても、その他の仮想ジョブ情報よりも優先してスケジュールアップを行なうことができる。一方、プリントデバイスの復旧が遅い場合には他のプリンタデバイスを用いてより早く印刷出力を得ることが可能となり、プリントデバイスが早く復旧した場合には印刷中断が発生したプリントデバイスに送信されていた印刷ジョブがそのまま印刷されるため、効率的な印刷を行うことが可能となる。
[第2実施形態]
第1実施形態では、実ジョブ情報と仮想ジョブ情報とを明確に区別して説明してきた。しかし、特定の印刷装置に負荷が偏るという問題を解決するために、複数の印刷装置を負荷を分散して効率よく利用し、印刷ジョブを印刷装置に送信した後で、その印刷装置でエラーが発生した場合を考慮すると言う点では第1実施形態には限定されない。
つまり、複数の印刷装置に夫々対応した複数のプリントキューを情報処理装置に備えさせ、複数のプリントキューに、直接的或いは間接的に印刷データとリンク可能な情報を含むジョブ情報を登録し、プリントキューの空きに応じて最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にし、スケジュールアップしたジョブ情報に基づく印刷ジョブが出力された印刷装置において印刷中断が発生した場合にはスケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とするようにしても良い。これは第1実施形態で説明してきた図1乃至6A、6Bにおいて説明したプリントシステムのソフトウェア構成で実現できる。
具体的に図13のように3つのプリントッキュー701、701A、701Aを用いた場合について説明する。まず、負荷分散印刷としてユーザの指定した論理プリンタに対応したプリントキュー701に図10と同様の印刷ジョブ情報を登録する。そして、登録が行われたプリントキュー701のプリントキュー情報(図9)中のバックアッププリンタ名で特定される701A、701Bのプリントキューに対して図10と同様の印刷ジョブ情報(図22)を登録する。さらに、バックアッププリンタ名で特定されるプリントキューにも関連するプリントキューに登録されたジョブ情報のジョブIDが設定される。
例えばプリントキュー701Aに登録される印刷ジョブ情報を図22に示す。ドキュメント名2202、ジョブID、プリントタイプ2204、実行タイプ2207、スプールファイル名については図10と同様なので詳しい説明は省略する。2205、2206は、プリントキュー701Aには図9に基づき、プリントキュー701及び701Bが関連付けら得ているので、ジョブID1(701)とジョブID2(701B)とが設定されている。
なお、留意されたい点は、第2実施形態ではバックアッププリンタ名は関連プリンタ名として定義でき、登録される印刷ジョブ情報も実ジョブ情報と仮想ジョブ情報とに区別することなくジョブ情報とすることができる。そして、各々の印刷ジョブ情報には自らの印刷ジョブのジョブIDに加えて、関連するプリントキューに登録された印刷ジョブのジョブIDが設定される。このようなジョブ情報の登録を基づき、どのようにして図12に相当するフローチャートを実行するかについて以下説明する。
まず、ステップS1201〜1202においては図12で説明した通りとする。但しステップS1201において受け付けられた印刷ジョブ情報には登録時刻などの登録順番の属性が付されており、所定のプリントキューへ登録された印刷ジョブ情報はこの登録順番にスケジュールアップされることとする。
ステップS1204では実ジョブキュー(プリントキュー701)への登録を行い仮想ジョブキューへの登録を省略する。ステップS1205〜1208における仮想ジョブ情報の登録を関連するプリンタ名で特定されるプリントキュー(例えばプリントキュー701A、701B)へ印刷ジョブ情報を登録する。そして、登録された各印刷ジョブ情報に対してステップS1210の処理を実行する。この際にも図14のアクション発生の監視処理は平行して実行されているものとする。
そして、図14のステップS1402でプリントキューへの登録順に従ってスケジュールアップが行われた何れかの印刷ジョブ情報を監視し、図15のフローチャートへ移行する。例えば、ステップS1201でプリントキュー701に登録された印刷ジョブ情報と負荷分散印刷で関連付けられたプリントキュー701Aに登録されたジョブ情報がスケジュールアップしたことを想定して以下の説明を行う。
図15のステップS1501、1502では同様の処理を実行し、ステップS1505へ移行する。ステップS1503、1504の処理は省略する。
ステップS1505は、関連する印刷ジョブのジョブIDを取得する処理に置きかえることができる。
そして、ステップS1506では、ステップS1505で取得された関連する印刷ジョブのID2205、2206に対応する印刷ジョブ情報の停止させ、最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にする。この結果プリントキュー701と701Bに登録された印刷ジョブ情報に基づく印刷ジョブは印刷装置へ出力されない。
次に、第2の実施の形態における図19のフローチャートの処理について説明する。
まず、ステップS1801で印刷の中断が検知されると、図22において特定される、関連するジョブID2205、2206の停止を解除させ、スケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とする。
そして、ステップS1803で、印刷が中断されたプリントデバイスが復旧したことが検知されれば、再び印刷ジョブのID2205、2206に対応する印刷ジョブ情報の停止させ、自印刷ジョブ情報に基づく印刷ジョブの印刷を所定の続きの頁から再開する。再開後印刷出力が終了した場合には複数の印刷ジョブ情報は削除される。
一方、停止を解除した関連する印刷ジョブIDのジョブ情報の何れかがスケジュールアップしたことが確認されれば、スケジュールアップした印刷ジョブ情報中に設定される自らを除く関連した印刷ジョブIDの印刷ジョブ情報をスケジュールアップ対象外とする。そして、スケジュールアップが行われた印刷ジョブ情報に基づく印刷ジョブの印刷装置への出力が完了すると全ての印刷ジョブ情報の削除が行われる。
尚、上の説明では、スケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にしたり、印刷中断発生で再度スケジュールアップ対象にしたりする処理を図22のジョブ情報に基づき行うように説明してきたがこれに限定されるものではない。例えば、第1実施形態における実ジョブ情報のスケジュールアップが仮想ジョブ情報のそれよりも優先されるという規則を除き、且つ、それを前提に第1実施形態の仕組みを実行することによっても実現される。
以上述べてきたように、第1実施形態における図1乃至6と同じ仕組みで、且つ、図12、14、15、17のフローチャートノ各ステップの省略及び変更することによっても、複数の印刷装置を負荷を分散して効率よく利用し、印刷ジョブを印刷装置に送信した後で、その印刷装置でエラーが発生した場合でも負荷分散印刷を維持した仕組みを実現することができる。
また関連する印刷ジョブ情報を削除することなく、登録順番を維持したまま停止させたり停止を解除するようにするので、関連する複数の印刷ジョブ情報の何れかに基づく印刷ジョブを印刷装置に送信した後に印刷が中断したとしても、印刷順序を確保し且つ負荷分散印刷を維持し且つ代行印刷処理を達成することができる。
(他の実施形態)
以上、本発明の実施形態について詳述したが、本発明は、複数の機器から構成されるシステムに適用しても良いし、また、一つの機器からなる装置に適用しても良い。
なお、本発明は、前述した実施形態の機能を実現するソフトウェアのプログラムを、システムあるいは装置に直接あるいは遠隔から供給し、そのシステムあるいは装置のコンピュータが供給されたプログラムコードを読み出して実行することによっても達成される場合を含む。その場合、プログラムの機能を有していれば、形態は、プログラムである必要はない。
従って、本発明の機能処理をコンピュータで実現するために、コンピュータにインストールされるプログラムコード自体も本発明を実現するものである。つまり、本発明のクレームでは、本発明の機能処理を実現するためのコンピュータプログラム自体も含まれる。
その場合、プログラムの機能を有していれば、オブジェクトコード、インタプリタにより実行されるプログラム、OSに供給するスクリプトデータ等、プログラムの形態を問わない。
プログラムを供給するための記録媒体としては、例えば、フロッピー(登録商標)ディスク、ハードディスク、光ディスク、光磁気ディスク、MO、CD−ROM、CD−R、CD−RW、磁気テープ、不揮発性のメモリカード、ROM、DVD(DVD−ROM,DVD−R)などがある。
その他、プログラムの供給方法としては、クライアントコンピュータのブラウザを用いてインターネットのホームページに接続し、ホームページから本発明のコンピュータプログラムそのもの、もしくは圧縮され自動インストール機能を含むファイルをハードディスク等の記録媒体にダウンロードすることによっても供給できる。また、本発明のプログラムを構成するプログラムコードを複数のファイルに分割し、それぞれのファイルを異なるホームページからダウンロードすることによっても実現可能である。つまり、本発明の機能処理をコンピュータで実現するためのプログラムファイルを複数のユーザに対してダウンロードさせるWWWサーバも、本発明のクレームに含まれるものである。
また、本発明のプログラムを暗号化してCD−ROM等の記憶媒体に格納してユーザに配布し、所定の条件をクリアしたユーザに対し、インターネットを介してホームページから暗号化を解く鍵情報をダウンロードさせ、その鍵情報を使用することにより暗号化されたプログラムを実行してコンピュータにインストールさせて実現することも可能である。また、コンピュータが、読み出したプログラムを実行することによって、前述した実施形態の機能が実現される他、そのプログラムの指示に基づき、コンピュータ上で稼動しているOSなどが、実際の処理の一部または全部を行い、その処理によっても前述した実施形態の機能が実現され得る。
更に、記録媒体から読み出されたプログラムが、コンピュータに挿入された機能拡張ボードやコンピュータに接続された機能拡張ユニットに備わるメモリに書き込まれた後、そのプログラムの指示に基づき、その機能拡張ボードや機能拡張ユニットに備わるCPUなどが実際の処理の一部または全部を行い、その処理によっても前述した実施形態の機能が実現される。
本発明の実施形態としてのプリントシステムの全体構成を示すブロック図である。 サーバまたはクライアントのハードウェア構成を説明するブロック図である。 図2に示したRAM202のメモリマップの一例を示す図である。 図2に示したFD204のメモリマップの一例を示す図である。 図2に示したFDドライブ203に対して挿入されるFD204との関係を示す図である。 プリントシステムのソフトウェア構成の1例を示す図である。 プリントシステムのソフトウェア構成の、他の例を示す図である。 負荷分散印刷時の印刷ジョブの流れを示す図である。 プリントキューと実ジョブキュー及び仮想ジョブキューの関連を表す図である。 プリントキュー情報の内容を示す図である。 実ジョブ情報の内容を示す図である。 仮想ジョブ情報の内容を示す図である。 印刷ジョブを受け付けてから、仮想ジョブを作成する処理の流れを示すフローチャートである。 実ジョブ、仮想ジョブと実ジョブキュー、仮想ジョブキュー、プリントキュー、バックアッププリントキューの関連を示す図である。 スケジュールアップの処理を示すフローチャートである。 スケジュールアップから印刷するまでの処理を示すフローチャートである。 実ジョブ、仮想ジョブと実ジョブキュー、仮想ジョブキュー、プリントキュー、バックアッププリントキューの関連を示す図である。 実ジョブ、実ジョブキュー、仮想ジョブキュー、プリントキュー、バックアッププリントキューの関連を示す図である。 プリンタに関する情報を設定するための画面の1例を示す図である。 プリントデバイスに印刷データを送信した後にプリントデバイスで印刷中断が発生した場合の処理を示すフローチャートである。 プリントデバイスで印刷中断が発生した場合の、印刷ジョブの処理方法を説明するための概念図である。 プリントデバイスで印刷中断が発生した場合の、印刷ジョブの処理方法を説明するための概念図である。 所定のプリントキューに登録された印刷ジョブ情報に関連したジョブ情報の内容を示す図である。

Claims (16)

  1. 複数の印刷装置に夫々対応した複数のプリントキューを備える情報処理装置であって、
    前記複数のプリントキューに、直接的或いは間接的に印刷データとリンク可能な情報を含むジョブ情報を登録する登録手段と、
    プリントキューの空きに応じて最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にし、スケジュールアップしたジョブ情報に基づく印刷ジョブが出力された印刷装置において印刷中断が発生した場合には前記スケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とする手段とを備えることを特徴とする情報処理装置。
  2. 前記プリントキューは基本プリントキュー或いはバックアッププリントキューとして機能し、前記登録手段は印刷指示に応じて前記基本プリントキューに印刷ジョブ情報を、前記バックアッププリントキューにバックアッププリント印刷ジョブ情報を、それぞれ登録することを特徴とし、更に、バックアップ印刷ジョブ情報よりも優先された印刷ジョブ情報のスケジュールアップを検知する検知手段と、
    スケジュールアップした印刷ジョブ情報に基づく印刷ジョブの印刷装置への出力を行なう出力手段と、
    前記印刷装置へ出力された印刷ジョブに対応する印刷ジョブ情報に関連付けられたバックアップ印刷ジョブ情報を、スケジュールアップ対象外にする変更手段と、
    印刷装置における印刷中断を認識する認識手段と、
    を備え、
    前記変更手段は、印刷ジョブの出力先の印刷装置での印刷中断が前記認識手段により認識された場合に、スケジュールアップ対象外とされたバックアップジョブ情報をスケジュールアップ対象に変更することを特徴とする請求項1に記載の情報処理装置。
  3. 前記検知手段は前記印刷中断が検知された印刷装置の復旧を検知し、前記変更手段は、前記検知手段により前記復旧が検知されたことに応じて前記バックアップジョブ情報を再度スケジュールアップの対象外にすることを特徴とする請求項2に記載の情報処理装置。
  4. 前記登録手段は、バックアップ印刷ジョブ情報の登録を、登録順番を付して行なうことを特徴とする請求項2又は3に記載の情報処置装置。
  5. 複数の印刷装置に印刷データを送信可能な情報処理装置であって、
    前記複数の印刷装置に対応する複数のプリントキューについて、前記複数のプリントキューのうち、いずれか1つを基本プリントキューとして設定し、前記基本プリントキュー以外のプリントキューをバックアッププリントキューとして設定するプリントキュー設定手段と、
    印刷ジョブ情報を前記基本プリントキューに登録する印刷ジョブ登録手段と、
    前記基本プリントキューに登録された前記印刷ジョブ情報に対応するバックアップジョブ情報を生成して、出力対象として前記バックアッププリントキューに登録するバックアップジョブ登録手段と、
    前記基本プリントキュー及び前記バックアッププリントキューのそれぞれにおいて、印刷ジョブ情報が登録されている場合には、優先的に該印刷ジョブ情報に対応する印刷データを、対応する印刷装置に対して出力し、印刷ジョブ情報が登録されておらず、出力対象のバックアップジョブ情報が登録されている場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始するジョブ制御手段と、
    前記基本プリントキュー及び前記バックアッププリントキューにおいて、登録されている前記印刷ジョブ情報及びそれに対応するバックアップジョブ情報のいずれか1つが印刷装置への出力開始の対象となった場合に、出力開始の対象とならなかった前記バックアップジョブ情報を、出力対象ではないバックアップジョブ情報として前記バックアッププリントキューに保持する保持手段と、
    前記印刷装置で印刷中断が発生したことを検知する手段と、
    を有し、
    前記保持手段は、前記印刷装置で印刷中断が発生した場合に、印刷中断の対象となった印刷データに対応するバックアップジョブ情報を、出力対象とすることを特徴とする情報処理装置。
  6. 前記ジョブ制御手段は、前記印刷装置の印刷中断が復旧する前に、前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷データに対応するバックアップジョブ情報が出力対象として登録された状態となった場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始し、前記印刷装置において印刷中断対象の印刷データの処理をキャンセルすることを特徴とする請求項5に記載の情報処理装置。
  7. 前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷ジョブ情報に対応するバックアップジョブ情報が出力対象として登録された状態となる前に、前記印刷装置の印刷中断が復旧した場合には、復旧した印刷装置に存在する印刷データの印刷を実行し、印刷完了後、前記保持手段で保持された前記バックアップジョブ情報を削除することを特徴とする請求項5または6に記載の情報処理装置。
  8. 複数の印刷装置に夫々対応した複数のプリントキューを備える情報処理装置における負荷分散印刷方法であって、
    前記複数のプリントキューに、直接的或いは間接的に印刷データとリンク可能な情報を含むジョブ情報を登録する登録ステップと、
    プリントキューの空きに応じて最初にスケジュールアップしたジョブ情報以外のジョブ情報をスケジュールアップの対象外にし、スケジュールアップしたジョブ情報に基づく印刷ジョブが出力された印刷装置において印刷中断が発生した場合には前記スケジュールアップの対象外となっていたジョブ情報をスケジュールアップの対象とするステップとを備えることを特徴とする負荷分散印刷方法。
  9. 前記プリントキューは基本プリントキュー或いはバックアッププリントキューとして機能し、前記登録ステップは印刷指示に応じて前記基本プリントキューに印刷ジョブ情報を、前記バックアッププリントキューにバックアッププリント印刷ジョブ情報を、それぞれ登録することを特徴とし、更に、バックアップ印刷ジョブ情報よりも優先された印刷ジョブ情報のスケジュールアップを検知する検知ステップと、
    スケジュールアップした印刷ジョブ情報に基づく印刷ジョブの印刷装置への出力を行なう出力ステップと、
    前記印刷装置へ出力された印刷ジョブに対応する印刷ジョブ情報に関連付けられたバックアップ印刷ジョブ情報を、スケジュールアップ対象外にする変更ステップと、
    印刷装置における印刷中断を認識する認識ステップと、
    を備え、
    前記変更ステップは、印刷ジョブの出力先の印刷装置での印刷中断が前記認識ステップにより認識された場合に、スケジュールアップ対象外とされたバックアップジョブ情報をスケジュールアップ対象に変更することを特徴とする請求項8に記載の情報処理方法。
  10. 前記印刷中断が検知された印刷装置の復旧を検知する第2検知ステップと、前記第2検知ステップにおいて前記復旧が検知されたことに応じて前記バックアップジョブ情報を再度スケジュールアップの対象外にする第2変更ステップとを備えることを特徴とする請求項9に記載の負荷分散印刷方法。
  11. 前記登録ステップは、バックアップ印刷ジョブ情報の登録を登録順番を付して行なうことを特徴とする請求項9又は10に記載の負荷分散印刷方法。
  12. 複数の印刷装置に印刷データを送信することにより負荷を分散して印刷を行なう負荷分散印刷方法であって、
    前記複数の印刷装置に対応する複数のプリントキューについて、前記複数のプリントキューのうち、いずれか1つを基本プリントキューとして設定し、前記基本プリントキュー以外のプリントキューをバックアッププリントキューとして設定するプリントキュー設定ステップと、
    印刷ジョブ情報を前記基本プリントキューに登録する印刷ジョブ登録ステップと、
    前記基本プリントキューに登録された前記印刷ジョブ情報に対応するバックアップジョブ情報を生成して、出力対象として前記バックアッププリントキューに登録するバックアップジョブ登録ステップと、
    前記基本プリントキュー及び前記バックアッププリントキューのそれぞれにおいて、印刷ジョブ情報が登録されている場合には、優先的に該印刷ジョブ情報に対応する印刷データを、対応する印刷装置に対して出力し、印刷ジョブ情報が登録されておらず、出力対象のバックアップジョブ情報が登録されている場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始するジョブ制御ステップと、
    前記基本プリントキュー及び前記バックアッププリントキューにおいて、登録されている前記印刷ジョブ情報及びそれに対応するバックアップジョブ情報のいずれか1つが印刷装置への出力開始の対象となった場合に、出力開始の対象とならなかった前記バックアップジョブ情報を、出力対象ではないバックアップジョブ情報として前記バックアッププリントキューに保持させる第1保持制御ステップと、
    前記印刷装置で印刷中断が発生したことを検知するステップと、
    前記印刷装置で印刷中断が発生した場合に、印刷中断の対象となった印刷データに対応するバックアップジョブ情報を、出力対象としてバックアッププリントキューに保持させる第2保持制御ステップと、
    を含むことを特徴とする負荷分散印刷方法。
  13. 前記印刷装置の印刷中断が復旧する前に、前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷データに対応するバックアップジョブ情報が出力対象として登録された状態となった場合には、そのバックアップジョブ情報に対応する印刷ジョブ情報を生成して、生成した印刷ジョブ情報に対応する印刷データの、対応する印刷装置への出力を開始し、前記印刷装置において印刷中断対象の印刷データの処理をキャンセルする第2ジョブ制御ステップを有することを特徴とする請求項12に記載の負荷分散印刷方法。
  14. 前記基本プリントキュー及び前記バックアッププリントキューのいずれかにおいて、印刷ジョブ情報が登録されておらず、印刷中断対象の印刷ジョブ情報に対応するバックアップジョブ情報が出力対象として登録された状態となる前に、前記印刷装置の印刷中断が復旧した場合には、復旧した印刷装置に存在する印刷データの印刷を実行し、印刷完了後、前記第2保持制御ステップで保持された前記バックアップジョブ情報を削除することを特徴とする請求項12または13に記載の負荷分散印刷方法。
  15. 請求項8から14の何れかに記載の負荷分散印刷方法をコンピュータに実行させるための制御プログラム。
  16. 請求項15に記載のプログラムをコンピュータ可読の形態で記憶した記憶媒体。
JP2003416617A 2003-12-15 2003-12-15 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム Expired - Fee Related JP3854963B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2003416617A JP3854963B2 (ja) 2003-12-15 2003-12-15 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム
US10/999,922 US7916315B2 (en) 2003-12-15 2004-12-01 Method and apparatus for executing load distributed printing

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2003416617A JP3854963B2 (ja) 2003-12-15 2003-12-15 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム

Publications (2)

Publication Number Publication Date
JP2005174210A true JP2005174210A (ja) 2005-06-30
JP3854963B2 JP3854963B2 (ja) 2006-12-06

Family

ID=34650632

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2003416617A Expired - Fee Related JP3854963B2 (ja) 2003-12-15 2003-12-15 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム

Country Status (2)

Country Link
US (1) US7916315B2 (ja)
JP (1) JP3854963B2 (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009146312A (ja) * 2007-12-17 2009-07-02 Canon Inc 印刷システム及び印刷装置及びその印刷制御方法
JP2015036860A (ja) * 2013-08-12 2015-02-23 キヤノン株式会社 情報処理装置及び情報処理方法、情報処理システム、プログラム
JP2020119016A (ja) * 2019-01-18 2020-08-06 キヤノン株式会社 クラウドプリントサービスに対応した印刷装置および印刷装置の制御方法およびプログラム

Families Citing this family (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3833213B2 (ja) * 2003-12-01 2006-10-11 キヤノン株式会社 情報処理装置、印刷システム、負荷分散印刷方法、及びプログラム並びに記憶媒体
JP4006392B2 (ja) * 2003-12-03 2007-11-14 キヤノン株式会社 情報処理装置、及び、制御プログラム
JP3927949B2 (ja) * 2003-12-10 2007-06-13 キヤノン株式会社 情報処理装置、負荷分散印刷方法、プログラム、及び記憶媒体
JP4007358B2 (ja) * 2004-10-07 2007-11-14 コニカミノルタビジネステクノロジーズ株式会社 ジョブ実行装置およびその制御方法、画像形成装置、ならびにコンピュータプログラム
KR100727946B1 (ko) * 2005-06-29 2007-06-14 삼성전자주식회사 오프라인 상태의 화상 형성 장치에 대한 인쇄 작업 제어방법 및 장치.
US7512677B2 (en) * 2005-10-20 2009-03-31 Uplogix, Inc. Non-centralized network device management using console communications system and method
KR100793971B1 (ko) * 2005-12-20 2008-01-16 삼성전자주식회사 마우스 팝업 메뉴를 이용하여 인쇄하는 방법 및인쇄제어장치
JP4411271B2 (ja) * 2005-12-20 2010-02-10 キヤノン株式会社 印刷システム、印刷装置および制御装置
JP2007237693A (ja) * 2006-03-10 2007-09-20 Oki Data Corp 画像処理装置
JP2008040841A (ja) * 2006-08-07 2008-02-21 Konica Minolta Business Technologies Inc 出力管理サーバおよびデータ出力システム
JP4857102B2 (ja) * 2006-12-22 2012-01-18 キヤノン株式会社 情報処理装置、ジョブ処理方法、プログラム及び記憶媒体
US8224098B2 (en) * 2007-06-15 2012-07-17 Microsoft Corporation Façade rendering system
JP4944682B2 (ja) * 2007-06-22 2012-06-06 キヤノン株式会社 印刷制御装置、印刷制御方法、プログラム及び記憶媒体
US9223530B2 (en) 2008-02-26 2015-12-29 Konica Minolta Laboratory U.S.A., Inc. Multi-tiered constraint checking for managing print jobs
JP2009297994A (ja) * 2008-06-12 2009-12-24 Ricoh Co Ltd 印刷装置、印刷システムおよびプログラム
JP5381009B2 (ja) * 2008-10-20 2014-01-08 セイコーエプソン株式会社 デバイス制御システム
US20110055899A1 (en) * 2009-08-28 2011-03-03 Uplogix, Inc. Secure remote management of network devices with local processing and secure shell for remote distribution of information
US20110055367A1 (en) * 2009-08-28 2011-03-03 Dollar James E Serial port forwarding over secure shell for secure remote management of networked devices
US20130258377A1 (en) * 2010-03-31 2013-10-03 Canon Kabushiki Kaisha Printer control system, printing method, and storage medium
JP6080574B2 (ja) * 2013-02-01 2017-02-15 キヤノン株式会社 情報処理装置、情報処理システム、情報処理方法
JP2015191452A (ja) * 2014-03-28 2015-11-02 セイコーエプソン株式会社 記録装置、記録システム、記録媒体、プログラム、およびプログラム記憶媒体
JP2018158554A (ja) * 2017-03-23 2018-10-11 キヤノン株式会社 印刷装置、印刷装置の制御方法、およびプログラム
US11010116B1 (en) 2017-08-22 2021-05-18 Hewlett-Packard Development Company, L.P. Print job backup

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06259206A (ja) 1993-03-09 1994-09-16 Ricoh Co Ltd ネットワ−クプリンタ最適化方法
US6213652B1 (en) * 1995-04-18 2001-04-10 Fuji Xerox Co., Ltd. Job scheduling system for print processing
JP2000035867A (ja) * 1998-05-12 2000-02-02 Canon Inc 印刷制御装置、情報処理装置、印刷システム、印刷制御方法、情報処理方法、印刷方法、プログラムが格納されたコンピュ―タが読取可能な記録媒体
JP3254677B2 (ja) * 1998-09-08 2002-02-12 セイコーエプソン株式会社 プリンタ及び印刷方法
EP1376333A3 (en) * 2002-06-26 2007-10-17 Canon Kabushiki Kaisha Print control apparatus, print control method, program product, and print system
JP3833213B2 (ja) * 2003-12-01 2006-10-11 キヤノン株式会社 情報処理装置、印刷システム、負荷分散印刷方法、及びプログラム並びに記憶媒体
JP4006392B2 (ja) * 2003-12-03 2007-11-14 キヤノン株式会社 情報処理装置、及び、制御プログラム
JP3927949B2 (ja) * 2003-12-10 2007-06-13 キヤノン株式会社 情報処理装置、負荷分散印刷方法、プログラム、及び記憶媒体

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009146312A (ja) * 2007-12-17 2009-07-02 Canon Inc 印刷システム及び印刷装置及びその印刷制御方法
JP2015036860A (ja) * 2013-08-12 2015-02-23 キヤノン株式会社 情報処理装置及び情報処理方法、情報処理システム、プログラム
JP2020119016A (ja) * 2019-01-18 2020-08-06 キヤノン株式会社 クラウドプリントサービスに対応した印刷装置および印刷装置の制御方法およびプログラム
JP7204497B2 (ja) 2019-01-18 2023-01-16 キヤノン株式会社 クラウドプリントサービスに対応した印刷装置および印刷装置の制御方法およびプログラム

Also Published As

Publication number Publication date
JP3854963B2 (ja) 2006-12-06
US7916315B2 (en) 2011-03-29
US20050128512A1 (en) 2005-06-16

Similar Documents

Publication Publication Date Title
JP3854963B2 (ja) 情報処理装置、印刷システム、負荷分散印刷方法、及び制御プログラム
US8045202B2 (en) Information processing apparatus and print device control method
JP3833213B2 (ja) 情報処理装置、印刷システム、負荷分散印刷方法、及びプログラム並びに記憶媒体
JP4018622B2 (ja) 情報処理装置、情報処理システム、情報処理方法、及び情報処理プログラム並びに記憶媒体
US7719703B2 (en) Print control program and medium and information processing apparatus
JP4854608B2 (ja) 印刷制御装置、印刷制御方法、及びプログラム
JP3774702B2 (ja) 印刷制御プログラム及び情報処理装置
JP3927949B2 (ja) 情報処理装置、負荷分散印刷方法、プログラム、及び記憶媒体
US20070091361A1 (en) Printer, print control method, and program for executing print control method
JP4971778B2 (ja) 印刷管理装置、印刷管理方法、及びコンピュータプログラム
JP2003316545A (ja) 情報処理装置及び方法
US7839518B2 (en) Print control method, information processing apparatus, printing system, print control program and record medium
JP2009037488A (ja) 印刷ジョブの制御方法及びその印刷システムと情報処理装置と印刷装置
JP4886501B2 (ja) 印刷装置、印刷制御方法、及びプログラム
JP4174523B2 (ja) 情報処理装置、印刷システム、負荷分散印刷方法、及びプログラム、並びに記憶媒体
JP4110021B2 (ja) 部門管理を伴う印刷処理を行う印刷処理プログラム及び情報処理装置及び情報処理方法並びに記憶媒体
JP2005332227A (ja) 情報処理装置及び管理方法及びプログラム並びに記憶媒体
JP2005173921A (ja) 情報処理装置、印刷システム、及び情報処理方法、及び制御プログラム
JP3840226B2 (ja) 印刷制御プログラム及び媒体及び情報処理装置
JP2012059280A (ja) 印刷装置、データ処理装置、印刷制御方法、及びプログラム
JP4776763B2 (ja) プリントサーバ装置及び情報処理装置及び印刷ジョブ保存管理方法、及び保存ジョブ生成方法および記憶媒体
JP2005196439A (ja) 印刷システムにおける印刷データの制御方法および制御プログラム

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20060814

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20060828

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20060911

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090915

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100915

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100915

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110915

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110915

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120915

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120915

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130915

Year of fee payment: 7

LAPS Cancellation because of no payment of annual fees