The present invention relates to a weighing system having a client-server architecture, wherein the servers are configured to provide services to a client on request.
A client-service architecture is generally known. A server is a software module which offers a service. Another software module, the client, a user interface, for example, can request this service. Clients and servers can run on different devices or on the same device.
So that a client can access a service, the connection data of the corresponding service, for example its address, must be known to the client. If a new service is added to an existing client-service architecture, each client must be advised of the connection data of the new service. This is laborious, however.
It is the object of the present invention to provide a weighing system of the initially named kind, for example, a set of store scales or a combination unit comprising a set of store scales and further devices such as display terminals, cash register systems, printer systems and/or hardware servers, which avoids the disadvantage explained above.
This object is satisfied by a weighing system having the features of claim 1 and in particular in that a client-server communications broker is provided in which the services are registered and which is configured to broker a service requested by the client, wherein the provision of the requested service takes place directly between the client and a server determined for this purpose.
All the services present are registered at the client-server communications broker. A client which wants to access the services therefore does not have to know the connection data of the services. The client rather only needs to send a request for a respective service to the client-server communications broker which is aware of the connection data of the services and which then brokers the respective requested service. If a new service is subsequently added, for example by installation of a new software module, this only has to be registered with the client-server communications broker. It is not necessary to communicate the connection data of the new service to the clients.
The software implemented on the weighing system is therefore not influenced by service changes which can above all frequently occur in distributed systems. Additional software modules or additional hardware having new functions, for example a user recognition, can in particular be added over the course of time. A better maintenance capability and a simpler expandability of a weighing system can be achieved overall.
It is generally possible that the client sends a request to the client-server communications broker which determines the server offering the requested service and forwards the request to the determined server which provides the requested service to the client-server communications broker which then forwards the service to the requesting client. In accordance with the invention, the provision of the requested service takes place directly between the client and a server determined for this purpose. The effort on the part of the client-server communications broker can hereby be reduced since the latter is only used at the start and is otherwise not involved in the communication between the client and the server.
The client-server communications broker preferably includes a system of rules or a default for the starting and/or terminating of services and/or for the selection of the determined server. The system of rules is preferably a script which is stored in replaceable form in a file. Which services are started as a base configuration on a system start of the weighing system can, for example, be laid down in the system of rules. Furthermore, it can also be laid down in the system of rules whether a specific service may be started at all. It can, for example, be laid down that a service may only be started when sufficient hardware resources are present for this purpose, when it is permitted from a technical calibration aspect and/or when a license had been acquired for the respective service.
The requested service is preferably offered by a plurality of servers and the client-server communications broker is configured to determine the server from the plurality of servers which provides the requested service by an automatic selection with reference to the system of rules and to communicate the determined server to the client. A client can, for example, request a service “print”, wherein e.g. the following three different print services are available: a calibrated print service, a local print service and a remote print service. The client-server communications broker then decides which of the three print services is selected for the provision of the “print” service. The client therefore does not request a specific service (e.g. the local print service), but rather generally a function of a service (printing). The rule-based reading out can, for example, comprise selecting that print service which has already started from a local print service and a remote print service. This has the advantage of being particular resource-saving so that as little computing capacity or memory space as possible is required. This in particular makes it possible to work with weighing systems having relatively tight hardware resources.
In accordance with an embodiment of the invention, the provision of the requested service takes place in accordance with the publisher-subscriber model. In this case the client (=subscriber) subscribes to the data corresponding to the requested service with the server and said data are then automatically communicated, in particular at regular intervals or as soon as new or updated data are available at the server. The client then does not have to constantly query the server whether new or updated data are present.
To start the services, a service manager can be provided which is connected to the client-server communications broker and which has an autostart list with services to be started on the system start of the weighing system. The service manager can, however, also be integrated in the client-server communications broker. The service manager can furthermore have a further list in which services to be re registered which are only or are also only started at the request of the client-server communications broker. All the available data therefore do not have to be started directly on the system start.
The service manager can also allow a dynamic starting of services on request. Services not started at the system start can therefore also be added to the client-server architecture in a simple manner later. Services can generally be provided whose start takes place dependent on requirements. The start can take place automatically and in particular via the service manager.
The service manager is preferably configured to communicate the connection data of the client-server communications broker, which are in particular made separate, to every started service so that the started services can in each case register with the client-server communications broker which then allocates its connection data to the started services.
Services which are not needed or are no longer needed can in particular also be terminated by means of the service manager. The termination of the services not needed provides advantages in the configuration of the hardware. The hardware resources can then be configured with lower performance, that is can in particular be dimensioned more cost-favorably since all services do not always have to be active at a specific time. The client-server communications broker can generally be configured to terminate a service no longer needed.
A registration of a service to be added in particular takes place in the service manager on the installation of the service to be added.
In accordance with another embodiment of the invention, servers subject to mandatory calibration and servers not subject to mandatory calibration can be coupled to one another via feedback-free software interfaces to protect the services to be provided by the servers subject to mandatory calibration, for example weight display or price calculation. The feedback-free software interfaces are components of the servers subject to mandatory calibration and are, for example, made in each case as a filter which carries out a data control in that e.g. the plausibility, the origin or the checksum of the data are evaluated. A secure client-server architecture can thus be provided in which falsified data or manipulated data have no negative effect on the function of the client-server architecture. In this manner, in particular the most varied certification requirements can be satisfied which are made on the security of a set of scales.
The data corresponding to a service provided by a server subject to mandatory calibration are preferably provided with a code or an ID, for example with a hash-code. It can thereby be achieved that data subject to mandatory calibration are only exchanged between servers authorized by a responsible position. Data which are transmitted from an unauthorized server to an authorized server are not accepted there. Data which are sent from an authorized server to an unauthorized server lose their status as data subject to mandatory calibration. In particular only such data are accepted by the servers whose ID is stored in a memory and is thus known to the receiving server.
It is preferably known to the client-server communications broker whether a respective client and/or service is/are a calibrated or non-calibrated client and/or service. This in particular makes it possible that the brokering of a calibrated service requested by a non-calibrated client takes possible via a feedback-free software interface.
In accordance with a further embodiment of the invention, the weighing system is made as a distributed weighing system and/or as a combined weighing system. In this case, a plurality of devices or all the devices of the distributed weighing system can each have a client-server communications broker and the client-server communications brokers can communicate with one another. Such a weighing system can, for example, include a set of complex scales, a set of simple scales, display terminals, cash register systems, printer systems and/or hardware servers with a high computation power. The individual services can be distributed among the devices in such a weighing system. Computation-intensive servers can in particular run on a central hardware server so that the terminals require less hardware. A client of a terminal, for example a user interface, can nevertheless access all services and e.g. request an optical image evaluation for a user recognition. Such a weighing system also makes possible a continuous serving of a customer in a store or supermarket.
A weighing system includes at least one set of scales having a weighing cell for the detection of the weight of a product to be weighed. The a set of scales can in this respect have a housing with an integrated weighing cell and a load plate connected to the weighing cell. An input apparatus such as a keyboard or a touch screen and an output apparatus such as a printer or a monitor are preferably connected to the a set of scales.
A set of scales or a plurality of sets of scales arranged spatially distributed can be integrated into a such a weighing system and in turn have input or output apparatus and/or access input apparatus or output apparatus arranged distributed in the weighing system. In addition, the weighing system can have on or more servers which are arranged locally and/or are spatially far away and e.g. run as remote servers. In addition, the weighing system can include further components such as a cash register and/or an audio output for the output of audio files and/or a voice output for voice guidance of users and/or customers. Equally, the weighing system can include a communications apparatus, preferably a modem, to communicate with other data networks.
The present invention furthermore relates to a method for the operation of a weighing system having a client-server architecture, wherein the servers provide services offered to a client on request, wherein the services offered are registered with a client-server communications broker which brokers a service requested by the client, wherein the requested service is provided directly between the client and a server determined for this purpose.
Further preferred embodiments of the invention are described in the dependent claims.
The invention will be described in the following by way of example with reference to the drawing. There are shown, schematically in each case:
In
In accordance with
In
The middle part of the display 27 is controlled by a client 15b which makes use of the service of a served sale server 11b to display data on a served sale, wherein the data shown in the middle display are communicated in accordance with the publisher-subscriber model from the server 11b to the client 15b. In a base state of the server 11b, the display on the middle part of the display 27 is blank, for example. As soon as the server 11b changes into a state “article call”, data corresponding to the called up article are communicated to the client 15b and the middle part of the display 27 shows the called up article. If the called up article is then registered by pressing a register button, the server 11b automatically communicates corresponding data to the client 15b, whereby the name of the operator of the weighing system is displaced in the middle part of the display 27, for example.
The lower part of the display 27 is controlled by a client 15a which makes use of the service of a server 11a subject to mandatory calibration to display a weight, a base price and a calculated price for the called up article.
The servers 11a, 11b, 11c are in this respect in communications connection with one another. The server 11a subject to mandatory calibration can, for example, communicate base prices to the information server 11c. In addition, the served sale server 11b can communicate the called-up article to the server 11a subject to mandatory calibration.
Number | Date | Country | Kind |
---|---|---|---|
10 2008 009 116.2 | Feb 2008 | DE | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2009/001069 | 2/16/2009 | WO | 00 | 10/5/2010 |