![]() |
אז שתדע..עבודה עם קבצים יותר מעמיסה והסיבה :
בשביל לפתוח קובץ הוא צריך לטעון את כולו לזיכרון של המחשב.. בעת הפתיחה, לשמור עותק שלו.להביא את ה POINTER לסוף הקובץ, להוסיף את מה שהמשתמש רוצה ואז לשמור מחדש... יותר יעיל ? ממש ממש לא. לגבי הזה.... יש לך דרך אפילו יותר פשוטה, שאולי תחסוך לך כמה שאילתות קודם כל תעשה UPDATE userip WHERE ip=$IP SET lastvisit=$time (סתם דוגמא) ואז תבדוק אם יש שורות שמושפעות מזה עם mysql_affected_rows אם הוא לא מחזיר כלום.. סימן שזה לא קיים ואז תעשה INSERT רוצה לייעל את זה יותר ? תשתמש ב COOKIE... תבדוק אם קיים עוגייה שאתה יצרת, אם כן- אל תעשה כלום אם לא תנסה לעדכן (אולי הדפדפן של המשתמש לא תומך בעוגיות) ואז אם לא קיים במסד תכניס רוצה לייעל עוד קצת ? תוסיף גם עם SESSION וחסכת לך כמה מאות שאילתות ביום..... (כמובן עבור 1000 גולשים לא ייחודיים) |
חוץ מהעובדה שזה טוען את הקובץ טקסט לזכרון
תחשוב על זה שאתה יכול לגעת בקובץ רק פעם אחת באותו זמן ז"א יש לך נעילה מלאה על כל הקובץ. חשוב מאד לדאוג שאתה יוצר את הטבלה שלך מסוג InnoDB, מה שיתן לך שיפורים בביצועים, כי אתה יכול לעבוד על כמה שורות בבת אחת, הכוונה שיש לך נעילה ברמת השורה ולא הטבלה. אני בטוח שאם רק תשנה את הטבלה לInnoDB כבר תשים לב לשיפור בביצועים אחרי זה, אני בטוח שאפשר לשפר את השאילתות שלך שיעבדו בצורה יותר יעילה, נפנה לזה אח"כ |
RS324 תודה רבה אחי :)
ו omercnet מזה InnoDB? |
ציטוט:
שהם בעיקרון MYISAM , INNODB,MEMORY ועוד כמה לא זוכר בדיוק איזה.... |
ומה זה כאילו יותר מהיר?
|
דניאל למה שלא תשתמש בשורה אחת?
תפריד עם פסיקים או סימן אחר ותשתמש בזה,יחסוך לך הרבה שורות. של מידע. |
ציטוט:
שאם הוא יעשה ככה זה יותר "בזבזני" כי שהוא יוסיף עוד אי פי הוא יטען את כל השורה ורק אז יוסיף את ה IP החדש וזה יבזבז הרבה תעבורה עד כמה שאני יודע... |
ציטוט:
אבל יכול להיות לו כפילויות של IP וגם בעיות במשיכה של הנתונים איך שאמרתי לו באחד הפוסטים - זה הדרך היעילה ביותר. |
ציטוט:
|
ציטוט:
אולי יעמיס על השרת אבל מה הקשר לתעבורה? 8-* |
כל הזמנים הם GMT +2. הזמן כעת הוא 12:54. |
מופעל באמצעות VBulletin גרסה 3.8.6
כל הזכויות שמורות ©
כל הזכויות שמורות לסולל יבוא ורשתות (1997) בע"מ