A better way to handle real-time data?

A better way to handle real-time data?

am 25.01.2008 17:25:11 von martin

I have a series of php scripts that provide the user interface to an
industrial automation program.

One of the scripts serves out a page which displays some data, some
of which is constantly changing. On that page, I have some AJAX code
running that frequently requests fresh data and displays it
(frequently means about once a second).

When the php script that services the AJAX requests receives one, it
passes a request of its own over to the main process (via a socket)
which responds with some data which the script then sends out to the
browser page.

This all works fine but I'm concerned about the load this exchange of
data places in the main process.

What I'm wondering is: would it be possible that I could have my main
process send its data (in real time) to "something" in the php system
such that the php script could access this data much like it accesses
its own global variables? IOW, the script would have immediate access
to the values instead of having to request them from the main process.

Please understand that all of this activity is running on one computer
and this is all confined to an inTRAnet (there's no internet access
involved). And, this one computer is entirely under my control. I am
free to do what ever needs to be done with regards to php
configuration, security settings, etc.

Any recommendations?

Thanks.

Re: A better way to handle real-time data?

am 25.01.2008 20:27:00 von zeldorblat

On Jan 25, 11:25 am, Martin wrote:
> I have a series of php scripts that provide the user interface to an
> industrial automation program.
>
> One of the scripts serves out a page which displays some data, some
> of which is constantly changing. On that page, I have some AJAX code
> running that frequently requests fresh data and displays it
> (frequently means about once a second).
>
> When the php script that services the AJAX requests receives one, it
> passes a request of its own over to the main process (via a socket)
> which responds with some data which the script then sends out to the
> browser page.
>
> This all works fine but I'm concerned about the load this exchange of
> data places in the main process.
>
> What I'm wondering is: would it be possible that I could have my main
> process send its data (in real time) to "something" in the php system
> such that the php script could access this data much like it accesses
> its own global variables? IOW, the script would have immediate access
> to the values instead of having to request them from the main process.
>
> Please understand that all of this activity is running on one computer
> and this is all confined to an inTRAnet (there's no internet access
> involved). And, this one computer is entirely under my control. I am
> free to do what ever needs to be done with regards to php
> configuration, security settings, etc.
>
> Any recommendations?
>
> Thanks.

Sounds likes a database would work just fine. The main process can
update values in the database and the PHP script can read them
whenever it needs to. Or perhaps I'm missing something larger here...

Re: A better way to handle real-time data?

am 25.01.2008 23:48:11 von martin

On Fri, 25 Jan 2008 11:27:00 -0800 (PST), ZeldorBlat
wrote:

>On Jan 25, 11:25 am, Martin wrote:
>> I have a series of php scripts that provide the user interface to an
>> industrial automation program.
>>
>> One of the scripts serves out a page which displays some data, some
>> of which is constantly changing. On that page, I have some AJAX code
>> running that frequently requests fresh data and displays it
>> (frequently means about once a second).
>>
>> When the php script that services the AJAX requests receives one, it
>> passes a request of its own over to the main process (via a socket)
>> which responds with some data which the script then sends out to the
>> browser page.
>>
>> This all works fine but I'm concerned about the load this exchange of
>> data places in the main process.
>>
>> What I'm wondering is: would it be possible that I could have my main
>> process send its data (in real time) to "something" in the php system
>> such that the php script could access this data much like it accesses
>> its own global variables? IOW, the script would have immediate access
>> to the values instead of having to request them from the main process.
>>
>> Please understand that all of this activity is running on one computer
>> and this is all confined to an inTRAnet (there's no internet access
>> involved). And, this one computer is entirely under my control. I am
>> free to do what ever needs to be done with regards to php
>> configuration, security settings, etc.
>>
>> Any recommendations?
>>
>> Thanks.
>
>Sounds likes a database would work just fine. The main process can
>update values in the database and the PHP script can read them
>whenever it needs to. Or perhaps I'm missing something larger here...

Yes, I agree - a database probably would work ok. But, even then,
there would be a lot of disc activity. I'm thinking that if the data
could be stored in memory somewhere/someway, then the processing time
would be minimized.

