גיט

מערכת ניהול גירסאות

גיטאנגלית: Git) היא מערכת ניהול גרסאות מבוססת קוד פתוח, שמטרתה לסייע למפתחים בניהול קוד, תיאום עבודה צוותית ומעקב אחר שינויים בקובצי תוכנה. מטרותיה העיקריות הן לספק מהירות, שלמות מידע ותמיכה בתהליכים מבוזרים ולא ליניאריים.

Git
הדגמת שימוש בסיסי בתוכנת Git
הדגמת שימוש בסיסי בתוכנת Git
מפתחג'וניו המאנו, לינוס טורבאלדס
מחזור חיים7 באפריל 2005 – הווה (19 שנים) עריכת הנתון בוויקינתונים
גרסה אחרונה2.45.0 (29 באפריל 2024) עריכת הנתון בוויקינתונים
מערכת הפעלהחוצה-פלטפורמות
נכתבה בשפותC, Bourne Shell, Tcl, Perl
סוג רישיוןהרישיון הציבורי הכללי של גנו
קוד מקורhttps://git.kernel.org/pub/scm/git/git.git עריכת הנתון בוויקינתונים
קטגוריהניהול גרסאות
git-scm.com
לעריכה בוויקינתונים שמשמש מקור לחלק מהמידע בתבנית

כמערכת בקרת גרסאות מבוזרת, עותק שלה הוא מאגר שמכיל את מלוא המידע עם תיעוד מלא ואפשרויות מעקב אחר שינויי גרסה, ללא תלות בגישה לרשת או בשרת מרכזי.

היוצר של גיט הוא לינוס טורבאלדס והוא יצר את המערכת באפריל של שנת 2005. נכון לשנת 2020, היא נחשבת למערכת ניהול הגרסאות הפופולרית ביותר.[1]

היסטוריה

החל משנת 2002, הפיתוח של פרויקט לינוקס השתמש במערכת ניהול הגרסאות המבוזרת הקניינית BitKeeper (אנ'). בשנת 2005 הצליח אנדרו טריגל לפתח לקוח עצמאי, ובעקבות כך נשלל רישיון השימוש במערכת לפרויקט לינוקס. טורבאלדס לא היה מרוצה ממערכות ניהול הגרסאות האחרות שהיו קיימות באותו שלב,[2] והחליט לכתוב אחת משלו. הוא החל לעבוד על גיט ב-3 באפריל 2005. פחות מחודש לאחר מכן כבר הייתה גרסה שאפשרה פיתוח יעיל של לינוקס (מערכת מרקוריאל נכתבה באותו הזמן ומאותן הסיבות). ביולי של אותה השנה, הפך ג'וניו המאנו למתחזק הראשי.

ברחבי העולם, מספר עצום של חברות הזנק (סטארט-אפ), קולקטיבים וחברות בין-לאומיות, כולל גוגל ומיקרוסופט, משתמשים בגיט כדי לשמור על קוד המקור של פרויקטי התוכנה שלהם. חלקם מארחים פרויקטי גיט משלהם, אחרים משתמשים בגיט באמצעות חברות אירוח מסחריות כמו GitHub (נוסדה בשנת 2007), Bitbucket (אנ') (נוסדה בשנת 2010) ו-GitLab (אנ') (נוסדה בשנת 2011). הגדולה שבהן, GitHub, מונה 40 מיליון מפתחים רשומים ונרכשה על ידי מיקרוסופט תמורת 7.5 מיליארד דולר בשנת 2018.[3]

עדות לדומיננטיות השוק של גיט ניתן למצוא בסקר מפתחים שנערך על ידי Stack Overflow. בסקר של שנת 2018, לדוגמה, נמצא כי 88.4% מכלל 74,298 המשתתפים בסקר בשנת השתמשו בגיט (עלייה מ -69.3% בשנת 2015). המתחרים הקרובים ביותר היו Subversion, עם כניסה של 16.6% (ירידה מ -36.9%); Team Foundation Version Control עם 11.3% (ירידה מ -12.2%); ו-Mercurial, עם 3.7% (ירידה מ -7.9%). למעשה, גיט הפכה לכה דומיננטית עד כדי כך שמדעני הנתונים ב-Stack Overflow לא טרחו לשאול את השאלה בסקר שלהם ב-2019[4] [5].

מבנה

גיט היא מערכת ניהול גרסאות מבוזרת - כל עותק מקומי של המאגר מכיל את כל המידע (כל ההיסטוריה). המידע הזה נשמר בדרך כלל בתת-תיקייה בשם "‎.git". גיט שומרת אובייקטים מסוג מידע (blob, בדרך כלל קובץ), עץ (tree, מבנה ספריות) וגרסה (commit). האובייקטים מזוהים על ידי שם שהוא גיבוב תוכנם לפי SHA-1.

בניגוד לרוב מערכות ניהול הגרסאות המודרניות ששומרות שינויים בין גרסאות שונות[דרוש מקור], גיט שומרת את תוכני הקבצים עצמם. גיט תוכננה להיות מעין מערכת קבצים משוכללת שמעליה תבנה מערכת ניהול גרסאות. בתחילה השם היה אמור להתייחס רק לקרביים ("צנרת"), אולם בהמשך התברר שעדיף לספק גם מימוש אחיד של מערכת ניהול גרסאות ("פורצלן").

לרוב מקובל להסתכל על גרסאות כעץ: בנקודות מסוימות מתפצל הפיתוח לעבודה על ענפים שונים. בגיט אפשר גם למזג ענפים שונים. לכן גיט מתייחס לגרסאות כגרף מכוון חסר מעגלים: גרסה מתבססת על גרסה קודמת ומכילה שינויים כלפיה. אולם גרסה יכולה להיות גם תוצאת מיזוג שתי גרסאות שונות.

מונחים

גרסה (revision או commit)

כל שינוי שנשמר הוא צומת בגרף, המכונה גרסה. בדרך כלל מדובר על שינוי ביחס לגרסה קודמת, אולם השינוי יכול להיות גם מיזוג (merge) של שתי גרסאות קודמות משני ענפי פיתוח שונים. שם הגרסה הוא פלט של SHA-1, שהוא למעשה מספר הקסדצימלי באורך 40 "ספרות" הקסדצימליות (לדוגמה: b70df95dbae39b3f0447be5c214d1dee33245827). אפשר להשתמש ברוב המקרים במספר יותר קטן של תווים מתחילת המספר (לדוגמה: b70df95) כשם מקוצר לאותה גרסה.

ענף (branch)

הוא תת גרף בגרף הגרסאות. כל גרסה, כלומר כל צומת, מוצגת כאן בשמה המקוצר. גיט מחזיק רשימה של ענפים מקומיים והם בדרך כלל הקצוות הנוכחיים של השינויים. מקובל לקרוא לענף הראשי master או main. כמו כן HEAD הוא שם שמור לצומת שבו אנחנו נמצאים כרגע (בדרך כלל: בענף הפיתוח הפעיל). כל גרסה מסומנת על ידי שם מקוצר.

תגית (tag)

אפשר לסמן גרסה מסוימת בתג. זה מאפשר לתת שם סמלי למקום מסוים (לדוגמה: תג בשם v1.23.5-beta2 יכול לסמל את גרסה מס' 1.23.5-beta2 של התוכנה). בגיט התג יכול לכלול גם חתימה דיגיטלית. בכך אפשר להתחייב על תוכנו של תג.

מיזוג (merge)

בדרך כלל כל גרסה מתקבלת על ידי שינויים בגרסה, צומת, אחד בלבד. על גרסה כזו נאמר שיש לה אב אחד. אולם לפעמים מעוניינים ליצור גרסה חדשה ממיזוג של שתי גרסאות. לדוגמה: ענף פיתוח צדדי שהושלם ממוזג לתוך הענף הראשי. גיט זוכר את ההיסטוריה הזו. לפיכך, לגרסה שהיא מיזוג גרסאות יש שני הורים (ולפעמים אף יותר).

דוגמה, מ-http://tzafrir.org.il/~tzafrir/git_test/.git, של מאגר גיט פשוט:

* 8f56b9b (HEAD, tag: v0.3, master) Some integration work* 45ace55 Merge branch 'feature-branch'|\| * 5f90c8c (feature-branch) Add a new feature| | * b76c518 (experiment) Testing an experimental feature| |/|/|* | b70df95 (tag: v0.2) Adding a new header* | b65d3e3 Adding documentation|/* 5742dfe (tag: v0.1) Adding hello.

בדוגמה זו נראה מאגר תוכנה קטן. כל גרסה נקראת בשמה המקוצר, ב-7 ספרות הקסאדצימליות. שלוש גרסאות סומנו בתגיות (v0.1, v0.2, v0.3). רוב התיקונים נעשו בענף הראשי (master). כל התגיות הם של גרסאות על הענף הראשי. אולם היו שני ענפי פיתוח צדדיים: הענף 'feature-branch' נוצר לאחר גרסה v0.1 ומוזג לענף הראשי לאחר סימון v0.2. הענף השני הוא הענף הניסיוני 'experiment' שלא מוזג עדיין.

איסוף זבל

איסוף זבל (Garbage Collection) הוא תהליך שבו תוכנה מוחקת אובייקטים שקיימים עדיין בזיכרון למרות שהצורך בהם הסתיים.

בהקשר של git, מחיקה של ענף גרסאות לדוגמה איננה כוללת מחיקה מיידית של כל הגרסאות המקושרות אליו[דרוש מקור]. במקום זאת, מופעל באופן תקופתי תהליך של "איסוף זבל" הבודק את כל הגרסאות ומוחק גרסאות שכבר אין שום ענף או תגית המפנים אליהן.

שרת

המאגר בגיט עובד מול מאגרים אחרים. המאגרים הללו יכולים להיות קבצים על מערכת הקבצים המקומית או קבצים מרוחקים על שרתים אחרים. אם הקבצים יושבים על שרתים אחרים יש כמה אפשרויות לגשת אליהם:

  • פרוטוקול טיפש (dumb)‏ - HTTP‏, HTTPS (כאשר שרתים מאפשרים גישה לקבצים בתיקייה) או כל פרוטוקול אחר שמאפשר גישה לתוכנם של קבצים על שרת מרוחק (לדוגמה: FTP). לקריאה בלבד.
  • שרת גיט: מקשיב בדרך כלל על פורט TCP‏ 9148. לקריאה בלבד.
  • חיבור דרך SSH

ההתחברות דרך SSH או דרך שרת גיט יעילה יותר (מהירה יותר וצורכת פחות נפח תעבורה) מאשר הפרוטוקול הטיפש, מכיוון שאפשר להשתמש במידע בצורה יעילה יותר (בקשת fetch-pack). פרוטוקול גיט לא כולל הזדהות ולכן לא נהוג לאפשר העלאת תוכן דרכו. נהוג לאפשר העלאת תוכן רק דרך SSH (במקרים רבים ההזדהות היא על ידי מפתחות ציבוריים).[6][7]

ממשקי גיט

ממשק האתר GitLab

במצבו הטבעי, Git הוא יישום הפועל בטרמינל Linux.

עם זאת, מאחר שמדובר בקוד מקור פתוח מעוצב היטב, מפתחים מכל רחבי העולם עיצבו דרכים אחרות לגשת אליו.

הוא חינמי ומגיע בחבילות Linux,‏ BSD,‏ Illumos ומערכות הפעלה אחרות דמויות Unix. הוא נראה כך:

$ git --versiongit version 2.43.0

ככל הנראה, ממשקי הגיט הכי מוכרים הם מבוססי אתרים: אתרים כמו GitHub, המקור הפתוח GitLab,‏ Savannah,‏ BitBucket ו־SourceForge כולם מציעים אירוח קוד מקוון כדי למקסם את ההיבט הציבורי והחברתי של קוד פתוח, ברמות שונות, יחד עם GUI מבוסס-דפדפן כדי למזער את עקומת הלמידה של השימוש בגיט. השילוב השקוף ביותר מגיע בצורה של תמיכה במנהל קבצים. מנהל הקבצים KDE, Dolphin, יכול להראות את מצב הגיט של תיקייה ואף ליצור התחייבויות, דחיפות ומשיכות. SparkleShare (אנ') משתמשת בגיט כבסיס לממשק שיתוף קבצים בסגנון Dropbox.

סיעוף ומיזוג

לגיט יש מודל סיעוף שמייחד אותה מתוכנות אחרות לניהול קוד. גיט מאפשרת ליצור מספר ענפים (branch) מקומיים על מחשב, שיכולים להיות בלתי תלויים זה בזה לחלוטין ומאפשרים להוסיף לקוד חלקים חדשים במקביל ובצורה נוחה. מיזוג הקוד שנכתב בענפים השונים לכדי גרסה יציבה אינו מסובך בזכות הממשק הוויזואלי של גיט.

בקרב המפתחים קיימות קונבנציות לשמות של ענפים בהתאם לתפקידם, ונהוג שלכל פרויקט יש ענף ראשי שכל הענפים מסתעפים ממנו, ומתמזגים אליו בסיום הפיתוח הנקודתי. במשך שנים רבות היה נהוג לכנות את הענף הראשי בשם "master", אך ב-2021 שונה השם ל-"main" בעקבות מחאות על הקונוטציה השלילית של השם master שמתקשרת לעבדות.[8] ענף נוסף שנהוג להשתמש בו הוא "develop" - ענף שמשמש לייצוג גרסת הפיתוח היציבה שעדיין לא שוחררה לשימוש. לעיתים נעשה שימוש גם ב-"stable" שמשמש ליצוג הגרסה האחרונה של מערכת שהיא יציבה בוודאות.[9]

מודל הסיעוף מאפשר התנסות בפיתוח ללא חשש לפגוע במהימנות של המוצר הראשי ולכן הופך את חוויית הפיתוח של המשתמשים לקלה יותר ולנוחה יותר. המודל גם מאפשר מעבר מהיר בין גרסאות במקרה של תקלות ובאגים.

גרסאות

רשימה של גרסאות:

מקור
מספר גרסהתאריך שחרור גרסה
0.9911-07-2005
1.021-12-2005
1.108-01-2006
1.212-02-2006
1.318-04-2006
1.410-06-2006
1.514-02-2007
1.617-08-2008
1.713-02-2010
1.821-10-2012
1.914-02-2014
2.028-05-2014
2.116-08-2014
2.226-11-2014
2.305-02-2015
2.430-04-2015
2.527-07-2015
2.628-09-2015
2.704-10-2015
2.828-03-2016
2.906-06-2016
2.1002-09-2016
2.1129-11-2016
2.1224-02-2017
2.1310-05-2017
2.1404-08-2017
2.1530-10-2017
2.1617-01-2018
2.1702-04-2018
2.1821-06-2018
2.1910-09-2018
2.2009-12-2018
2.2124-02-2019
2.2207-06-2019
2.2316-08-2019
2.2404-11-2019
2.2513-01-2020
2.3727-07-2022
2.3803-10-2022
2.38.118-10-2022


ארגון

טורבאלדס פיתח את גיט בחודשים הראשונים. לאחר מכן הפך ג'וניו המאנו למפתח הראשי. גיט לא דורשת השמת זכויות יוצרים, ונכון לסוף 2010 יותר מ-600 אנשים תרמו קוד למיזם.[10] החל מה־16 בדצמבר 2010 המיזם מנוהל בחסות מוסד חופש התוכנה (Software Freedom Conservatory). גוף זה מספק ישות משפטית (לדוגמה: עבור תרומות) וייעוץ משפטי.[11]

ראו גם

קישורים חיצוניים

מדיה וקבצים בנושא גיט בוויקישיתוף

הערות שוליים

🔥 Top keywords: ערב אל-עראמשהעמוד ראשימיוחד:חיפושחטיפת חיילי צה"ל בהר דבליגת האלופותקטגוריה:זמרים ישראליםמלחמת חרבות ברזלמיוחד:שינויים אחרוניםקערת ליל הסדרקטגוריה:זמרים השרים בעבריתשקשוקה (סדרת טלוויזיה)התקיפה האיראנית על ישראל (2024)ריאל מדרידרותם אבוהבנמר אנטוליעדי אשכנזיאיראןיריחו (טיל)נעמי פולניג'קי אלקייםקרלו אנצ'לוטימרדכי שפרפייסבוקדרגות צה"לטיל בליסטיישראלמנצ'סטר סיטיחטיפת משפחת ביבסמיוחד:רשימת המעקבערוץ 77 באוקטובריוטיובעומר אדםיוסי כהןחטיבת עציוניפסחכלי טיס בלתי מאוישז'וזפ גוארדיולהעונת 2023/2024 בליגת האלופות