This application is based on and claims priority under 35 USC 119 from Japanese Patent Application No. 2012-254393 filed Nov. 20, 2012.
The present invention relates to an information processing apparatus, an information processing method, and a non-transitory computer readable medium.
According to an aspect of the invention, there is provided an information processing apparatus including a plurality of communication interfaces connected to a plurality of communication networks that are independent from each other, the plurality of communication interfaces each receiving data from a terminal connected to at least one of the plurality of communication networks, the plurality of communication interfaces each transmitting data to the terminal on a basis of terminal identification information, the terminal identification information indicating a position of the terminal on the at least one of the plurality of communication networks, a first acquiring section that acquires the terminal identification information of a destination terminal that is a destination of data, and service information indicating a service that can be executed in the destination terminal, a second acquiring section that acquires service information indicating a service that can be executed in a candidate terminal, the candidate terminal being a candidate of a destination of data, the candidate terminal having the same terminal identification information as the terminal identification information of the destination terminal in each of the communication networks, and a selecting section that selects one of the plurality of communication interfaces on a basis of the service information of the destination terminal and the service information of the candidate terminal.
Exemplary embodiment of the present invention will be described in detail based on the following figures, wherein:
An information processing apparatus, an information processing method, and a non-transitory computer readable medium according to an exemplary embodiment of the invention will be described with reference to the figures.
The information processing apparatus 1 is configured as a piece of equipment including a function as a printer, and a function as a scanner. The information processing apparatus 1 includes a controller 10, multiple communication interfaces (I/Fs) 21 and 22, a memory 3, a printer unit 4, a scanner unit 5, a display 6, and an operating unit 7.
The controller 10 includes, for example, an arithmetic section such as a central processing unit (CPU) and a memory such as a random access memory (RAM), and executes information processing in accordance with a program. The program may be provided from a computer readable information recording medium such as a CD-ROM, or may be provided via a communication line such as the Internet.
The communication I/Fs 21 and 22 are pieces of equipment for communicating with other apparatuses (for example, the terminals 91 and 92) via the communication networks 81 and 82, respectively. The first communication I/F 21 is connected to the first communication network 81, and can communicate with each of the terminals 91. The second communication I/F 22 is connected to the second communication network 82, and can communicate with each of the terminals 92. Specifically, the communication I/Fs 21 and 22 pass data received from the terminals 91 and 92, respectively, to the controller 10. The communication I/Fs 21 and 22 also transmit data accepted from the controller 10 to the terminals 91 and 92, respectively.
The memory 3 is, for example, a hard disk drive (HDD) or a solid state drive (SSD). A database that can be accessed by the controller 10 is built in the memory 3. The database may be built in another apparatus different from the information processing apparatus 1.
The printer unit 4 is a unit that implements a function as a printer. The printer unit 4 forms an image on the surface of a medium in accordance with an instruction from the controller 10. The scanner unit 5 is a unit that implements a function as a scanner. The scanner unit 5 outputs image data read from the surface of a medium to the controller 10.
The display 6 is, for example, a liquid crystal display panel. The operating unit 7 is, for example, a touch panel.
Each of the terminals 91 and 92 is, for example, a personal computer. Each of the terminals 91 and 92 transmits data to the information processing apparatus 1, or receives data from the information processing apparatus 1. For example, each of the terminals 91 and 92 transmits a print job to the information processing apparatus 1, or receives image data from the information processing apparatus 1.
Generally, when specifying the destination of data, terminal identification information indicating a position on a communication network such as an IP address is used.
However, because the information processing apparatus 1 according to the exemplary embodiment is connected to the multiple communication networks 81 and 82 that are independent from each other, situations may arise in which it is not possible to specify the destination of data by use of the above-mentioned terminal identification information alone. That is, situations may arise in which the terminal identification information of the terminal 91 connected to the communication network 81, and the terminal identification information of the terminal 92 connected to the communication network 82 overlap. In such situations, it is not clear to which one of these terminals 91 and 92 data should be transmitted.
Accordingly, in the exemplary embodiment, in view of the above-mentioned circumstances, the processing described below is executed.
In the exemplary embodiment, the information processing apparatus 1 and each of the terminals 91 and 92 can communicate with each other in accordance with Simple Network Management Protocol (SNMP). For example, the information processing apparatus 1 receives a data unit Get Request (hereinafter, simply referred to as “Get Request”) including management information of each of the terminals 91 and 92, from each of the terminals 91 and 92. The information processing apparatus 1 also transmits a data unit Trap (hereinafter, referred to as Trap notification) which notifies when a problem such as a paper jam occurs, to each of the terminals 91 and 92.
Multiple versions exist for SNMP. Legacy Versions 1 and 2 and the latest Version 3 differ greatly in areas such as security. In the exemplary embodiment, it is assumed that some of the terminals 91 and 92 can execute Version 3 of SNMP, and other some of the terminals 91 and 92 cannot execute Version 3 of SNMP but can execute Versions 1 and 2 of SNMP.
The user information is, for example, the log-on user name of each of the terminals 91 and 92. The terminal information is, for example, the terminal name of each of the terminals 91 and 92. The terminal identification information is, for example, the IP address of each of the terminals 91 and 92. These pieces of information are included in, for example, Get Request transmitted from each of the terminals 91 and 92 to the information processing apparatus 1. Each of the terminals 91 and 92 transmits Get Request to the information processing apparatus 1 at predetermined timing such as at activation, and the information processing apparatus 1 extracts various information from the received Get Request.
The SNMP version support information indicates, for example, whether or not each of the terminals 91 and 92 supports Version 3 (v3), and whether or not each of the terminals 91 and 92 supports Versions 1 and 2 (v1/v2). As will be described later, the SNMP version support information is acquired from each of the terminals 91 and 92 when the information processing apparatus 1 narrows down the node that is the destination of Trap notification.
The exemplary embodiment is not limited to this but acquisition of the SNMP version support information may be performed at predetermined timing. For example, the SNMP version support information may be acquired with reception of Get Request by the information processing apparatus 1 from each of the terminals 91 and 92 as a trigger, or may be acquired with communication between the information processing apparatus 1 and each of the terminals 91 and 92 via a protocol different from SNMP as a trigger. Moreover, the SNMP version support information may be acquired at activation of the information processing apparatus 1, when the information processing apparatus 1 receives an arbitrary packet, at predetermined time intervals, or the like.
The history database is built in the memory 3 as described above. The controller 10 can reference information stored in the history database.
In S21, the controller 10 determines whether or not to perform Trap notification. It is determined to perform Trap notification when, for example, a problem such as a paper jam has occurred. In a case where it is determined to perform Trap notification (S21: YES), the processing proceeds to S22.
In S22, the controller 10 acquires information of a destination terminal that is the destination of Trap notification. Information of a destination terminal includes, for example, the IP address of the destination terminal, and information of the SNMP version that can be executed in the destination terminal. Information of a destination terminal may also include user information indicating the user of the destination terminal. Information of a destination terminal is stored in advance in, for example, the memory 3. In this way, the controller 10 functions as an example of the first acquiring section that acquires information of a destination terminal.
Because the information processing apparatus 1 is connected to the multiple communication networks 81 and 82 that are independent from each other, there is a possibility that there may exist a node (terminal) having the same IP address as that of the above-mentioned destination terminal in each of the communication networks 81 and 82. Accordingly, by the following procedure, the controller 10 narrows down the node that is the destination of Trap notification.
In S23, the controller 10 outputs Packet Internet Grouper (ping) to the same IP address as that of the above-mentioned destination terminal in each of the communication networks 81 and 82, and checks whether or not there is a response.
In S24 and S25, the controller 10 acquires information of the SNMP version that can be executed in each node that has responded to ping. Specifically, authentication as to whether or not Version 3 (v3) of SNMP is supported is performed in S24, and authentication as to whether or not Versions 1 and 2 (v1/v2) of SNMP are supported is performed in S25. Each node that has responded to ping is a candidate terminal as a candidate of the destination of Trap notification, which has the same IP address as that of the above-mentioned destination terminal in each of the communication networks 81 and 82. In this way, the controller 10 functions as the second acquiring section that acquires information of the SNMP version that can be executed in each candidate terminal.
In S26, the controller 10 narrows down the node that is the destination of Trap notification, on the basis of the information of the SNMP version of the destination terminal acquired in S22 mentioned above, and the information of the SNMP version of each candidate terminal acquired in S24 and S25 mentioned above. Consequently, it is determined which one of the multiple communication I/Fs 21 and 22 is to be used for Trap notification. In this way, the controller 10 functions as an example of the selecting section that selects one of the multiple communication I/Fs 21 and 22.
For example, the controller 10 determines that it is possible to narrow down the node in a case where there is only one candidate terminal whose SNMP version information matches that of the destination terminal. Specifically, it is determined that it is possible to narrow down the node in a case where the destination terminal supports Version 3 of SNMP, and only one candidate terminal supports Version 3 of SNMP. Likewise, it is determined that it is possible to narrow down the node also in a case where the destination terminal supports Versions 1 and 2 of SNMP, and only one candidate terminal supports Versions 1 and 2 of SNMP.
The controller 10 determines that it is not possible to narrow down the node in a case where there are multiple or zero candidate terminals whose SNMP version information matches that of the destination terminal.
In a case where it is possible to narrow down the node (S27: YES), the processing proceeds to S28. In S28, the controller 10 sets the candidate terminal whose SNMP version information matches that of the destination terminal as the destination of Trap notification, and executes Trap notification by using one of the multiple communication I/Fs 21 and 22 that is selected as a result of this setting.
In a case where it is not possible to narrow down the node (S27: NO), the processing proceeds to S29, where the controller 10 transmits a warning mail indicating that it is not possible to narrow down the node to the administrator or the like.
While in the exemplary embodiment mentioned above the controller 10 acquires SNMP version information from each candidate terminal when narrowing down the node that is the destination of Trap notification, this should not be construed restrictively. The controller 10 may acquire SNMP version information from many terminals 91 and 92 in advance and store the acquired SNMP version information in the history database, and acquire the SNMP version information of each candidate terminal from the history database.
In addition, the controller 10 may use not only SNMP version information but also user information when narrowing down the node that is the destination of Trap notification. In this case, the controller 10 acquires user information of the destination terminal in S22 mentioned above, and acquires user information of each candidate terminal either directly from the candidate terminal or from the history database.
While the exemplary embodiment of the invention has been described above, the invention is not to be limited to the above-mentioned exemplary embodiment. Obviously, many modifications and variations will be apparent to practitioners skilled in the art.
Number | Date | Country | Kind |
---|---|---|---|
2012-254393 | Nov 2012 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5771457 | Tsutsui | Jun 1998 | A |
6006272 | Aravamudan et al. | Dec 1999 | A |
6157950 | Krishnan | Dec 2000 | A |
6208656 | Hrastar et al. | Mar 2001 | B1 |
6434627 | Millet et al. | Aug 2002 | B1 |
6463061 | Rekhter et al. | Oct 2002 | B1 |
6865613 | Millet et al. | Mar 2005 | B1 |
7315903 | Bowden | Jan 2008 | B1 |
7568047 | Aysan et al. | Jul 2009 | B1 |
8060587 | Ahmad et al. | Nov 2011 | B2 |
8392998 | Schrecker et al. | Mar 2013 | B1 |
8495745 | Schrecker et al. | Jul 2013 | B1 |
20020038382 | Ryu et al. | Mar 2002 | A1 |
20020097182 | Goren et al. | Jul 2002 | A1 |
20020098852 | Goren et al. | Jul 2002 | A1 |
20020136210 | Boden et al. | Sep 2002 | A1 |
20020165982 | Leichter et al. | Nov 2002 | A1 |
20030016672 | Rosen et al. | Jan 2003 | A1 |
20030161295 | Shah et al. | Aug 2003 | A1 |
20040088542 | Daude et al. | May 2004 | A1 |
20040093492 | Daude et al. | May 2004 | A1 |
20040240446 | Compton | Dec 2004 | A1 |
20040255329 | Compton et al. | Dec 2004 | A1 |
20050195823 | Chen et al. | Sep 2005 | A1 |
20060013211 | Deerman et al. | Jan 2006 | A1 |
20060088031 | Nalawade | Apr 2006 | A1 |
20060125690 | Goren et al. | Jun 2006 | A1 |
20060146184 | Gillard et al. | Jul 2006 | A1 |
20060146870 | Harvey et al. | Jul 2006 | A1 |
20060160545 | Goren et al. | Jul 2006 | A1 |
20060209832 | Keller-Tuberg | Sep 2006 | A1 |
20070064683 | Furukawa | Mar 2007 | A1 |
20070160034 | Koretsky | Jul 2007 | A1 |
20070281678 | Lipsit | Dec 2007 | A1 |
20080140822 | Torii | Jun 2008 | A1 |
20080198851 | Yamaguchi et al. | Aug 2008 | A1 |
20090077650 | Yoda et al. | Mar 2009 | A1 |
20090113035 | Ohashi | Apr 2009 | A1 |
20100074267 | Ladd | Mar 2010 | A1 |
20100169467 | Shukla et al. | Jul 2010 | A1 |
20100169878 | Seki et al. | Jul 2010 | A1 |
20110051736 | Takenouchi | Mar 2011 | A1 |
20110055416 | Chen et al. | Mar 2011 | A1 |
20110153815 | Aoki | Jun 2011 | A1 |
20110286466 | Ge et al. | Nov 2011 | A1 |
20110292922 | Yang | Dec 2011 | A1 |
20120014386 | Xiong et al. | Jan 2012 | A1 |
20120307263 | Ichikawa et al. | Dec 2012 | A1 |
20130016392 | Lee | Jan 2013 | A1 |
20130027741 | Liu | Jan 2013 | A1 |
20130103801 | Hansen et al. | Apr 2013 | A1 |
20130103817 | Koponen et al. | Apr 2013 | A1 |
20130107318 | Yamada | May 2013 | A1 |
20130145002 | Kannan et al. | Jun 2013 | A1 |
20130145008 | Kannan et al. | Jun 2013 | A1 |
20130197998 | Buhrmann et al. | Aug 2013 | A1 |
20130287026 | Davie | Oct 2013 | A1 |
20130340084 | Schrecker et al. | Dec 2013 | A1 |
20140016638 | Chen et al. | Jan 2014 | A1 |
Number | Date | Country |
---|---|---|
2006-331289 | Jul 2006 | JP |
Number | Date | Country | |
---|---|---|---|
20140139865 A1 | May 2014 | US |