I'm also thinking that if the processing time is minimized, then I
could speed up the frequency of the AJAX requests (and thus provide a
more real-time appearance to the viewer's screens).

Re: A better way to handle real-time data?

am 26.01.2008 01:19:49 von zeldorblat

On Jan 25, 5:48 pm, Martin wrote:
> On Fri, 25 Jan 2008 11:27:00 -0800 (PST), ZeldorBlat
>
>
>
> wrote:
> >On Jan 25, 11:25 am, Martin wrote:
> >> I have a series of php scripts that provide the user interface to an
> >> industrial automation program.
>
> >> One of the scripts serves out a page which displays some data, some
> >> of which is constantly changing. On that page, I have some AJAX code
> >> running that frequently requests fresh data and displays it
> >> (frequently means about once a second).
>
> >> When the php script that services the AJAX requests receives one, it
> >> passes a request of its own over to the main process (via a socket)
> >> which responds with some data which the script then sends out to the
> >> browser page.
>
> >> This all works fine but I'm concerned about the load this exchange of
> >> data places in the main process.
>
> >> What I'm wondering is: would it be possible that I could have my main
> >> process send its data (in real time) to "something" in the php system
> >> such that the php script could access this data much like it accesses
> >> its own global variables? IOW, the script would have immediate access
> >> to the values instead of having to request them from the main process.
>
> >> Please understand that all of this activity is running on one computer
> >> and this is all confined to an inTRAnet (there's no internet access
> >> involved). And, this one computer is entirely under my control. I am
> >> free to do what ever needs to be done with regards to php
> >> configuration, security settings, etc.
>
> >> Any recommendations?
>
> >> Thanks.
>
> >Sounds likes a database would work just fine. The main process can
> >update values in the database and the PHP script can read them
> >whenever it needs to. Or perhaps I'm missing something larger here...
>
> Yes, I agree - a database probably would work ok. But, even then,
> there would be a lot of disc activity. I'm thinking that if the data
> could be stored in memory somewhere/someway, then the processing time
> would be minimized.
>

Key word here is "thinking." Do you know that there will be too much
disk activity? Have you used a profiler to test both methods to see
which one is faster? Have you tried using a database and know for a
fact that the performance is bad? If so, how much worse? Do you even
know that putting it all in memory will be better than what you're
doing now?

Premature optimization is a common pitfall. You can't optimize
something until you know what you need to optimize. Code things in a
clean and manageable way and then, if you run into problems, you can
optimize specific areas.

Google for "premature optimization" and you'll find a lot of info on
the subject.

Re: A better way to handle real-time data?

am 26.01.2008 02:15:08 von Norman Peelman

Martin wrote:
> I have a series of php scripts that provide the user interface to an
> industrial automation program.
>
> One of the scripts serves out a page which displays some data, some
> of which is constantly changing. On that page, I have some AJAX code
> running that frequently requests fresh data and displays it
> (frequently means about once a second).
>
> When the php script that services the AJAX requests receives one, it
> passes a request of its own over to the main process (via a socket)
> which responds with some data which the script then sends out to the
> browser page.
>
> This all works fine but I'm concerned about the load this exchange of
> data places in the main process.
>
> What I'm wondering is: would it be possible that I could have my main
> process send its data (in real time) to "something" in the php system
> such that the php script could access this data much like it accesses
> its own global variables? IOW, the script would have immediate access
> to the values instead of having to request them from the main process.
>
> Please understand that all of this activity is running on one computer
> and this is all confined to an inTRAnet (there's no internet access
> involved). And, this one computer is entirely under my control. I am
> free to do what ever needs to be done with regards to php
> configuration, security settings, etc.
>
> Any recommendations?
>
> Thanks.
>
>

What about APC (Alternative PHP Cache)? Has functions for
storing/retrieving global server data/variables... take a look.

--
Norman
Registered Linux user #461062

Re: A better way to handle real-time data?

am 26.01.2008 02:33:41 von Jerry Stuckle

Martin wrote:
> On Fri, 25 Jan 2008 11:27:00 -0800 (PST), ZeldorBlat
> wrote:
>
>> On Jan 25, 11:25 am, Martin wrote:
>>> I have a series of php scripts that provide the user interface to an
>>> industrial automation program.
>>>
>>> One of the scripts serves out a page which displays some data, some
>>> of which is constantly changing. On that page, I have some AJAX code
>>> running that frequently requests fresh data and displays it
>>> (frequently means about once a second).
>>>
>>> When the php script that services the AJAX requests receives one, it
>>> passes a request of its own over to the main process (via a socket)
>>> which responds with some data which the script then sends out to the
>>> browser page.
>>>
>>> This all works fine but I'm concerned about the load this exchange of
>>> data places in the main process.
>>>
>>> What I'm wondering is: would it be possible that I could have my main
>>> process send its data (in real time) to "something" in the php system
>>> such that the php script could access this data much like it accesses
>>> its own global variables? IOW, the script would have immediate access
>>> to the values instead of having to request them from the main process.
>>>
>>> Please understand that all of this activity is running on one computer
>>> and this is all confined to an inTRAnet (there's no internet access
>>> involved). And, this one computer is entirely under my control. I am
>>> free to do what ever needs to be done with regards to php
>>> configuration, security settings, etc.
>>>
>>> Any recommendations?
>>>
>>> Thanks.
>> Sounds likes a database would work just fine. The main process can
>> update values in the database and the PHP script can read them
>> whenever it needs to. Or perhaps I'm missing something larger here...
>
> Yes, I agree - a database probably would work ok. But, even then,
> there would be a lot of disc activity. I'm thinking that if the data
> could be stored in memory somewhere/someway, then the processing time
> would be minimized.
>
> I'm also thinking that if the processing time is minimized, then I
> could speed up the frequency of the AJAX requests (and thus provide a
> more real-time appearance to the viewer's screens).
>
>
>

Your limitation is probably going to be network, not disk activity.

Also, databases and your OS cache a lot of data. You can store it in
memory, but then you're going to go through a lot of trouble (and CPU
cycles) retrieving and sorting it.

Allow the database to do its job.

--
==================
Remove the "x" from my email address
Jerry Stuckle
JDS Computer Training Corp.
jstucklex@attglobal.net
==================

Re: A better way to handle real-time data?

am 26.01.2008 09:52:16 von Giovanni

I think db is the best solution too. A db contains a lot of
optimization like query caching that avoid to access to disk if no
values are changed.Is also really fast to retrieve data.Obviously if
the network is the neck-bottle,you should power it.