US20070174477A1 - Communication profiles for integrated database messaging system - Google Patents
Communication profiles for integrated database messaging system Download PDFInfo
- Publication number
- US20070174477A1 US20070174477A1 US11/337,256 US33725606A US2007174477A1 US 20070174477 A1 US20070174477 A1 US 20070174477A1 US 33725606 A US33725606 A US 33725606A US 2007174477 A1 US2007174477 A1 US 2007174477A1
- Authority
- US
- United States
- Prior art keywords
- database
- profile
- profiles
- message
- user
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L61/00—Network arrangements, protocols or services for addressing or naming
- H04L61/45—Network directories; Name-to-address mapping
- H04L61/4547—Network directories; Name-to-address mapping for personal communications, i.e. using a personal identifier
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/10—Network architectures or network communication protocols for network security for controlling access to devices or network resources
- H04L63/102—Entity profiles
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/2866—Architectures; Arrangements
- H04L67/30—Profiles
- H04L67/306—User profiles
Definitions
- the present invention is in the field of data processing systems and, in particular, to systems, methods and media for providing communication profiles for an integrated database messaging system for communications between database client users and database administrators.
- Computer systems such as personal computers (PCs), servers, workstations, and mainframes are well known in the art. Computer systems have attained widespread use for providing computing power to many segments of today's modem society.
- One important function for computer systems is to access, modify, and share information. To accomplish this, information is often stored in a database so that it may be shared among many computer systems.
- Databases typically have a database manager to facilitate access, manipulation, or storage of the information in the database by other computer systems.
- the database manager may typically execute on a database server while computer systems using the database may serve as database clients in a client-server relationship.
- Example database managers include International Business Machine Corporation's (IBM®'s) DB 2 ® database management system, Microsoft Corporation's Microsoft® SQL Server system, Oracle Corporation's Oracle® database management system, or Sybase, Inc.'s ® database management system.
- Database servers and their clients may run on various operating system platforms and database clients (and their applications) communicate with the database server in order to obtain data from the server.
- a database administrator may be responsible for managing the environmental aspects of a database such as recoverability, resource management, integrity, security, availability, performance, and development and testing support.
- Database server support commonly offers the ability for the database server to notify the DBA of events (such as table locks) for which the DBA has requested notification as well as sending return codes (such as error, warning or informational codes) to a connected application.
- a DBA wishes to inform database client users of particular events, such as when the database needs to be taken down or recycled for maintenance, when the database has performance problems, or other occurrences.
- the DBA may provide better service to database clients and reduce the frustration some database client users feel when the database becomes unavailable for reasons unknown to them.
- IM instant messaging
- This solution suffers from a significant problem in that the DBA must know the IM identity of the database client user who is connected to the database in order to send them an IM message.
- the DBA will not know which particular database client users are connected at any given time and therefore cannot effectively send them IM messages.
- DBAs and database client users often change (such as for different shifts) and are often remote, increasing the difficulty of knowing which database client users are presently using the database.
- Such a solution may also rely on the availability of an IM server to forward the message, as well as both sender and receiving being logged on, further limiting the usefulness of IM.
- database client users do not have an effective and efficient mechanism to communicate with a DBA.
- database client users often do not know the identity of DBAs, they cannot easily contact the DBAs via phone, e-mail, or IM message.
- Embodiments may include a method for providing communication profiles for an integrated database messaging system.
- Embodiments of the method may include receiving from a user of the database messaging system a request for one or more profiles and determining one or more profiles associated based on the attributes of each profile request by accessing a profile database.
- the one or more profiles may include an indication of a user of the database messaging system and an Internet Protocol (IP) address.
- IP Internet Protocol
- Embodiments may also include providing the one or more determined profiles to the requesting user. Further embodiments may include receiving an indication of one or more changes to the profile database and modifying the profile database.
- the user may include a database administrator (DBA) or database client user.
- DBA database administrator
- Each profile may contain personal, organizational, contact, group or other types of information.
- the profile request includes an indication of a group of users and the method may further include receiving a message request and transmitting a message to the IP addresses associated with the profiles of the group of users.
- Another embodiment provides a machine-accessible medium containing instructions effective, when executing in a data processing system, to cause the system to perform a series of operations for communicating between database client users and administrators.
- the series of operations generally includes receiving from a user of the database messaging system a request for one or more profiles and determining one or more profiles associated based on the attributes of each profile request by accessing a profile database.
- the one or more profiles may include an indication of a user of the database messaging system and an Internet Protocol (IP) address.
- IP Internet Protocol
- Embodiments may also include a series of operations for providing the one or more determined profiles to the requesting user. Further embodiments may include a series of operations for receiving an indication of one or more changes to the profile database and modifying the profile database.
- a further embodiment provides a database messaging system.
- the database messaging system may generally include a database server having a database messaging module to transmit a message to a determined IP address, where the determined IP address is associated with a database client.
- the database messaging system may also include one or more database clients in communication with the database server and each having a client listener, where each client listener may receive a message from the database server and display the received message.
- the database messaging system may also include a profile database and a communication profile module to receive a request from a user of the database messaging system for a profile associated with, for example, combinations of an IP address, a database name, and/or a group name, or other pertinent attributes.
- the communications profile module may also determine one or more profiles based on the profile request by accessing the profile database.
- the communications profile module and profile database may be located on the database client and/or the database server.
- FIG. 1 depicts an environment for a database messaging system with a database server and one or more database clients according to one embodiment
- FIG. 2 depicts a block diagram of one embodiment of a computer system suitable for use as a component of the database messaging system
- FIG. 3 depicts a conceptual illustration of software components of a database server with a database messaging module and a communication profile module according to one embodiment
- FIG. 4 depicts a conceptual illustration of software components of a database client with a client messaging module and a communication profile module according to one embodiment
- FIG. 5 depicts an example of a flow chart for receiving a message request and transmitting a message to one or more database clients according to one embodiment
- FIG. 6 depicts an example of a flow chart for receiving a message from a database server, displaying the message to a database client user, and transmitting a message to a DBA according to one embodiment
- FIG. 7 depicts an example of a flow chart for receiving a request for a profile, determining a profile, and transmitting the profile according to one embodiment.
- the system and methodology of the disclosed embodiments provides for an effective and efficient way of providing communication between a DBA and database client users.
- the disclosed database messaging system provides a mechanism for a DBA to send a message to database client users without knowing their identity by facilitating transmittal of the message to the IP address of the user's database client and displaying the message to the user at the database client.
- the disclosed system provides a mechanism for database client users to transmit a message to the DBA at the IP address of the database server without knowing the identity of the DBA. While such a system provides an effective means for communication between DBAs and database client users, it is often desired to know more information about the database client user and/or DBA than just the IP address.
- the disclosed system and methodology for providing communication profiles advantageously provides personal information, organizational information, contact information, group information or other types of information to DBAs and database client users. For situations where transmission of a message to a generic IP address is unsatisfactory, the disclosed system may accordingly provide a more robust and useful solution.
- a database client user or DBA may, in one example, use contact information in a profile to e-mail or call someone who is not responding to messages displayed at their IP address.
- a DBA may search for profiles associated with a group of database client users who use the same application and, upon accessing the profiles, may send a message to the IP address of each database client associated with those database client users.
- the DBA of this example may effectively broadcast messages to these users utilizing profile selection and groups of profiles.
- the use of profiles may also support the creation and gathering of metrics and statistics for the database messaging system 100 .
- the profiles may be scanned to extract relevant information and attributes to generate reports or perform other tasks.
- FIG. 1 depicts an environment for a database messaging system with a database server and one or more database clients according to one embodiment.
- the database messaging system 100 may include one or more database clients 102 in communication with a database server 106 via a network 104 as well as a database 110 in communication with the database server 106 .
- Each database client 102 may include a database application 112 to access the database 110 through the database server 106 .
- Database client 102 may facilitate communications between database client users and the database server 106 .
- the database server 106 may manage communications to and operations with database 110 and may also, as described in more detail subsequently, facilitate communications from a DBA to users of the database clients 102 and from database client users to the DBA.
- either or both of the database client 102 and the database server 106 may include a communication profile module 118 to provide profiles for users of the database messaging system 100 .
- the profiles may include information about users that allows other users to find out more information about the users, contact those users via other means, or perform other tasks.
- Users of the database messaging system 100 may include both database client users and DBAs as well as other users.
- any of the database clients 102 , the database server 106 , and the database 110 may be located at the same location, such as in the same building or computer lab, or could be remote. While the term “remote” is used with reference to the distance between the components of the database messaging system 100 , the term is used in the sense of indicating separation of some sort, rather than in the sense of indicating a large physical distance between the systems. For example, any of the components of the database messaging system 100 may be physically adjacent or located as part of the same computer system in some network arrangements.
- Each database client 102 may include one or more personal computers, workstations, servers, mainframe computers, notebook or laptop computers, desktop computers, PDAs, set-top boxes, mobile phones, wireless devices, or the like.
- a database client 102 may be a computer system as described in relation to FIG. 2 .
- the database client 102 may be in wired or wireless communication with network 104 .
- a database client user may utilize a database client 102 and its database application 112 to facilitate the access, viewing, and use of content on database 110 through the use of database server 106 .
- Application 112 may include any type of executable application that accesses database 110 , such as an application that uses files from database 110 , a word processor, a spreadsheet, business applications (e.g., industry-specific software), a browser, or any other type of application.
- Each database client 102 may include a client listener 114 and a client transmitter 116 as part of a client messaging module, as described in more detail in relation to FIG. 4 .
- the client listener 114 may receive messages from the DBA through the database server 106 , generate a display window (such as a new window or pop-up window) or utilize an existing window, and display the message to a database client user.
- the client listener 114 may monitor a predetermined port and act as a server on the database client 102 machine.
- the client listener 114 may optionally be incorporated into the database application 112 or any database management software installed on the database client 102 .
- the client transmitter 116 may receive a request to transmit a message to a DBA from a database client user, determine the IP address of the database server 106 , and transmit the message to the database server 106 , which in turn provides the message to the DBA.
- the client transmitter 116 may thus act as a client on the database client 102 with respect to the database server 106 .
- a database client 102 may also include a communication profile module 118 .
- the database server 106 may also have a communication profile module 118 that either works independently of or in conjunction with that of the database client 102 .
- a communication profile module 118 may have a profile database for storing profiles and/or may be in communication with other communication profile modules 118 on other systems and their profile databases.
- a communication profile module 118 of a database client 102 may, for example, access a local profile database or a profile database located at the database server 106 to find a profile for a DBA based on an IP address and/or database name.
- the communication profile module 118 may determine any profiles associated with an IP address and provide the profile to the database client user, such as by displaying it to the database client user using a GUI or other interface.
- a database client user with proper authorization may also add or edit their profiles or those of others, allowing for efficient updating of profiles in the database.
- only a DBA will have access to modify database profiles.
- a database client user may have the ability to modify part of their profile while others parts are restricted (e.g., database client user can modify home phone number but not supervisor).
- Profiles may include any type of information, including personal information, organizational information, or contact information, associated with a user such as a database client user or DBA.
- Personal information may include any information associated with the database client user, such as their name, address, shift hours, office location, authorizations, applications they have access to, etc., or similar information for a DBA.
- Organizational information may include any information associated with a user's place within an organization, such as the user's title, job responsibilities, supervisor's name or contact information, organizational/reporting structure, term of service, etc.
- Contact information may include any information associated with communication with a user, such as the user's phone number, alternative phone number, fax number, pager number, e-mail address, Internet address, MAC address, alternative contact information, an ‘away’ message, etc.
- Profiles may also include group information, which may be an indication of one or more groups, or collections, to which the user belongs. These groups may, in some embodiments, may be based on other types of profile information, such as applications, organizational structures, etc. Groups may also be defined by a user of the database messaging system 100 .
- a database client user may, for example, define a group of DBAs with whom they frequently work.
- a DBA may, in another example, define a group of database client users who use a particular application, who want to be notified of particular events (e.g., updates, system interruptions, etc.), etc.
- the same profile information may be copied into multiple groups, potentially saving time when new users are added or other situations.
- Network 104 may be any type or combination of data communications channel(s), such as the Internet, an intranet, a local area network (LAN), a wide area network (WAN), an Ethernet network, a wireless network, a proprietary network, or a broadband cable network.
- a corporate intranet implemented on a LAN may serve as network 104 for communications between components of a corporate database messaging system 100 .
- Those skilled in the art will recognize, however, that the invention described herein may be implemented utilizing any type of data communications channel or combinations of data communication channels.
- the database server 106 provides an interface between database clients 102 and database 110 by facilitating access, manipulation, and storage of information in database 110 by database applications 112 of the database clients 102 .
- the database server 106 may be one or more of any type of computer system, including servers, personal computers, workstations, mainframe computers, notebook or laptop computer, desktop computers, or the like. In some embodiments, the database server 106 may be a computer system as described in relation to FIG. 2 .
- An example database server 106 is an IBM® eServerg server or similar server. In this example, the database server 106 may include software such as IBM®'s DB2® database management system application that provides an effective and robust database platform.
- the database server 106 may include modules such as a communication profile module 118 , a database manager 120 , a database monitor 122 , a database messaging transmitter 124 , a DBA interface module 126 , and a database listener 128 .
- the database manager 120 may be a database management system such as IBM®'s DB2® database management system, Microsoft®'s SQL Server system, Oracle®'s database management system, or Sybase, Inc.'s ® database management system.
- the database manager 120 may facilitate access, manipulation, or storage of information in database 110 by database applications 112 of the database clients 102 .
- the database monitor 122 may monitor database 110 activities and may also allow database server support to communicate with the DBA.
- the database monitor 122 may monitor any type of database 110 activity, such as when records are inserted, updated, or deleted, deadlock of the database 110 , exceeding a predefined threshold for file system size.
- the database monitor 122 may log these activities and/or notify the DBA upon their occurrence.
- the database messaging transmitter 124 and DBA interface module 126 may provide for communications between the DBA to users of the database clients 102 .
- the DBA interface module 126 may receive a message request from a DBA or other person to be sent to one or more database client users via their database clients 102 .
- the DBA interface module 126 provides a graphical user interface (GUI) with which the DBA may input information.
- GUI graphical user interface
- the message request may include both message content (including message text, files for attachment, or other information) and an indication of the database client user or users to whom the message should be sent.
- a DBA or other authorized person may be using a separate DBA computer system, may be directly accessing database server 106 , or using another computer system.
- the database messaging transmitter 124 may then transmit a message to the network address (i.e., IP address) for each database client 102 .
- the database messaging transmitter 124 may effectively serve as a client to the client listener 114 of the receiving database clients 102 .
- Database servers 106 generally have access to the IP or other network address for all connected database clients 102 and may advantageously use this IP address to communicate with database client users.
- the database listener 128 may facilitate communications from users of the database clients 102 to the DBA.
- the database listener 128 (acting as a server with respect to the client transmitter 116 ) may receive a message transmitted to an IP address of the database server 106 and intended for a DBA, such as by monitoring one or more ports of the database server 106 .
- the database listener 128 may then provide the message to the DBA.
- the database 110 may be a collection of related information accessed and managed by a database management system such as database manager 120 .
- Database 110 may be any type of database, such as a hierarchical database or a relational database. Most modern databases are relational databases whose management systems restrict data access to a messaging protocol such as SQL, a nonprocedural language that allows a programmer to specify desired results.
- Example databases 110 may be consistent with management systems such as IBM®'s DB2® database management system, Microsoft®'s SQL Server system, Oracle®'s database management system, or Sybase, Inc.'s ® database management system.
- the data of database 110 may be stored on one or more storage media such as hard drives, on a storage area network (SAN), tape backup, network attached storage (NAS), or in any other fashion or combination of fashions.
- An example hardware solution to store a database 110 may be IBM®'s TotalStorage® line of disk storage systems.
- the database server 106 may also have a communications profile module 118 in addition to, or instead of, that of the database client 102 .
- the communication profile module 118 of the database server 106 may, in some embodiments, be substantially similar in function to that of the database client 102 and the description will not be repeated in the interest of brevity.
- a DBA may use the communication profile module 118 to find out information about database client users, such as when they need to contact one via phone after they failed to respond to messages to their IP address.
- a DBA with proper authorization may also add or edit their profiles or those of others, allowing for efficient updating of profiles in the database.
- a DBA may only have authorization over a sub-group of database client users or databases.
- a DBA may send messages to individual or groups of database client users and database client users may likewise communicate with the DBA, providing for an effective and efficient mode of communication between database client users and DBAs.
- communication profile modules 118 both DBAs and database client users may advantageously access profiles for other users of the database messaging system 100 instead of relying solely on the IP address for that user's computer system.
- a DBA for example, that is trying to reach a database client user but is not getting a response may access the database client user's profile to find that user's contact information so that they may call, e-mail, etc.
- the DBA may be able to determine who is responsible for maintaining that client by accessing the profile.
- the DBA in this example may also be able to determine the organization and reporting structure to whom the responsible database client user reports.
- a database client user may be unhappy with the performance of the database client 102 and may request service from the assigned DBA. If such service is unsatisfactory, the database client user may access the DBA profile to contact the DBA or, alternatively, to contact the DBA's supervisor for resolution.
- Users of the database messaging system 100 may also take advantages of groups of profiles to find others users or to broadcast messages to groups of users.
- the communication profile module 118 may be installed with the database or installed at a later time, such as part of an upgrade or a separate module.
- the communication profile modules 118 may be organized by node in some embodiments that includes both database clients 102 and a database server 106 , so that one or more DBAs administering a database server 106 and each of the database client users administering a database client 102 may have the ability to add data that would personalize the node.
- the profile database in this embodiment may be located at either the database server 106 , at one or more of the database clients 102 , or distributed over multiple computer systems.
- a central profile database may be located at the database server 106 and the communication profile modules 118 of the database clients 106 may access the central profile database either directly or through a communication profile module 118 of the database server 106 .
- FIG. 2 depicts a block diagram of one embodiment of a computer system 200 suitable for use as a component of the database messaging system 100 , such as a database client 102 or a database server 106 .
- a computer having capabilities other than those ascribed herein and possibly beyond those capabilities, and they may, in other embodiments, be any combination of processing devices such as workstations, servers, mainframe computers, notebook or laptop computers, desktop computers, PDAs, mobile phones, wireless devices, set-top boxes, or the like.
- At least certain of the components of computer system 200 may be mounted on a multi-layer planar or motherboard (which may itself be mounted on the chassis) to provide a means for electrically interconnecting the components of the computer system 200 .
- the computer system 200 includes a processor 202 , storage 204 , memory 206 , a user interface adapter 208 , and a display adapter 210 connected to a bus 212 .
- the bus 212 facilitates communication between the processor 202 and other components of the computer system 200 , as well as communication between components.
- Processor 202 may include one or more system central processing units (CPUs) or processors to execute instructions, such as an IBM® PowerPCTM processor, an Intel Pentium® processor, an Advanced Micro Devices Inc. processor, or any other suitable processor.
- the processor 202 may utilize storage 204 , which may be non-volatile storage such as one or more hard drives, tape drives, diskette drives, CD-ROM drive, DVD-ROM drive, or the like.
- the processor 202 may also be connected to memory 206 via bus 212 , such as via a memory controller hub (MCH).
- System memory 206 may include volatile memory such as random access memory (RAM) or double data rate (DDR) synchronous dynamic random access memory (SDRAM).
- the user interface adapter 208 may connect the processor 202 with user interface devices such as a mouse 220 or keyboard 222 .
- the user interface adapter 208 may also connect with other types of user input devices, such as touch pads, touch sensitive screens, electronic pens, microphones, etc.
- a database client user may input a desired message using the keyboard 222 of a database client 102 .
- the bus 212 may also connect the processor 202 to a display 214 , such as an LCD display or CRT monitor, via the display adapter 210 .
- a database client 102 that receives a message from the database server 106 , or a database server 106 that receives a message from a database client 102 may display that message in a window of display 214 in some embodiments.
- a database client 102 or database server 106 may also use display 214 to display a profile to a DBA or database client user, respectively.
- FIG. 3 depicts a conceptual illustration of software components of a database server with a database messaging module and a communication profile module according to one embodiment.
- the database server 106 of the depicted embodiment includes a communication profile module 118 , a database manager 120 , a database monitor 122 , a communications module 302 , a user interface module 304 , and a database messaging module 310 .
- the database messaging module 310 may include sub-modules such as a database messaging transmitter 124 , a DBA interface module 126 , a database listener 128 , an address module 312 , and a redirection module 314 .
- the communication profile module 118 , database manager 120 , database monitor 122 , database messaging transmitter 124 , DBA interface module 126 , and database listener 128 are described in relation to FIG. 1 and the description will not be repeated for the sake of brevity.
- the communication profile module 118 may include a profile database 330 and a profile user interface 332 .
- the profile database 330 may store one or more profiles for users of the database messaging system 100 .
- the stored profiles may optionally have an indication of one or more groups with which the profiles are associated.
- the profile user interface 332 may receive a request for a profile or group of profiles from a DBA, database client user, or other user.
- the profile user interface 332 may also display or otherwise provide a profile to a DBA, database client user or other user via GUI interface, text interface, or other means.
- the profile user interface 332 may work with the DBA interface module 126 to interface with a DBA.
- a DBA who sends a message to an IP address may, for example, also be presented with an option to see profiles associated with that IP address. In this fashion, a DBA may efficiently access profiles when transmission to an IP address is unsuccessful.
- a DBA receiving a message from a database client user may alternatively also be presented with the profile for that database client user so that they know the origin of the message.
- the profile user interface 332 may also facilitate modifications to profiles in a profile database 330 by the DBA.
- a DBA may also request a group of profiles and send a message to the IP addresses associated with the profiles in the group in order to broadcast a message to each user in the profiles simultaneously.
- the communications module 302 may facilitate communications to and from the database server 106 via network 104 , such as communications with database clients 102 .
- the user interface module 304 may receive user input from user input devices such as a mouse 220 or keyboard 222 and may also provide output to a user, such as via a display 214 or speaker.
- the database messaging module 310 and its components may receive message requests from a DBA to be sent to one or more database clients 102 , determine the IP addresses associated with the database clients 102 , and transmit a message to those IP addresses.
- the database messaging module 310 and its components may also receive messages transmitted from database clients 102 and display or otherwise provide those messages to DBAs.
- the DBA interface module 126 may receive the message request that includes message content and an indication of one or more database clients 102 to which the message will be sent.
- the DBA interface module 126 may also provide a GUI or text display of a received message to the DBA.
- the address module 312 may determine an IP address associated with each of the one or more database clients 102 to which a message will be sent, after which the database messaging transmitter 124 may transmit the message to the determined IP addresses.
- database servers 106 generally have access to the IP or other network address for all connected database clients 102 .
- the address module 312 may determine the IP addresses in a number of fashions. If a DBA submits a list of one or more IP addresses, the address module 312 may simply use those IP addresses (after optionally converting them to decimal format). If the DBA specifies a database name, the address module 312 may determine all of the IP addresses currently active with or associated with that database.
- duplicate IP addresses may be eliminated.
- the DBA may effectively broadcast a message to all connected database clients 102 without having to specify each individually.
- the address module 312 may determine the IP addresses associated with that group, such as by referencing a table. The address module 312 may use any methodology to translate the indication of database clients 102 received from the DBA to a list of one or more IP addresses.
- the database listener 128 may receive such message from a database client 102 by monitoring one or more ports of the database server 106 or other methodology.
- the redirection module 314 may provide additional flexibility in providing the content of the message to a DBA. If a DBA is local (i.e., with the database server 106 ), the DBA interface module 126 may display the message to the DBA, as described previously. The redirection module 314 may transmit the message to another device that the DBA is using when a DBA is remote from the database server 106 .
- FIG. 4 depicts a conceptual illustration of software components of a database client with a client messaging module and a communication profile module according to one embodiment.
- the database client 102 of the depicted embodiment includes a database application 112 , a communication profile module 118 , a communications module 402 , and a client messaging module 410 .
- the client messaging module 410 may include sub-modules such as a client listener 114 , a client transmitter 116 , an address module 412 , and a user interface module 414 .
- the database application 112 , client listener 114 , and client transmitter 116 are described in relation to FIG. 1 and the description will not be repeated for the sake of brevity.
- the communication profile module 118 may include a profile database 330 and a profile user interface 332 , as described previously in relation to FIG. 3 .
- the profile user interface 332 may receive a request for a profile or group of profiles from a database client user, such as a database client user requesting a profile for a DBA for the database application 112 they are using.
- the profile user interface 332 may display or otherwise provide a profile to database client user via GUI interface, text interface, or other means.
- a database client user may optionally be able to modify their own profile in the profile database 330 using the profile user interface 332 .
- the communications module 402 may facilitate communications to and from the database client 102 via network 104 , such as communications with database server 106 .
- the client messaging module 410 and its components may receive message requests from a database client user to be sent to the DBA, determine the IP addresses associated with the database server 106 , and transmit a message to that IP address.
- the client messaging module 410 and its components may also receive messages from a DBA through the database server 106 and may then display or otherwise provide the message to the user of the database client 102 .
- the client listener 114 and client transmitter 116 may provide for receipt and transmission of messages, respectively, for the client messaging module 410 .
- the address module 412 of the client messaging module 410 may determine an IP address associated with the database server 106 , after which the client transmitter 114 may transmit the message to the determined IP address.
- the address module 412 may determine the IP address in any fashion, such as requesting the IP address of the database server 106 from the database application 112 , which may need such information to provide access to database 110 .
- Database clients 102 generally have access to the IP or other network address for the database server 106 with which they are connected.
- the user interface module 414 may receive user input from user input devices such as a mouse 220 or keyboard 222 and may also provide output to a database client user, such as via a display 214 or speaker.
- the user interface module 414 may display the message using display 214 .
- a user may utilize a GUI or text interface of the user interface module 414 to view a message, input a new message, reply to a message, or request transmission of a message.
- FIG. 5 depicts an example of a flow chart for receiving a message request and transmitting a message to one or more database clients according to one embodiment.
- components of a database server 106 such as the database messaging module 310 and its components may perform the elements of flow chart 500 .
- flow chart 500 begins with element 502 , where the DBA interface module 126 of the database messaging module 310 may receive a message request from the DBA or other authorized person that includes message content that the DBA desires to send to one or more database clients 102 and/or database client users. As part of the receiving the message request, the DBA interface module 126 may also receive an indication of the one or more database clients 102 to receive the message at element 504 .
- the indication of database clients 102 to receive the message may be a list of IP addresses for the database clients 102 , a database name, a group name, or other indication or combination of indications.
- the message request may include both the message content (e.g., message text, file attachments) and the indication of database clients 102 .
- the address module 312 of the database messaging module 310 may determine the IP addresses associated with the database client 102 indications.
- the address module 312 may determine whether one or more IP addresses were received as the database client 102 indications. If IP addresses were received, the address module 312 may determine the IP addresses for the messaging recipients by converting those IP addresses as necessary, such as by converting them to the decimal format.
- the database messaging transmitter 124 may then transmit the message (based on the message content) to the selected IP addresses at element 508 .
- the address module 312 may determine whether one or more database names were received as part of the database client 102 indication.
- the method of flow chart 500 continues to element 512 , where the address module 312 may determine the IP addresses associated with the database name, such as by cross-referencing the database name with a list of IP addresses currently accessing that database. The address module 312 may also eliminate duplicate IP addresses that may occur when a database client 102 is logged in multiple times. The database messaging transmitter 124 may then transmit the message to the determined IP addresses at element 514 .
- the address module 312 may determine whether one or more group names were received as part of the user indication. If a group name was received, the method of flow chart 500 continues to element 518 , where the address module 312 may determine the IP addresses associated with the group name, such as by accessing the profiles associated with the group. The database messaging transmitter 124 may then transmit the message to the IP addresses at element 520 .
- Groups may be similar in functionality to ‘buddy lists’ in instant messaging (IM) systems or contact lists in e-mail applications. By specifying a group name, a DBA may efficiently select all the database client users within that group without having to input each IP address individually.
- a DBA may, for example, create a group associated with a particular database application that includes the profiles of database client users (including their IP addresses) that use the database application. By selecting this group, the DBA may efficiently inform all interested clients about the application, such as when it has been updated, when support will no longer be provided, etc.
- the database messaging transmitter 124 is depicted as potentially transmitting a message separately at elements 508 , 514 , and 520 , some or all of the transmission may be combined into one transmission before termination of method 500 .
- the received indication of one or more database clients 102 received as part of the message request may include a plurality of different methods for indicating database clients 102 .
- a message request may include a list of three IP address, a database name, and a group name.
- the database messaging transmitter 124 may transmit the message to all IP addresses simultaneously if so desired.
- the database server 106 may optionally receive a message from a database client user (through a database client 102 ) and display or otherwise provide that message to a DBA.
- Element 522 may occur when, for example, database client users respond to a DBA-transmitted message or when a database client user sends a message to the DBA to report a problem or for other reasons.
- the database listener 128 may generate a display window for the message, such as by creating such a display window or requesting another application to do so, or may utilize an existing window, such as a window created as part of an ongoing conversation between a DBA and database client user.
- the database server 106 may also optionally receive a request for a profile, such as when a DBA requests the profile of a database client user sending him or her a message.
- the communication profile module 118 may access the profiles for any of the determined IP addresses for the DBA at element 522 , after which the method terminates.
- FIG. 6 depicts an example of a flow chart for receiving a message from a database server, displaying the message to a database client user, and transmitting a message to a DBA according to one embodiment.
- components of a database client 102 may perform the elements of flow chart 600 .
- flow chart 600 begins with element 602 , where the client listener 114 of a database client 102 may receive a message from the database server 106 .
- the database client 102 executing the client listener 114 has an IP address matching one of the IP addresses determined by the address module 312 as described in relation to FIG. 5 .
- the client listener 114 may listen on a specified or pre-determined port of the database client 102 for the message. In doing so, the client listener 114 may act as the server on the database client 102 with respect to the database messaging transmitter 124 .
- the client listener 114 may optionally generate a display window for the message at element 604 , such as by creating such a display window or requesting another application to do so.
- a display window may be, for example, any aspect of a graphical user interface (GUI) that allows a message to be displayed such as a browser instantiation, a pop-up window, a text window, etc.
- GUI graphical user interface
- the client listener 114 may utilize an existing window, such as in the case of repeated messages from a DBA or an ongoing conversation.
- the client listener 114 may then, at element 606 , display the message in the generated display window, allowing a user of the database client 102 to view the message from the DBA.
- the display window may preempt other items on the database client user's display 214 so that they are more likely to see the message.
- the client listener 114 may also optionally determine whether to save the message in a message log at decision block 608 . If the message will be saved, the client listener 114 may store the message in a message log at element 610 .
- the database client user may desire to send a message to the DBA, such as to report a problem or to respond to a message received at element 602 . If it is determined at decision block 612 that no message is to be sent, the method of flow chart 600 may terminate. If a message is to be sent, the method continues to element 614 , where the user interface module 414 of the client messaging module 410 may receive a message request that the database client user desires to send to the DBA.
- the message request may include message content such as text, files, etc., as well as an intention to send the message to a DBA.
- the address module 412 may determine the IP address associated with the database server 106 at element 616 , such as by requesting such information from the application 112 or from detection when receiving a message.
- the client transmitter 116 may then, at element 618 , transmit the message to the database server IP address for display or redirection to the DBA.
- a database client user may request profile information for the DBA if the DBA is non-responsive or for other reasons.
- the communication profile module 118 may access the profiles for the server IP address at element 620 , after which the method terminates. The methodology for accessing profiles is described in relation to FIG. 7 .
- FIG. 7 depicts an example of a flow chart for receiving a request for a profile, determining a profile, and transmitting the profile according to one embodiment.
- a communication profile module 118 and its components may perform the elements of flow chart 700 .
- flow chart 700 begins with element 702 , where the profile user interface 332 may receive a request to modify a profile database 330 from a user.
- a user of the communication profile module 118 may include a database client user, a DBA, or any other user. If no request to modify the profile database 330 is received (as will typically be the case), the method of flow chart 700 continues to element 710 .
- the method of flow chart 700 continues to element 704 , where the profile user interface 332 may optionally receive authorization from the user to modify the profile database 330 . As described previously, authorization may be required to change some or all elements of a profile. Once authorization is received (if required), the profile user interface 332 may receive an indication of the changes at element 706 and may modify the profile database 330 at element 708 .
- the profile user interface 332 may receive a request from a user for any profiles associated with an IP address.
- a DBA may request a profile for a database client user or for all user profiles associated with a database client 102 and IP address.
- a database client user in another example, may request the profile of a DBA by requesting the profile associated with the database server 106 IP address and/or database name.
- the communication profile module 118 may then, at element 712 , determine the profile associated with the IP address by accessing the profile database 330 .
- the communication profile module 118 may use any methodology for this task, including by access a table of the profile database 330 that provides a list of profiles associated with a particular IP address and/or database name.
- the communication profile module 118 may then transmit the profiles associated with an IP address to the user at element 714 . Transmitting the profiles may include, for example, displaying the profiles to the user on a display 214 , transmitting the profiles to another component (such as a DBA interface module 126 or user interface module 414 ) for display to the user, or other methodology.
- Transmitting the profiles may include, for example, displaying the profiles to the user on a display 214 , transmitting the profiles to another component (such as a DBA interface module 126 or user interface module 414 ) for display to the user, or other methodology.
- the user interface for displaying profiles to a user may optionally provide for filtering. If the communication profile module 118 determines at decision block 716 that filtering will be used, it may filter the profiles associated with the IP address at element 718 . After filtering the profiles, the communication profile module 118 may transmit the filtered profiles at element 720 , after which the method terminates. Any type of filtering may be used.
- a DBA may wish to see the profiles associated with a particular application 112 and may accordingly request for profiles to be filtered by application 112 . In another example, a DBA may desire to filter based on database client user organizational position so that they may see where each user falls in an organizational hierarchy.
- routines executed to implement the embodiments of the invention may be part of an operating system or a specific application, component, program, module, object, or sequence of instructions.
- the computer program of the present invention typically is comprised of a multitude of instructions that will be translated by the native computer into a machine-readable format and hence executable instructions.
- programs are comprised of variables and data structures that either reside locally to the program or are found in memory or on storage devices.
- various programs described hereinafter may be identified based upon the application for which they are implemented in a specific embodiment of the invention. However, it should be appreciated that any particular program nomenclature that follows is used merely for convenience, and thus the invention should not be limited to use solely in any specific application identified and/or implied by such nomenclature.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Hardware Design (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Systems, methods and media for providing communication profiles for an integrated database messaging system are disclosed. Embodiments of the method may include receiving from a user of the database messaging system a request for one or more profiles and determining one or more profiles associated based on the attributes of each profile request by accessing a profile database. The one or more profiles may include an indication of a user of the database messaging system and an Internet Protocol (IP) address. Embodiments may also include providing the one or more determined profiles to the requesting user. Further embodiments may include receiving an indication of one or more changes to the profile database and modifying the profile database. The user may include a database administrator (DBA) or user of a database. Each profile may contain personal, organizational, contact, group or other types of information.
Description
- The present invention is in the field of data processing systems and, in particular, to systems, methods and media for providing communication profiles for an integrated database messaging system for communications between database client users and database administrators.
- Computer systems such as personal computers (PCs), servers, workstations, and mainframes are well known in the art. Computer systems have attained widespread use for providing computing power to many segments of today's modem society. One important function for computer systems is to access, modify, and share information. To accomplish this, information is often stored in a database so that it may be shared among many computer systems. Databases typically have a database manager to facilitate access, manipulation, or storage of the information in the database by other computer systems. The database manager may typically execute on a database server while computer systems using the database may serve as database clients in a client-server relationship. Example database managers include International Business Machine Corporation's (IBM®'s) DB2® database management system, Microsoft Corporation's Microsoft® SQL Server system, Oracle Corporation's Oracle® database management system, or Sybase, Inc.'s ® database management system. Database servers and their clients may run on various operating system platforms and database clients (and their applications) communicate with the database server in order to obtain data from the server.
- A database administrator (DBA) may be responsible for managing the environmental aspects of a database such as recoverability, resource management, integrity, security, availability, performance, and development and testing support. Database server support commonly offers the ability for the database server to notify the DBA of events (such as table locks) for which the DBA has requested notification as well as sending return codes (such as error, warning or informational codes) to a connected application. Often, a DBA wishes to inform database client users of particular events, such as when the database needs to be taken down or recycled for maintenance, when the database has performance problems, or other occurrences. By informing database client users of the problem (as well as estimated timelines for completion or workarounds), the DBA may provide better service to database clients and reduce the frustration some database client users feel when the database becomes unavailable for reasons unknown to them.
- One solution to this problem is to use instant messaging (IM) systems to send messages from the DBA to database client users. This solution, however, suffers from a significant problem in that the DBA must know the IM identity of the database client user who is connected to the database in order to send them an IM message. In a typical large database, the DBA will not know which particular database client users are connected at any given time and therefore cannot effectively send them IM messages. Moreover, DBAs and database client users often change (such as for different shifts) and are often remote, increasing the difficulty of knowing which database client users are presently using the database. Such a solution may also rely on the availability of an IM server to forward the message, as well as both sender and receiving being logged on, further limiting the usefulness of IM.
- Another problem is that database client users do not have an effective and efficient mechanism to communicate with a DBA. As database client users often do not know the identity of DBAs, they cannot easily contact the DBAs via phone, e-mail, or IM message. Even if a database client user knows the identity of a DBA, they may not know whether the DBA is on-shift or working from an alternative location, making it more difficult to communicate with the DBA. There is, therefore, a need for an efficient and effective mechanism for providing communication between database client users and administrators.
- The problems identified above are in large part addressed by systems, methods and media for providing communication profiles for an integrated database messaging system. Embodiments may include a method for providing communication profiles for an integrated database messaging system. Embodiments of the method may include receiving from a user of the database messaging system a request for one or more profiles and determining one or more profiles associated based on the attributes of each profile request by accessing a profile database. The one or more profiles may include an indication of a user of the database messaging system and an Internet Protocol (IP) address. Embodiments may also include providing the one or more determined profiles to the requesting user. Further embodiments may include receiving an indication of one or more changes to the profile database and modifying the profile database. The user may include a database administrator (DBA) or database client user. Each profile may contain personal, organizational, contact, group or other types of information. In a further embodiment, the profile request includes an indication of a group of users and the method may further include receiving a message request and transmitting a message to the IP addresses associated with the profiles of the group of users.
- Another embodiment provides a machine-accessible medium containing instructions effective, when executing in a data processing system, to cause the system to perform a series of operations for communicating between database client users and administrators. The series of operations generally includes receiving from a user of the database messaging system a request for one or more profiles and determining one or more profiles associated based on the attributes of each profile request by accessing a profile database. The one or more profiles may include an indication of a user of the database messaging system and an Internet Protocol (IP) address. Embodiments may also include a series of operations for providing the one or more determined profiles to the requesting user. Further embodiments may include a series of operations for receiving an indication of one or more changes to the profile database and modifying the profile database.
- A further embodiment provides a database messaging system. The database messaging system may generally include a database server having a database messaging module to transmit a message to a determined IP address, where the determined IP address is associated with a database client. The database messaging system may also include one or more database clients in communication with the database server and each having a client listener, where each client listener may receive a message from the database server and display the received message. The database messaging system may also include a profile database and a communication profile module to receive a request from a user of the database messaging system for a profile associated with, for example, combinations of an IP address, a database name, and/or a group name, or other pertinent attributes. The communications profile module may also determine one or more profiles based on the profile request by accessing the profile database. The communications profile module and profile database may be located on the database client and/or the database server.
- Advantages of the invention will become apparent upon reading the following detailed description and upon reference to the accompanying drawings in which, like references may indicate similar elements:
-
FIG. 1 depicts an environment for a database messaging system with a database server and one or more database clients according to one embodiment; -
FIG. 2 depicts a block diagram of one embodiment of a computer system suitable for use as a component of the database messaging system; -
FIG. 3 depicts a conceptual illustration of software components of a database server with a database messaging module and a communication profile module according to one embodiment; -
FIG. 4 depicts a conceptual illustration of software components of a database client with a client messaging module and a communication profile module according to one embodiment; -
FIG. 5 depicts an example of a flow chart for receiving a message request and transmitting a message to one or more database clients according to one embodiment; -
FIG. 6 depicts an example of a flow chart for receiving a message from a database server, displaying the message to a database client user, and transmitting a message to a DBA according to one embodiment; and -
FIG. 7 depicts an example of a flow chart for receiving a request for a profile, determining a profile, and transmitting the profile according to one embodiment. - The following is a detailed description of example embodiments of the invention depicted in the accompanying drawings. The example embodiments are in such detail as to clearly communicate the invention. However, the amount of detail offered is not intended to limit the anticipated variations of embodiments; on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present invention as defined by the appended claims. The descriptions below are designed to make such embodiments obvious to a person of ordinary skill in the art.
- The system and methodology of the disclosed embodiments provides for an effective and efficient way of providing communication between a DBA and database client users. The disclosed database messaging system provides a mechanism for a DBA to send a message to database client users without knowing their identity by facilitating transmittal of the message to the IP address of the user's database client and displaying the message to the user at the database client. Similarly, the disclosed system provides a mechanism for database client users to transmit a message to the DBA at the IP address of the database server without knowing the identity of the DBA. While such a system provides an effective means for communication between DBAs and database client users, it is often desired to know more information about the database client user and/or DBA than just the IP address. The disclosed system and methodology for providing communication profiles advantageously provides personal information, organizational information, contact information, group information or other types of information to DBAs and database client users. For situations where transmission of a message to a generic IP address is unsatisfactory, the disclosed system may accordingly provide a more robust and useful solution. A database client user or DBA may, in one example, use contact information in a profile to e-mail or call someone who is not responding to messages displayed at their IP address. In another example, a DBA may search for profiles associated with a group of database client users who use the same application and, upon accessing the profiles, may send a message to the IP address of each database client associated with those database client users. The DBA of this example may effectively broadcast messages to these users utilizing profile selection and groups of profiles. The use of profiles may also support the creation and gathering of metrics and statistics for the
database messaging system 100. The profiles may be scanned to extract relevant information and attributes to generate reports or perform other tasks. - While specific embodiments will be described below with reference to particular configurations of hardware and/or software, those of skill in the art will realize that embodiments of the present invention may advantageously be implemented with other substantially equivalent hardware and/or software systems. Aspects of the invention described herein may be stored or distributed on computer-readable media, including magnetic and optically readable and removable computer disks, as well as distributed electronically over the Internet or over other networks, including wireless networks. Data structures and transmission of data (including wireless transmission) particular to aspects of the invention are also encompassed within the scope of the invention.
- Turning now to the drawings,
FIG. 1 depicts an environment for a database messaging system with a database server and one or more database clients according to one embodiment. Thedatabase messaging system 100 may include one ormore database clients 102 in communication with adatabase server 106 via anetwork 104 as well as adatabase 110 in communication with thedatabase server 106. Eachdatabase client 102 may include adatabase application 112 to access thedatabase 110 through thedatabase server 106.Database client 102 may facilitate communications between database client users and thedatabase server 106. Thedatabase server 106 may manage communications to and operations withdatabase 110 and may also, as described in more detail subsequently, facilitate communications from a DBA to users of thedatabase clients 102 and from database client users to the DBA. As will be described in more detail subsequently, either or both of thedatabase client 102 and thedatabase server 106 may include acommunication profile module 118 to provide profiles for users of thedatabase messaging system 100. The profiles may include information about users that allows other users to find out more information about the users, contact those users via other means, or perform other tasks. Users of thedatabase messaging system 100 may include both database client users and DBAs as well as other users. - In the
database messaging system 100, any of thedatabase clients 102, thedatabase server 106, and thedatabase 110 may be located at the same location, such as in the same building or computer lab, or could be remote. While the term “remote” is used with reference to the distance between the components of thedatabase messaging system 100, the term is used in the sense of indicating separation of some sort, rather than in the sense of indicating a large physical distance between the systems. For example, any of the components of thedatabase messaging system 100 may be physically adjacent or located as part of the same computer system in some network arrangements. - Each
database client 102 may include one or more personal computers, workstations, servers, mainframe computers, notebook or laptop computers, desktop computers, PDAs, set-top boxes, mobile phones, wireless devices, or the like. In some embodiments, adatabase client 102 may be a computer system as described in relation toFIG. 2 . Thedatabase client 102 may be in wired or wireless communication withnetwork 104. A database client user may utilize adatabase client 102 and itsdatabase application 112 to facilitate the access, viewing, and use of content ondatabase 110 through the use ofdatabase server 106.Application 112 may include any type of executable application that accessesdatabase 110, such as an application that uses files fromdatabase 110, a word processor, a spreadsheet, business applications (e.g., industry-specific software), a browser, or any other type of application. - Each
database client 102 may include aclient listener 114 and aclient transmitter 116 as part of a client messaging module, as described in more detail in relation toFIG. 4 . Theclient listener 114 may receive messages from the DBA through thedatabase server 106, generate a display window (such as a new window or pop-up window) or utilize an existing window, and display the message to a database client user. As will be described in more detail subsequently, theclient listener 114 may monitor a predetermined port and act as a server on thedatabase client 102 machine. Theclient listener 114 may optionally be incorporated into thedatabase application 112 or any database management software installed on thedatabase client 102. Theclient transmitter 116 may receive a request to transmit a message to a DBA from a database client user, determine the IP address of thedatabase server 106, and transmit the message to thedatabase server 106, which in turn provides the message to the DBA. Theclient transmitter 116 may thus act as a client on thedatabase client 102 with respect to thedatabase server 106. - A
database client 102 may also include acommunication profile module 118. As will be described subsequently, thedatabase server 106 may also have acommunication profile module 118 that either works independently of or in conjunction with that of thedatabase client 102. Acommunication profile module 118 may have a profile database for storing profiles and/or may be in communication with othercommunication profile modules 118 on other systems and their profile databases. Acommunication profile module 118 of adatabase client 102 may, for example, access a local profile database or a profile database located at thedatabase server 106 to find a profile for a DBA based on an IP address and/or database name. Upon request of a database client user, thecommunication profile module 118 may determine any profiles associated with an IP address and provide the profile to the database client user, such as by displaying it to the database client user using a GUI or other interface. A database client user with proper authorization may also add or edit their profiles or those of others, allowing for efficient updating of profiles in the database. In some embodiments, only a DBA will have access to modify database profiles. In other embodiments, a database client user may have the ability to modify part of their profile while others parts are restricted (e.g., database client user can modify home phone number but not supervisor). - Profiles may include any type of information, including personal information, organizational information, or contact information, associated with a user such as a database client user or DBA. Personal information may include any information associated with the database client user, such as their name, address, shift hours, office location, authorizations, applications they have access to, etc., or similar information for a DBA. Organizational information may include any information associated with a user's place within an organization, such as the user's title, job responsibilities, supervisor's name or contact information, organizational/reporting structure, term of service, etc. Contact information may include any information associated with communication with a user, such as the user's phone number, alternative phone number, fax number, pager number, e-mail address, Internet address, MAC address, alternative contact information, an ‘away’ message, etc.
- Profiles may also include group information, which may be an indication of one or more groups, or collections, to which the user belongs. These groups may, in some embodiments, may be based on other types of profile information, such as applications, organizational structures, etc. Groups may also be defined by a user of the
database messaging system 100. A database client user may, for example, define a group of DBAs with whom they frequently work. A DBA may, in another example, define a group of database client users who use a particular application, who want to be notified of particular events (e.g., updates, system interruptions, etc.), etc. When creating a profile, the same profile information may be copied into multiple groups, potentially saving time when new users are added or other situations. -
Network 104 may be any type or combination of data communications channel(s), such as the Internet, an intranet, a local area network (LAN), a wide area network (WAN), an Ethernet network, a wireless network, a proprietary network, or a broadband cable network. In one exemplary embodiment, a corporate intranet implemented on a LAN may serve asnetwork 104 for communications between components of a corporatedatabase messaging system 100. Those skilled in the art will recognize, however, that the invention described herein may be implemented utilizing any type of data communications channel or combinations of data communication channels. - The
database server 106 provides an interface betweendatabase clients 102 anddatabase 110 by facilitating access, manipulation, and storage of information indatabase 110 bydatabase applications 112 of thedatabase clients 102. Thedatabase server 106 may be one or more of any type of computer system, including servers, personal computers, workstations, mainframe computers, notebook or laptop computer, desktop computers, or the like. In some embodiments, thedatabase server 106 may be a computer system as described in relation toFIG. 2 . Anexample database server 106 is an IBM® eServerg server or similar server. In this example, thedatabase server 106 may include software such as IBM®'s DB2® database management system application that provides an effective and robust database platform. - The
database server 106 may include modules such as acommunication profile module 118, adatabase manager 120, adatabase monitor 122, adatabase messaging transmitter 124, aDBA interface module 126, and adatabase listener 128. Thedatabase manager 120 may be a database management system such as IBM®'s DB2® database management system, Microsoft®'s SQL Server system, Oracle®'s database management system, or Sybase, Inc.'s ® database management system. Thedatabase manager 120 may facilitate access, manipulation, or storage of information indatabase 110 bydatabase applications 112 of thedatabase clients 102. The database monitor 122 may monitordatabase 110 activities and may also allow database server support to communicate with the DBA. The database monitor 122 may monitor any type ofdatabase 110 activity, such as when records are inserted, updated, or deleted, deadlock of thedatabase 110, exceeding a predefined threshold for file system size. The database monitor 122 may log these activities and/or notify the DBA upon their occurrence. - The
database messaging transmitter 124 and DBA interface module 126 (which may both be part of a database messaging module as described in relation toFIG. 3 ) may provide for communications between the DBA to users of thedatabase clients 102. TheDBA interface module 126 may receive a message request from a DBA or other person to be sent to one or more database client users via theirdatabase clients 102. In some embodiments, theDBA interface module 126 provides a graphical user interface (GUI) with which the DBA may input information. The message request may include both message content (including message text, files for attachment, or other information) and an indication of the database client user or users to whom the message should be sent. A DBA or other authorized person may be using a separate DBA computer system, may be directly accessingdatabase server 106, or using another computer system. After receiving the message request, thedatabase messaging transmitter 124 may then transmit a message to the network address (i.e., IP address) for eachdatabase client 102. Thedatabase messaging transmitter 124 may effectively serve as a client to theclient listener 114 of the receivingdatabase clients 102.Database servers 106 generally have access to the IP or other network address for all connecteddatabase clients 102 and may advantageously use this IP address to communicate with database client users. - The
database listener 128 may facilitate communications from users of thedatabase clients 102 to the DBA. The database listener 128 (acting as a server with respect to the client transmitter 116) may receive a message transmitted to an IP address of thedatabase server 106 and intended for a DBA, such as by monitoring one or more ports of thedatabase server 106. Thedatabase listener 128 may then provide the message to the DBA. - The
database 110 may be a collection of related information accessed and managed by a database management system such asdatabase manager 120.Database 110 may be any type of database, such as a hierarchical database or a relational database. Most modern databases are relational databases whose management systems restrict data access to a messaging protocol such as SQL, a nonprocedural language that allows a programmer to specify desired results.Example databases 110 may be consistent with management systems such as IBM®'s DB2® database management system, Microsoft®'s SQL Server system, Oracle®'s database management system, or Sybase, Inc.'s ® database management system. The data ofdatabase 110 may be stored on one or more storage media such as hard drives, on a storage area network (SAN), tape backup, network attached storage (NAS), or in any other fashion or combination of fashions. An example hardware solution to store adatabase 110 may be IBM®'s TotalStorage® line of disk storage systems. - The
database server 106 may also have acommunications profile module 118 in addition to, or instead of, that of thedatabase client 102. Thecommunication profile module 118 of thedatabase server 106 may, in some embodiments, be substantially similar in function to that of thedatabase client 102 and the description will not be repeated in the interest of brevity. A DBA may use thecommunication profile module 118 to find out information about database client users, such as when they need to contact one via phone after they failed to respond to messages to their IP address. A DBA with proper authorization may also add or edit their profiles or those of others, allowing for efficient updating of profiles in the database. In some embodiments, a DBA may only have authorization over a sub-group of database client users or databases. - Using the disclosed system, a DBA may send messages to individual or groups of database client users and database client users may likewise communicate with the DBA, providing for an effective and efficient mode of communication between database client users and DBAs. By using
communication profile modules 118, both DBAs and database client users may advantageously access profiles for other users of thedatabase messaging system 100 instead of relying solely on the IP address for that user's computer system. A DBA, for example, that is trying to reach a database client user but is not getting a response may access the database client user's profile to find that user's contact information so that they may call, e-mail, etc. If adatabase client 102 environment is repeatedly violating an operating standard, in another example, the DBA may be able to determine who is responsible for maintaining that client by accessing the profile. The DBA in this example may also be able to determine the organization and reporting structure to whom the responsible database client user reports. Conversely, a database client user may be unhappy with the performance of thedatabase client 102 and may request service from the assigned DBA. If such service is unsatisfactory, the database client user may access the DBA profile to contact the DBA or, alternatively, to contact the DBA's supervisor for resolution. Users of thedatabase messaging system 100 may also take advantages of groups of profiles to find others users or to broadcast messages to groups of users. - The
communication profile module 118, like other components of thedatabase messaging system 100, may be installed with the database or installed at a later time, such as part of an upgrade or a separate module. Thecommunication profile modules 118 may be organized by node in some embodiments that includes bothdatabase clients 102 and adatabase server 106, so that one or more DBAs administering adatabase server 106 and each of the database client users administering adatabase client 102 may have the ability to add data that would personalize the node. The profile database in this embodiment may be located at either thedatabase server 106, at one or more of thedatabase clients 102, or distributed over multiple computer systems. In one embodiment, a central profile database may be located at thedatabase server 106 and thecommunication profile modules 118 of thedatabase clients 106 may access the central profile database either directly or through acommunication profile module 118 of thedatabase server 106. -
FIG. 2 depicts a block diagram of one embodiment of acomputer system 200 suitable for use as a component of thedatabase messaging system 100, such as adatabase client 102 or adatabase server 106. Other possibilities for thecomputer system 200 are possible, including a computer having capabilities other than those ascribed herein and possibly beyond those capabilities, and they may, in other embodiments, be any combination of processing devices such as workstations, servers, mainframe computers, notebook or laptop computers, desktop computers, PDAs, mobile phones, wireless devices, set-top boxes, or the like. At least certain of the components ofcomputer system 200 may be mounted on a multi-layer planar or motherboard (which may itself be mounted on the chassis) to provide a means for electrically interconnecting the components of thecomputer system 200. - In the depicted embodiment, the
computer system 200 includes aprocessor 202,storage 204,memory 206, auser interface adapter 208, and adisplay adapter 210 connected to a bus 212. The bus 212 facilitates communication between theprocessor 202 and other components of thecomputer system 200, as well as communication between components.Processor 202 may include one or more system central processing units (CPUs) or processors to execute instructions, such as an IBM® PowerPC™ processor, an Intel Pentium® processor, an Advanced Micro Devices Inc. processor, or any other suitable processor. Theprocessor 202 may utilizestorage 204, which may be non-volatile storage such as one or more hard drives, tape drives, diskette drives, CD-ROM drive, DVD-ROM drive, or the like. Theprocessor 202 may also be connected tomemory 206 via bus 212, such as via a memory controller hub (MCH).System memory 206 may include volatile memory such as random access memory (RAM) or double data rate (DDR) synchronous dynamic random access memory (SDRAM). - The
user interface adapter 208 may connect theprocessor 202 with user interface devices such as a mouse 220 orkeyboard 222. Theuser interface adapter 208 may also connect with other types of user input devices, such as touch pads, touch sensitive screens, electronic pens, microphones, etc. A database client user, for example, may input a desired message using thekeyboard 222 of adatabase client 102. The bus 212 may also connect theprocessor 202 to adisplay 214, such as an LCD display or CRT monitor, via thedisplay adapter 210. Adatabase client 102 that receives a message from thedatabase server 106, or adatabase server 106 that receives a message from adatabase client 102, may display that message in a window ofdisplay 214 in some embodiments. Adatabase client 102 ordatabase server 106 may also usedisplay 214 to display a profile to a DBA or database client user, respectively. -
FIG. 3 depicts a conceptual illustration of software components of a database server with a database messaging module and a communication profile module according to one embodiment. Thedatabase server 106 of the depicted embodiment includes acommunication profile module 118, adatabase manager 120, adatabase monitor 122, acommunications module 302, auser interface module 304, and adatabase messaging module 310. Thedatabase messaging module 310 may include sub-modules such as adatabase messaging transmitter 124, aDBA interface module 126, adatabase listener 128, anaddress module 312, and aredirection module 314. Thecommunication profile module 118,database manager 120,database monitor 122,database messaging transmitter 124,DBA interface module 126, anddatabase listener 128 are described in relation toFIG. 1 and the description will not be repeated for the sake of brevity. - The
communication profile module 118 may include aprofile database 330 and aprofile user interface 332. Theprofile database 330 may store one or more profiles for users of thedatabase messaging system 100. The stored profiles may optionally have an indication of one or more groups with which the profiles are associated. Theprofile user interface 332 may receive a request for a profile or group of profiles from a DBA, database client user, or other user. Theprofile user interface 332 may also display or otherwise provide a profile to a DBA, database client user or other user via GUI interface, text interface, or other means. In some embodiments, theprofile user interface 332 may work with theDBA interface module 126 to interface with a DBA. In these embodiments a DBA who sends a message to an IP address may, for example, also be presented with an option to see profiles associated with that IP address. In this fashion, a DBA may efficiently access profiles when transmission to an IP address is unsuccessful. Similarly, a DBA receiving a message from a database client user may alternatively also be presented with the profile for that database client user so that they know the origin of the message. Theprofile user interface 332 may also facilitate modifications to profiles in aprofile database 330 by the DBA. A DBA may also request a group of profiles and send a message to the IP addresses associated with the profiles in the group in order to broadcast a message to each user in the profiles simultaneously. - The
communications module 302 may facilitate communications to and from thedatabase server 106 vianetwork 104, such as communications withdatabase clients 102. Theuser interface module 304 may receive user input from user input devices such as a mouse 220 orkeyboard 222 and may also provide output to a user, such as via adisplay 214 or speaker. - The
database messaging module 310 and its components may receive message requests from a DBA to be sent to one ormore database clients 102, determine the IP addresses associated with thedatabase clients 102, and transmit a message to those IP addresses. Thedatabase messaging module 310 and its components may also receive messages transmitted fromdatabase clients 102 and display or otherwise provide those messages to DBAs. As described previously, theDBA interface module 126 may receive the message request that includes message content and an indication of one ormore database clients 102 to which the message will be sent. TheDBA interface module 126 may also provide a GUI or text display of a received message to the DBA. - When the
database messaging module 310 is transmitting a message, theaddress module 312 may determine an IP address associated with each of the one ormore database clients 102 to which a message will be sent, after which thedatabase messaging transmitter 124 may transmit the message to the determined IP addresses. As described previously,database servers 106 generally have access to the IP or other network address for all connecteddatabase clients 102. Theaddress module 312 may determine the IP addresses in a number of fashions. If a DBA submits a list of one or more IP addresses, theaddress module 312 may simply use those IP addresses (after optionally converting them to decimal format). If the DBA specifies a database name, theaddress module 312 may determine all of the IP addresses currently active with or associated with that database. If aparticular database client 102 is connected more than once to thesame database 110, duplicate IP addresses may be eliminated. By allowing the DBA to specify a database name, the DBA may effectively broadcast a message to all connecteddatabase clients 102 without having to specify each individually. If the DBA specifies a group name, theaddress module 312 may determine the IP addresses associated with that group, such as by referencing a table. Theaddress module 312 may use any methodology to translate the indication ofdatabase clients 102 received from the DBA to a list of one or more IP addresses. - When the
database messaging module 310 is receiving a message, thedatabase listener 128 may receive such message from adatabase client 102 by monitoring one or more ports of thedatabase server 106 or other methodology. Theredirection module 314 may provide additional flexibility in providing the content of the message to a DBA. If a DBA is local (i.e., with the database server 106), theDBA interface module 126 may display the message to the DBA, as described previously. Theredirection module 314 may transmit the message to another device that the DBA is using when a DBA is remote from thedatabase server 106. -
FIG. 4 depicts a conceptual illustration of software components of a database client with a client messaging module and a communication profile module according to one embodiment. Thedatabase client 102 of the depicted embodiment includes adatabase application 112, acommunication profile module 118, acommunications module 402, and aclient messaging module 410. Theclient messaging module 410 may include sub-modules such as aclient listener 114, aclient transmitter 116, anaddress module 412, and auser interface module 414. Thedatabase application 112,client listener 114, andclient transmitter 116 are described in relation toFIG. 1 and the description will not be repeated for the sake of brevity. - 00391 The
communication profile module 118 may include aprofile database 330 and aprofile user interface 332, as described previously in relation toFIG. 3 . Theprofile user interface 332 may receive a request for a profile or group of profiles from a database client user, such as a database client user requesting a profile for a DBA for thedatabase application 112 they are using. Theprofile user interface 332 may display or otherwise provide a profile to database client user via GUI interface, text interface, or other means. In addition to finding profiles for DBAs, a database client user may optionally be able to modify their own profile in theprofile database 330 using theprofile user interface 332. - The
communications module 402 may facilitate communications to and from thedatabase client 102 vianetwork 104, such as communications withdatabase server 106. Theclient messaging module 410 and its components may receive message requests from a database client user to be sent to the DBA, determine the IP addresses associated with thedatabase server 106, and transmit a message to that IP address. Theclient messaging module 410 and its components may also receive messages from a DBA through thedatabase server 106 and may then display or otherwise provide the message to the user of thedatabase client 102. Theclient listener 114 andclient transmitter 116 may provide for receipt and transmission of messages, respectively, for theclient messaging module 410. - The
address module 412 of theclient messaging module 410 may determine an IP address associated with thedatabase server 106, after which theclient transmitter 114 may transmit the message to the determined IP address. Theaddress module 412 may determine the IP address in any fashion, such as requesting the IP address of thedatabase server 106 from thedatabase application 112, which may need such information to provide access todatabase 110.Database clients 102 generally have access to the IP or other network address for thedatabase server 106 with which they are connected. Theuser interface module 414 may receive user input from user input devices such as a mouse 220 orkeyboard 222 and may also provide output to a database client user, such as via adisplay 214 or speaker. When theclient messaging module 410 receives a message, for example, theuser interface module 414 may display themessage using display 214. A user may utilize a GUI or text interface of theuser interface module 414 to view a message, input a new message, reply to a message, or request transmission of a message. -
FIG. 5 depicts an example of a flow chart for receiving a message request and transmitting a message to one or more database clients according to one embodiment. In one embodiment, components of adatabase server 106 such as thedatabase messaging module 310 and its components may perform the elements offlow chart 500. In the depicted embodiment,flow chart 500 begins withelement 502, where theDBA interface module 126 of thedatabase messaging module 310 may receive a message request from the DBA or other authorized person that includes message content that the DBA desires to send to one ormore database clients 102 and/or database client users. As part of the receiving the message request, theDBA interface module 126 may also receive an indication of the one ormore database clients 102 to receive the message atelement 504. The indication ofdatabase clients 102 to receive the message may be a list of IP addresses for thedatabase clients 102, a database name, a group name, or other indication or combination of indications. In some embodiments, the message request may include both the message content (e.g., message text, file attachments) and the indication ofdatabase clients 102. - After receiving the message request (with its indication of database clients 102), the
address module 312 of thedatabase messaging module 310 may determine the IP addresses associated with thedatabase client 102 indications. Atdecision block 506, theaddress module 312 may determine whether one or more IP addresses were received as thedatabase client 102 indications. If IP addresses were received, theaddress module 312 may determine the IP addresses for the messaging recipients by converting those IP addresses as necessary, such as by converting them to the decimal format. Thedatabase messaging transmitter 124 may then transmit the message (based on the message content) to the selected IP addresses atelement 508. Atdecision block 510, theaddress module 312 may determine whether one or more database names were received as part of thedatabase client 102 indication. If a database name was received, the method offlow chart 500 continues toelement 512, where theaddress module 312 may determine the IP addresses associated with the database name, such as by cross-referencing the database name with a list of IP addresses currently accessing that database. Theaddress module 312 may also eliminate duplicate IP addresses that may occur when adatabase client 102 is logged in multiple times. Thedatabase messaging transmitter 124 may then transmit the message to the determined IP addresses atelement 514. - Similarly, at
decision block 516, theaddress module 312 may determine whether one or more group names were received as part of the user indication. If a group name was received, the method offlow chart 500 continues toelement 518, where theaddress module 312 may determine the IP addresses associated with the group name, such as by accessing the profiles associated with the group. Thedatabase messaging transmitter 124 may then transmit the message to the IP addresses atelement 520. Groups may be similar in functionality to ‘buddy lists’ in instant messaging (IM) systems or contact lists in e-mail applications. By specifying a group name, a DBA may efficiently select all the database client users within that group without having to input each IP address individually. A DBA may, for example, create a group associated with a particular database application that includes the profiles of database client users (including their IP addresses) that use the database application. By selecting this group, the DBA may efficiently inform all interested clients about the application, such as when it has been updated, when support will no longer be provided, etc. - While the
database messaging transmitter 124 is depicted as potentially transmitting a message separately atelements method 500. Moreover, the received indication of one ormore database clients 102 received as part of the message request may include a plurality of different methods for indicatingdatabase clients 102. For example, a message request may include a list of three IP address, a database name, and a group name. In this example, after all the relevant IP addresses are determined by theaddress module 312, thedatabase messaging transmitter 124 may transmit the message to all IP addresses simultaneously if so desired. - At
element 522, thedatabase server 106 may optionally receive a message from a database client user (through a database client 102) and display or otherwise provide that message to a DBA.Element 522 may occur when, for example, database client users respond to a DBA-transmitted message or when a database client user sends a message to the DBA to report a problem or for other reasons. To display the message, thedatabase listener 128 may generate a display window for the message, such as by creating such a display window or requesting another application to do so, or may utilize an existing window, such as a window created as part of an ongoing conversation between a DBA and database client user. - The
database server 106 may also optionally receive a request for a profile, such as when a DBA requests the profile of a database client user sending him or her a message. Upon receiving a request for a profile, thecommunication profile module 118 may access the profiles for any of the determined IP addresses for the DBA atelement 522, after which the method terminates. -
FIG. 6 depicts an example of a flow chart for receiving a message from a database server, displaying the message to a database client user, and transmitting a message to a DBA according to one embodiment. In one embodiment, components of adatabase client 102 may perform the elements offlow chart 600. In the depicted embodiment,flow chart 600 begins withelement 602, where theclient listener 114 of adatabase client 102 may receive a message from thedatabase server 106. Thedatabase client 102 executing theclient listener 114 has an IP address matching one of the IP addresses determined by theaddress module 312 as described in relation toFIG. 5 . As described previously, theclient listener 114 may listen on a specified or pre-determined port of thedatabase client 102 for the message. In doing so, theclient listener 114 may act as the server on thedatabase client 102 with respect to thedatabase messaging transmitter 124. - After receiving the message, the
client listener 114 may optionally generate a display window for the message atelement 604, such as by creating such a display window or requesting another application to do so. A display window may be, for example, any aspect of a graphical user interface (GUI) that allows a message to be displayed such as a browser instantiation, a pop-up window, a text window, etc. Alternatively, theclient listener 114 may utilize an existing window, such as in the case of repeated messages from a DBA or an ongoing conversation. Theclient listener 114 may then, atelement 606, display the message in the generated display window, allowing a user of thedatabase client 102 to view the message from the DBA. In some embodiments, the display window may preempt other items on the database client user'sdisplay 214 so that they are more likely to see the message. Theclient listener 114 may also optionally determine whether to save the message in a message log atdecision block 608. If the message will be saved, theclient listener 114 may store the message in a message log atelement 610. - In some embodiments, the database client user may desire to send a message to the DBA, such as to report a problem or to respond to a message received at
element 602. If it is determined atdecision block 612 that no message is to be sent, the method offlow chart 600 may terminate. If a message is to be sent, the method continues toelement 614, where theuser interface module 414 of theclient messaging module 410 may receive a message request that the database client user desires to send to the DBA. The message request may include message content such as text, files, etc., as well as an intention to send the message to a DBA. Theaddress module 412 may determine the IP address associated with thedatabase server 106 atelement 616, such as by requesting such information from theapplication 112 or from detection when receiving a message. Theclient transmitter 116 may then, atelement 618, transmit the message to the database server IP address for display or redirection to the DBA. - After transmitting a message to a DBA, a database client user may request profile information for the DBA if the DBA is non-responsive or for other reasons. Upon receiving a request for a profile, the
communication profile module 118 may access the profiles for the server IP address atelement 620, after which the method terminates. The methodology for accessing profiles is described in relation toFIG. 7 . -
FIG. 7 depicts an example of a flow chart for receiving a request for a profile, determining a profile, and transmitting the profile according to one embodiment. In one embodiment, acommunication profile module 118 and its components (located at either adatabase client 102 or database server 106) may perform the elements offlow chart 700. In the depicted embodiment,flow chart 700 begins withelement 702, where theprofile user interface 332 may receive a request to modify aprofile database 330 from a user. A user of thecommunication profile module 118 may include a database client user, a DBA, or any other user. If no request to modify theprofile database 330 is received (as will typically be the case), the method offlow chart 700 continues toelement 710. If a request is received, the method offlow chart 700 continues toelement 704, where theprofile user interface 332 may optionally receive authorization from the user to modify theprofile database 330. As described previously, authorization may be required to change some or all elements of a profile. Once authorization is received (if required), theprofile user interface 332 may receive an indication of the changes atelement 706 and may modify theprofile database 330 atelement 708. - At
element 710, theprofile user interface 332 may receive a request from a user for any profiles associated with an IP address. A DBA, for example, may request a profile for a database client user or for all user profiles associated with adatabase client 102 and IP address. A database client user, in another example, may request the profile of a DBA by requesting the profile associated with thedatabase server 106 IP address and/or database name. Thecommunication profile module 118 may then, atelement 712, determine the profile associated with the IP address by accessing theprofile database 330. Thecommunication profile module 118 may use any methodology for this task, including by access a table of theprofile database 330 that provides a list of profiles associated with a particular IP address and/or database name. Thecommunication profile module 118 may then transmit the profiles associated with an IP address to the user atelement 714. Transmitting the profiles may include, for example, displaying the profiles to the user on adisplay 214, transmitting the profiles to another component (such as aDBA interface module 126 or user interface module 414) for display to the user, or other methodology. - The user interface for displaying profiles to a user may optionally provide for filtering. If the
communication profile module 118 determines atdecision block 716 that filtering will be used, it may filter the profiles associated with the IP address atelement 718. After filtering the profiles, thecommunication profile module 118 may transmit the filtered profiles atelement 720, after which the method terminates. Any type of filtering may be used. A DBA, for example, may wish to see the profiles associated with aparticular application 112 and may accordingly request for profiles to be filtered byapplication 112. In another example, a DBA may desire to filter based on database client user organizational position so that they may see where each user falls in an organizational hierarchy. - In general, the routines executed to implement the embodiments of the invention, may be part of an operating system or a specific application, component, program, module, object, or sequence of instructions. The computer program of the present invention typically is comprised of a multitude of instructions that will be translated by the native computer into a machine-readable format and hence executable instructions. Also, programs are comprised of variables and data structures that either reside locally to the program or are found in memory or on storage devices. In addition, various programs described hereinafter may be identified based upon the application for which they are implemented in a specific embodiment of the invention. However, it should be appreciated that any particular program nomenclature that follows is used merely for convenience, and thus the invention should not be limited to use solely in any specific application identified and/or implied by such nomenclature.
- It will be apparent to those skilled in the art having the benefit of this disclosure that the present invention contemplates methods, systems, and media for providing communication profiles for an integrated database messaging system. It is understood that the form of the invention shown and described in the detailed description and the drawings are to be taken merely as examples. It is intended that the following claims be interpreted broadly to embrace all the variations of the example embodiments disclosed.
Claims (20)
1. A method for providing communication profiles in a database messaging system, the method comprising:
receiving from a user of the database messaging system a request for one or more profiles;
determining one or more profiles based on the profile request by accessing a profile database, the one or more profiles each including an indication of a user of the database messaging system and an Internet Protocol (IP) address; and
providing the one or more determined profiles to the requesting user.
2. The method of claim 1 , further comprising filtering the one or more determined profiles.
3. The method of claim 1 , further comprising:
receiving an indication of one or more changes to the profile database; and
modifying the profile database.
4. The method of claim 3 , further comprising receiving authorization to modify the profile database.
5. The method of claim 1 , further comprising:
receiving a message request to send to a user associated with one of the determined profiles; and
transmitting the message to the IP address associated with the profile.
6. The method of claim 1 , wherein the profile request comprises an indication of a group of users.
7. The method of claim 6 , further comprising:
receiving a message request to send to the group of users; and
transmitting a message to the IP addresses associated with the profiles of the group of users.
8. The method of claim 1 , wherein the profile request comprises one or more of an Internet Protocol (IP) address or a database name.
9. The method of claim 1 , wherein providing the one or more determined profiles to the requesting user comprises one or more of transmitting the determined profiles or displaying the determined profiles.
10. The method of claim 1 , wherein the user of the database messaging system comprises one or more of a database administrator (DBA) or a database client user.
11. The method of claim 1 , wherein each profile comprises one or more of personal information, organizational information, contact information, or group information.
12. A machine-accessible medium containing instructions effective, when executing in a data processing system, to cause said data processing system to perform operations comprising:
receiving from a user of the database messaging system a request for one or more profiles;
determining one or more profiles based on the profile request by accessing a profile database, the one or more profiles each including an indication of a user of the database messaging system and an IP address; and
providing the one or more determined profiles to the requesting user.
13. The machine-accessible medium of claim 12 , further comprising:
receiving a message request to send to a user associated with one of the determined profiles; and
transmitting the message to the IP address associated with the profile.
14. The machine-accessible medium of claim 12 , wherein the profile request comprises an indication of a group of users.
15. The machine-accessible medium of claim 14 , further comprising:
receiving a message request to send to the group of users; and
transmitting a message to the IP addresses associated with the profiles of the group of users.
16. The machine-accessible medium of claim 12 , wherein each profile comprises one or more of personal information, organizational information, contact information, or group information.
17. A database messaging system, the system comprising:
a database server having a database messaging module, the database messaging module being adapted to transmit a message to a determined Internet Protocol (IP) address, wherein the determined IP address is associated with a database client;
one or more database clients in communication with the database server and each having a client listener, each client listener being adapted to receive a message from the database server and to display the received message;
a profile database; and
a communications profile module, the communications profile module being adapted to receive a request for a profile from a user of the database messaging system, the profile request comprising one or more of an IP address, a database name, or a group name, and the communications profile module being further adapted to determine one or more profiles based on the profile request by accessing the profile database.
18. The system of claim 17 , wherein the communications profile module and profile database are located on a database client.
19. The system of claim 17 , wherein the communications profile module and profile database are located on the database server.
20. The system of claim 17 , wherein the profiles each comprise one or more of personal information, organizational information, contact information, or group information.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/337,256 US20070174477A1 (en) | 2006-01-20 | 2006-01-20 | Communication profiles for integrated database messaging system |
US12/125,148 US8122115B2 (en) | 2006-01-20 | 2008-05-22 | Communication profiles for integrated database messaging system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/337,256 US20070174477A1 (en) | 2006-01-20 | 2006-01-20 | Communication profiles for integrated database messaging system |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/125,148 Continuation US8122115B2 (en) | 2006-01-20 | 2008-05-22 | Communication profiles for integrated database messaging system |
Publications (1)
Publication Number | Publication Date |
---|---|
US20070174477A1 true US20070174477A1 (en) | 2007-07-26 |
Family
ID=38286892
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/337,256 Abandoned US20070174477A1 (en) | 2006-01-20 | 2006-01-20 | Communication profiles for integrated database messaging system |
US12/125,148 Expired - Fee Related US8122115B2 (en) | 2006-01-20 | 2008-05-22 | Communication profiles for integrated database messaging system |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/125,148 Expired - Fee Related US8122115B2 (en) | 2006-01-20 | 2008-05-22 | Communication profiles for integrated database messaging system |
Country Status (1)
Country | Link |
---|---|
US (2) | US20070174477A1 (en) |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080222256A1 (en) * | 2007-03-08 | 2008-09-11 | Rosenberg Greg A | Autocomplete for intergrating diverse methods of electronic communication |
US20080222264A1 (en) * | 2006-01-20 | 2008-09-11 | Bostick James E | Integrated Two-Way Communications Between Database Client Users and Administrators |
US20080281914A1 (en) * | 2007-05-10 | 2008-11-13 | Hitachi, Ltd. | Computer system |
US20100082789A1 (en) * | 2007-09-28 | 2010-04-01 | Samsung Electronics Co., Ltd. | Ip address assignment method and apparatus for providing ip service in a zigbee network system |
US20100082683A1 (en) * | 2008-09-26 | 2010-04-01 | Microsoft Corporation | Visitor-assisted user profile creation |
US8250237B2 (en) | 2006-01-20 | 2012-08-21 | International Business Machines Corporation | Communication with database client users |
US8316020B1 (en) * | 2008-12-09 | 2012-11-20 | Amdocs Software Systems Limited | System, method, and computer program for creating a group profile based on user profile attributes and a rule |
US8589590B1 (en) * | 2007-09-10 | 2013-11-19 | Sprint Communications Company L.P. | Selecting an address provider using a dynamic indicator |
US20210118013A1 (en) * | 2019-10-18 | 2021-04-22 | Kakao Corp. | Method of displaying profile view in instant messaging service |
US11122014B2 (en) * | 2019-01-25 | 2021-09-14 | V440 Spółka Akcyjna | User device and method of providing notification in messaging application on user device |
US11310131B2 (en) * | 2016-02-29 | 2022-04-19 | Level 3 Communications, Llc | Data network analysis system and method for a communication network |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10482081B2 (en) * | 2007-06-04 | 2019-11-19 | Bce Inc. | Methods and systems for validating online transactions using location information |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5761696A (en) * | 1996-04-02 | 1998-06-02 | International Business Machines Corporation | Parallel database serving mechanism for a single-level-store computer system |
US6058389A (en) * | 1997-10-31 | 2000-05-02 | Oracle Corporation | Apparatus and method for message queuing in a database system |
US6182075B1 (en) * | 1997-09-26 | 2001-01-30 | International Business Machines Corporation | Method and apparatus for discovery of databases in a client server network |
US20020111986A1 (en) * | 2000-12-05 | 2002-08-15 | Wolfson Charles D. | Integration of messaging functions and database operations |
US6789112B1 (en) * | 2000-05-08 | 2004-09-07 | Citrix Systems, Inc. | Method and apparatus for administering a server having a subsystem in communication with an event channel |
US20040243851A1 (en) * | 2003-05-28 | 2004-12-02 | Chung-I Lee | System and method for controlling user authorities to access one or more databases |
US6868544B2 (en) * | 2000-12-08 | 2005-03-15 | Telcordia Technologies, Inc. | Method and system for general-purpose interactive notifications |
US6920475B1 (en) * | 1999-04-23 | 2005-07-19 | Oracle International Corporation | Communication architecture for distributed computing environment |
US20050198150A1 (en) * | 2004-01-29 | 2005-09-08 | Werner Carl E. | Instant message mass update generated from website entry |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5659728A (en) | 1994-12-30 | 1997-08-19 | International Business Machines Corporation | System and method for generating uniqueness information for optimizing an SQL query |
CN1111321C (en) | 1999-09-02 | 2003-06-11 | 深圳市中兴通讯股份有限公司 | PHS mobile database system based on V5 interface and its calling method |
US7296150B2 (en) * | 2000-10-23 | 2007-11-13 | Business-To-Investor, Inc. | Database management systems and methods of operating the same |
AU2003215359A1 (en) * | 2002-02-21 | 2003-09-09 | Bea Systems, Inc. | System and method for object activation |
US7136858B2 (en) * | 2002-05-21 | 2006-11-14 | Bellsouth Intellectual Property Corporation | Network update manager |
US20040078446A1 (en) | 2002-09-17 | 2004-04-22 | Daniell W. Todd | Options associated with instant messaging (IM) chat transcripts of IM chat sessions |
US8719284B2 (en) * | 2002-12-18 | 2014-05-06 | International Business Machines Corporation | Method, system and program product for filtering an entry of data items |
US20060053194A1 (en) | 2004-09-03 | 2006-03-09 | Schneider Ronald E | Systems and methods for collaboration |
US20070239755A1 (en) | 2005-01-10 | 2007-10-11 | Instant Information Inc. | Methods and systems for messaging in a collaboration system |
US20060224404A1 (en) * | 2005-04-05 | 2006-10-05 | Carl Keusseyan | Web-based system and method for screening job candidates |
US20070174395A1 (en) | 2006-01-20 | 2007-07-26 | Bostick James E | Systems, methods, and media for communication with database client users |
US20070174417A1 (en) | 2006-01-20 | 2007-07-26 | Bostick James E | Integrated two-way communications between database client users and administrators |
-
2006
- 2006-01-20 US US11/337,256 patent/US20070174477A1/en not_active Abandoned
-
2008
- 2008-05-22 US US12/125,148 patent/US8122115B2/en not_active Expired - Fee Related
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5761696A (en) * | 1996-04-02 | 1998-06-02 | International Business Machines Corporation | Parallel database serving mechanism for a single-level-store computer system |
US6182075B1 (en) * | 1997-09-26 | 2001-01-30 | International Business Machines Corporation | Method and apparatus for discovery of databases in a client server network |
US6058389A (en) * | 1997-10-31 | 2000-05-02 | Oracle Corporation | Apparatus and method for message queuing in a database system |
US6920475B1 (en) * | 1999-04-23 | 2005-07-19 | Oracle International Corporation | Communication architecture for distributed computing environment |
US6789112B1 (en) * | 2000-05-08 | 2004-09-07 | Citrix Systems, Inc. | Method and apparatus for administering a server having a subsystem in communication with an event channel |
US20020111986A1 (en) * | 2000-12-05 | 2002-08-15 | Wolfson Charles D. | Integration of messaging functions and database operations |
US6868544B2 (en) * | 2000-12-08 | 2005-03-15 | Telcordia Technologies, Inc. | Method and system for general-purpose interactive notifications |
US20040243851A1 (en) * | 2003-05-28 | 2004-12-02 | Chung-I Lee | System and method for controlling user authorities to access one or more databases |
US20050198150A1 (en) * | 2004-01-29 | 2005-09-08 | Werner Carl E. | Instant message mass update generated from website entry |
Cited By (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8938507B2 (en) | 2006-01-20 | 2015-01-20 | International Business Machines Corporation | Integrated two-way communications between database client users and administrators |
US20080222264A1 (en) * | 2006-01-20 | 2008-09-11 | Bostick James E | Integrated Two-Way Communications Between Database Client Users and Administrators |
US8250237B2 (en) | 2006-01-20 | 2012-08-21 | International Business Machines Corporation | Communication with database client users |
US9634966B2 (en) | 2006-01-20 | 2017-04-25 | Snap Inc. | Integrated two-way communications between database client users and administrators |
US20080222256A1 (en) * | 2007-03-08 | 2008-09-11 | Rosenberg Greg A | Autocomplete for intergrating diverse methods of electronic communication |
US10452763B2 (en) * | 2007-03-08 | 2019-10-22 | Oath Inc. | Autocomplete for integrating diverse methods of electronic communication |
US20080281914A1 (en) * | 2007-05-10 | 2008-11-13 | Hitachi, Ltd. | Computer system |
US8589590B1 (en) * | 2007-09-10 | 2013-11-19 | Sprint Communications Company L.P. | Selecting an address provider using a dynamic indicator |
US20100082789A1 (en) * | 2007-09-28 | 2010-04-01 | Samsung Electronics Co., Ltd. | Ip address assignment method and apparatus for providing ip service in a zigbee network system |
US8046431B2 (en) * | 2007-09-28 | 2011-10-25 | Samsung Electronics Co., Ltd. | IP address assignment method and apparatus for providing IP service in a ZIGBEE network system |
US20100082683A1 (en) * | 2008-09-26 | 2010-04-01 | Microsoft Corporation | Visitor-assisted user profile creation |
US8195601B2 (en) * | 2008-09-26 | 2012-06-05 | Microsoft Corporation | Visitor-assisted user profile creation |
US8316020B1 (en) * | 2008-12-09 | 2012-11-20 | Amdocs Software Systems Limited | System, method, and computer program for creating a group profile based on user profile attributes and a rule |
US11310131B2 (en) * | 2016-02-29 | 2022-04-19 | Level 3 Communications, Llc | Data network analysis system and method for a communication network |
US11848836B2 (en) | 2016-02-29 | 2023-12-19 | Level 3 Communications, Llc | Data network analysis system and method for a communication network |
US12177098B2 (en) | 2016-02-29 | 2024-12-24 | Level 3 Communications, Llc | Data network analysis system and method for a communication network |
US11122014B2 (en) * | 2019-01-25 | 2021-09-14 | V440 Spółka Akcyjna | User device and method of providing notification in messaging application on user device |
US20210118013A1 (en) * | 2019-10-18 | 2021-04-22 | Kakao Corp. | Method of displaying profile view in instant messaging service |
Also Published As
Publication number | Publication date |
---|---|
US20080222085A1 (en) | 2008-09-11 |
US8122115B2 (en) | 2012-02-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8122115B2 (en) | Communication profiles for integrated database messaging system | |
US9634966B2 (en) | Integrated two-way communications between database client users and administrators | |
US8250237B2 (en) | Communication with database client users | |
US7840596B2 (en) | Method and apparatus for persistent real-time collaboration | |
US7899891B2 (en) | Network adapted for mobile devices | |
US6829639B1 (en) | Method and system for intelligent global event notification and control within a distributed computing environment | |
US8495434B2 (en) | Failure source server and mail server administrator alert management programs, systems, and methods | |
US20030084104A1 (en) | System and method for remote storage and retrieval of data | |
US20040123242A1 (en) | Context instantiated application protocol | |
US20130238558A1 (en) | On-demand file synchronization | |
EP1934793A2 (en) | A method for distributing data, adapted for mobile devices | |
US9485202B2 (en) | Alerting recipients to errors occurring when accessing external services | |
JP2004318822A (en) | Presence information display method and apparatus | |
MX2011002738A (en) | Techniques to manage access to organizational information of an entity. | |
US9674280B1 (en) | Social file storage | |
WO2007038595A2 (en) | Virtual publication of data, adapted for mobile devices | |
US20050114401A1 (en) | Enterprise directory service domain controller replication alert and repair | |
US11556402B2 (en) | Metadata plane for application programming interface | |
US20060037062A1 (en) | Method, system and program product for securing resources in a distributed system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BOSTICK, JAMES E.;FORLENZA, RANDOLPH M.;KAEMMERER, JOHN P.;AND OTHERS;REEL/FRAME:017391/0203;SIGNING DATES FROM 20051212 TO 20060103 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |