Solved

php code architecture thoughts and suggestions

Posted on 2003-10-31
6
291 Views
Last Modified: 2012-05-04
I am working on a php project. Currently I have a php script that display a fair amount of text, email addresses atec on a page. The user has an option to edit it. If they do, a mail script which I have written is called and it parses a mail together and sends it out using the PHPMailer class.

after the mail is sent the user is moved back to another page.

This system is used to track work (here at work) and is used very often and many emails are sent from it. All the data is stored in a mysql database.

Here is my dilemma:
When a user sends out email, the script does not return until my script has parsed the message together and theclass file has connected to the mail server and sent the message. This can cause a very noticiable delay: 2-10 seconds usually, and if there are a few attachments, or large attachments, much longer.

What I would like to discuss:
How I can move this load of off the users browser and have "the server" take care of it.

Two ways I have thought of so far are :





having a php script which looks for some entry in the database and when it sees it, shoot off a message and change that value in the db. This would be done using a script that is run say every 5 minutes on the server via a batch file??




Secondly, which would probably be more preferrable is to have the mysql database call a php script via a command window when a certain value is changed (i.e a trigger function).


Now, i know mysql does not yet have triggers, but maybe some of my fellow coders here have already thought of a way around this or would like to think of a way.



3rdly, I would love to hear any other ideas anyone has on this topic.



Thanks alot,
Anthony
0
Comment
Question by:lazyelm
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
6 Comments
 
LVL 3

Expert Comment

by:ashoooo
ID: 9659843
You can create cron jobs to run, say, every 5 mins.

You can save all the mail requests in a db. The script would return as soon as it has made the changes to the db.

The cron job would then go through all the records and send emails and delete the records from this table.

0
 
LVL 6

Accepted Solution

by:
aolXFT earned 500 total points
ID: 9659869
Hmmm The only way I can see to solve your problem lies, in writing your own custom mail function, for either PHP, or MySQL.

This would depend on the sustem you are using, eg Linux, Windows, etc, but the main idea would involve spawning another process, and using it to send the mail, using the fork() command.
0
 
LVL 6

Expert Comment

by:aolXFT
ID: 9659897
Then you could let the main process get on with the job, and let the spawned one, send the mail. I don't particularly recommend doing this with PHP, as an apache(or other WebServer) module, though, because I don't have the necessary experience with apache programming to make such a recommendation.

The same would apply to a MySQL Operation. The problem is that you have no way to check for errors, because you would have to wait until the mail-sending is finished, before you see if it worked.
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 3

Expert Comment

by:ashoooo
ID: 9659961
I would recommend using cron jobs in linux/unix and at commands in windows to do the mailing job. Your PHP script should return as soon as it makes changes to the DB.

If at a later time, the mailing fails, you can notify the user using.. well.. another email :) or display it on the next page he visits.

Depends on your architecture....
0
 

Expert Comment

by:msknr
ID: 9660824
0
 
LVL 11

Expert Comment

by:shmert
ID: 9739825
Just posted this in the other thread, too... (actually accidentally double-posted :P)

Try this syntax to get the php call to system() to return _immediately_

system('/usr/local/bin/long_script > /tmp/php_out &');

This redirect output to the /tmp/php_out file, and the ampersand tells it to run in the background.  Both of these steps are essential.
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Since pre-biblical times, humans have sought ways to keep secrets, and share the secrets selectively.  This article explores the ways PHP can be used to hide and encrypt information.
3 proven steps to speed up Magento powered sites. The article focus is on optimizing time to first byte (TTFB), full page caching and configuring server for optimal performance.
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to create a basic form using some HTML5 and PHP for later processing. Set up your basic HTML file. Open your form tag and set the method and action attributes.: (CODE) Set up your first few inputs one for the name and …

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question