מודול php שרץ כל הזמן
-
@chagold ברור.
וכאן בדיוק נמצא המודל.
במודל אתה שם את הקוד ששאתה רוצה אחרי עידכון
וזה יהיה מכל מקום שיש בו עידכון - שמשתמש במודל.
ללא קשר כלל לתצוגה.לדוגמא: אם מימשת API שתוכנות חיצוניות יכולות להתממשק אליך, אם תשתמש במודל במקום כתיבה ישירות לDB, אז זה גם יעורר את האירוע
וגם תמיד יש לך אפשרות של טריגרים...
-
אם גורם העדכון הוא רק ממשק הווב, אז ברור שהוא זה שצריך להפעיל אותו.
אם הפעולה לוקחת זמן ממושך, אז כמו שכתבתי עדיף שהphp יפעיל משהו חיצוני בסגנון של exec.
אך אם יש גורמים אחרים מעדכנים אז אי אפשר לבנות על הPHP. ואז אכן הרעיון של הטריגרים שאמר @clickone הוא גם נכון (אגב לpostgres יש cron משלו בשם pgcron אבל כפי ש @clickone הסיק זה אכן לא נוגע למקרה שלך בגלל שזה לא תזמון אלא תגובה לשינוי). -
@dlt אמר במודול php שרץ כל הזמן:
אם גורם העדכון הוא רק ממשק הווב, אז ברור שהוא זה שצריך להפעיל אותו.
אם הפעולה לוקחת זמן ממושך, אז כמו שכתבתי עדיף שהphp יפעיל משהו חיצוני בסגנון של exec.
אך אם יש גורמים אחרים מעדכנים אז אי אפשר לבנות על הPHP. ואז אכן הרעיון של הטריגרים שאמר @clickone הוא גם נכון (אגב לpostgres יש cron משלו בשם pgcron אבל כפי ש @clickone הסיק זה אכן לא נוגע למקרה שלך בגלל שזה לא תזמון אלא תגובה לשינוי).זה בדיוק המקרה - שזה תגובה לעדכון של לקוח, אבל זה אמור להיות מאד ארוך.
תודה רבה. -
@chagold זה שזה ארוך לא אמור להיות מעניין.
פשוט שים אותו בטרייד נפרד בתוך הPHP.
https://stackoverflow.com/questions/70855/how-can-one-use-multi-threading-in-php-applications
או שתבקש מהPHP או מהטריגר להריץ EXEC חיצוני.אגב טריגרים כיום יכולים לעשות הרבה ברים. גם לשלוח מיילים וגם לבקש דברים מהPHP שלך.
אז אולי אתה צריך טריגר שיקרא לPHP שלך לדף מסויים ברגע שיש עידכון CDB. -
בודאי שאפשר עם PHP, הנקודה היא שזה לא יהיה מהקונטקסט של שירות האינטרנט (למשל תגובה לבקשת ווב, שזה בעצם רץ תחת אפאצ' או IIS או כל שרת אינטרנט אחר) שאז לא עוזר טריד נוסף כי הכל תחת אותו תהליך. ולכן אמרתי כאפשרות את exce שמה אפשר לשים כפרמטר את php עם קובץ להרצה (ואז זה רץ כתהליך נפרד לחלוטין באופן בלתי תלוי).