יצירת תור לבקשות API
-
הבנתי.
אתה צריך פתרון של נעילה לקטע קוד, שרק תהליך אחד יכול להיכנס בו בזמן נתון, קוראים לזה נעילה (בשפה האקדמית זה סמפור, Semaphore).
ממה שאני מבין באינטרנט אפשר לעשות את זה בPHP בצורה טריקית ע"י בקשה לגישה לקובץ ונעילת קובץ.דוגמה:
$f = fopen('some_file', 'a'); flock($f, LOCK_EX); //פה אתה כותב את הקריאה ל API flock($f, LOCK_UN); fclose($f);
-
@nigun בנוד אפשר לעשות את זה מסודר עם אירועים, תודיע אם זה רלוונטי להוסיף פרטים
-
@nigun אתה מדבר על TTS אולי?
אני בניתי לעצמי משהו, אחרי שחפרתי באינטרנט ומצאתי שזה הפתרון הכי פשוט, של בדיקה האם קובץ מסוים קיים, ואם כן להמתין.אצלי היה צורך אחר, שלא יהיו בשום אופן 2 קריאות לAPI בו זמנית.
ובעצם השתמשתי במטמון של קובץ, כי ב PHP לא קיים מטמון נורמלי.
ומיהרתי (?) את זה ע"י בדיקה שהקובץ לא קיים, ואם הקובץ קיים, בודק גם את תאריך השינוי האחרון, לוודא שלא היה קריסה או שהסקריפט נגמר לפני שמחק את הקובץ. כך שאם הקובץ השתנה לפני יותר מ 8 שניות, הוא מחק אותו.
כמובן שכל הבדיקה מבוצעת בלולאה עם USLEEP של XXX אלפיות שנייה. -
עכשיו נפל לי האסימון
אני צריך לעשות את הנעילה על השלב של הפעלת הסקריפט בלולאה מתוך הנתונים בDB
ולהפעיל כל דקה עם cron
וכדי למנוע אפשרות שסקריפט לא יגמר והcron יפעיל את הסקריפט שוב
אני עושה נעילה שאם הנעילה = true אז או שיפסיק או שיכנס ללולאת שינה
אני לא יכול לעשות את זה על הפעולה עצמה ושהמאזין יחכה בתור על הקו
כי יכול להיות שהמאזין יתקע חצי דקה על הקו עם שקט ואז הוא יחשוב שזה לא עובד
(אלא אם כן אני בונה את זה לבד באסטריסק ואז אני יכול לשים לו מוזיקה)
אמנם יש לי בעיה אם פעולה לא בוצעה בהצלחה המאזין לא ידע את זה
ויצטרך לחזור לקו בשביל לשמוע הודעה שים לב הפעולה האחרונה נכשלה
@chagold
טריגר בד"ב לא יעזור לי כי אני צריך לבצע פעולה בPHP עם הנתונים שנמצאים בד"ב
ולא לבצע פעולה בד"ב כמו עדכון/כתיבה/מחיקהלגבי הנעילה הזאת מישהו יודע מה ההבדל בין נעילה לבין פשוט לכתוב בקובץ טקסט 1 ובשחרור לכתוב 0?
-
-
@WWW מה שעשית נחשב המצאת הגלגל, וגם עבודה שחורה.
המצאת הגלגל למה? כי זה מושג שלא רק אתה צריך. אז למה לעבוד עם טריקים משלך ולא לבנות על ניסיון האחרים?
עבודה שחורה למה? כי בקוד שלך נהיה לכלוך. בדיקת קיום, בדיקת תאריך, מרחק בשניות ואם תהיה בעיה סימן שיש נפילה אחרת עליה לא חשבת...הבעיה בקוד שלך הוא שהוא לא מכסה מקרה בו יהיו שתי קריאות ממש בבת אחת.
במקרה כזה השורה שבודקת אם הקובץ קיים תבוצע ביחד, ולשני הקריאות התוצאה תהיה חיובית כי הקובץ באמת לא קיים.
ואז שני הקריאות יהיו בתוך הבלוק.
(זה קורה בPHP כי הוא מבוסס טרידים וכל בקשה יכולה לרוץ במקביל שזה מעלה. בנוד בגלל החיסרון של התהליך יחיד זה לא יכול לקרות אלא"כ יש פורק לאפליקציה). -
@dovid אמר ביצירת תור לבקשות API:
המצאת הגלגל למה? כי זה מושג שלא רק אתה צריך. אז למה לעבוד עם טריקים משלך ולא לבנות על ניסיון האחרים?
אדרבה, אני פתוח להצעות...
מצאתי כל מיני פתרונות שבנויים על מטמון קבצים, לא יודע איך הם מתמודדים עם 2 בקשות בו זמנית, חשבתי לעצמי שלא כדאי לי להתקין את כל התלויות שלהם בשביל איזה מקום אחד קטן שאני צריך את זה.אני בעצם חיפשתי משהו כמו משתנה PHP ברמת שרת.
אבל לא מצאתי דבר כזה.אשמח לקבל המלצות.
-
-
@WWW כשקראתי את הודעתך הבנתי שמטרתך הייתה רק מניעה של קוד לעבוד במקביל, ובשביל זה הבאתי קוד שאף אחד לא אישר אם הוא עובד (כלומר שהבקשה השניה מחכה לסיום הראשונה).
אם יש לך מטרה של מטמון אשמח לפירוט ואשמח להראות לך שדברים כאלה אמורים להיות פשוטים יותר וטריקיים פחות. -
@dovid
בימות אי אפשר לעשות מוזיקה בהמתנה לפעולה (ובארטריסק אפשר)
מה שכן אפשר לעשות הודעה "אנא המתן" ומעבר לשלוחה נוספת שבודקת האם הפעולה בוצעה
אם עדיין לא בוצע הפעולה משמיע הודעה של כמה שניות מוזיקה
ואחר כך מפנה שוב לאותה שלוחה (של הבדיקה) שוב ושוב עד שמקבל תשובה הפעולה בוצעה/נכשלה ועובר לתפריט הבא
(צריך לעשות מעבר נקי בין הסוף של הקובץ מוזיקה להתחלה שלא ישמע מוזר)