Facebook Pixel
Searching...
فارسی
EnglishEnglish
EspañolSpanish
简体中文Chinese
FrançaisFrench
DeutschGerman
日本語Japanese
PortuguêsPortuguese
ItalianoItalian
한국어Korean
РусскийRussian
NederlandsDutch
العربيةArabic
PolskiPolish
हिन्दीHindi
Tiếng ViệtVietnamese
SvenskaSwedish
ΕλληνικάGreek
TürkçeTurkish
ไทยThai
ČeštinaCzech
RomânăRomanian
MagyarHungarian
УкраїнськаUkrainian
Bahasa IndonesiaIndonesian
DanskDanish
SuomiFinnish
БългарскиBulgarian
עבריתHebrew
NorskNorwegian
HrvatskiCroatian
CatalàCatalan
SlovenčinaSlovak
LietuviųLithuanian
SlovenščinaSlovenian
СрпскиSerbian
EestiEstonian
LatviešuLatvian
فارسیPersian
മലയാളംMalayalam
தமிழ்Tamil
اردوUrdu
The Linux Programming Interface

The Linux Programming Interface

A Linux and UNIX System Programming Handbook
توسط Michael Kerrisk 2010 1552 صفحات
4.63
500+ امتیازها
گوش دادن
Listen to Summary

نکات کلیدی

1. هسته: هسته‌ی برنامه‌نویسی سیستم

هسته‌ی سیستم‌عامل: هسته.

نقش هسته. هسته قلب سیستم‌عامل است که منابع کامپیوتر مانند CPU، حافظه و دستگاه‌ها را مدیریت می‌کند. این هسته به عنوان واسطه‌ای بین برنامه‌ها و سخت‌افزار عمل می‌کند و یک رابط ثابت برای انجام وظایف توسط برنامه‌ها فراهم می‌آورد. هسته مسئول زمان‌بندی فرآیندها، مدیریت حافظه، دسترسی به سیستم فایل و تعامل با دستگاه‌ها است.

حالت کاربر در مقابل حالت هسته. هسته در یک حالت ویژه عمل می‌کند که به آن اجازه می‌دهد به تمام منابع حافظه و سخت‌افزار دسترسی داشته باشد. برنامه‌های کاربر در یک حالت محدود اجرا می‌شوند که مانع از دسترسی مستقیم آن‌ها به حافظه هسته یا انجام عملیات ویژه می‌شود. این جداسازی به حفظ ثبات و امنیت سیستم کمک می‌کند.

فراخوانی‌های سیستمی. برنامه‌های کاربر از طریق فراخوانی‌های سیستمی با هسته تعامل می‌کنند که نقاط ورودی کنترل‌شده‌ای به هسته هستند. این فراخوانی‌ها به برنامه‌ها اجازه می‌دهند تا خدماتی از هسته درخواست کنند، مانند ورودی/خروجی فایل، ایجاد فرآیند و ارتباطات شبکه. API فراخوانی‌های سیستمی لینوکس محور اصلی این کتاب است.

2. ورودی/خروجی فایل: رابط جهانی

جهانی بودن ورودی/خروجی.

مدل ورودی/خروجی جهانی. سیستم‌های UNIX، از جمله لینوکس، از یک مدل ورودی/خروجی جهانی استفاده می‌کنند که در آن از همان فراخوانی‌های سیستمی (open()، read()، write()، close() و غیره) برای انجام ورودی/خروجی بر روی تمام انواع فایل‌ها، از جمله فایل‌های عادی، دستگاه‌ها، لوله‌ها و سوکت‌ها استفاده می‌شود. این انتزاع برنامه‌نویسی را ساده‌تر کرده و قابلیت استفاده مجدد از کد را ترویج می‌دهد.

توصیف‌گرهای فایل. فایل‌های باز با استفاده از توصیف‌گرهای فایل که اعداد صحیح کوچکی هستند، ارجاع داده می‌شوند. یک فرآیند سه توصیف‌گر فایل استاندارد را به ارث می‌برد: 0 (ورودی استاندارد)، 1 (خروجی استاندارد) و 2 (خطای استاندارد). این توصیف‌گرها می‌توانند به فایل‌ها یا دستگاه‌های دیگر هدایت شوند.

بافرینگ. هم هسته و هم کتابخانه stdio بافرینگ ورودی/خروجی فایل را برای بهبود عملکرد انجام می‌دهند. هسته از یک بافر کش برای ذخیره‌سازی داده‌ها در حافظه استفاده می‌کند که تعداد دسترسی‌های دیسک را کاهش می‌دهد. کتابخانه stdio نیز از بافرها برای کاهش تعداد فراخوانی‌های سیستمی استفاده می‌کند. درک بافرینگ برای نوشتن برنامه‌های کارآمد و قابل اعتماد بسیار مهم است.

3. فرآیندها: بنیاد اجرای برنامه

فرآیندها و برنامه‌ها.

فرآیندها در مقابل برنامه‌ها. یک برنامه فایلی است که شامل دستورالعمل‌ها و داده‌ها است، در حالی که یک فرآیند نمونه‌ای از یک برنامه در حال اجرا است. هسته فرآیندها را مدیریت می‌کند و منابعی مانند زمان CPU، حافظه و توصیف‌گرهای فایل را تخصیص می‌دهد. هر فرآیند دارای یک شناسه فرآیند منحصر به فرد (PID) و یک شناسه فرآیند والد (PPID) است.

چیدمان حافظه. حافظه مجازی یک فرآیند به بخش‌هایی تقسیم می‌شود: متن (دستورالعمل‌های برنامه)، داده (متغیرهای جهانی اولیه‌گذاری شده)، هپ (حافظه تخصیص‌یافته به‌طور دینامیک) و پشته (اطلاعات تماس تابع). هسته حافظه مجازی را مدیریت می‌کند و به هر فرآیند فضای آدرس جداگانه‌ای ارائه می‌دهد.

ایجاد و خاتمه فرآیند. یک فرآیند جدید با استفاده از fork() ایجاد می‌شود که فرآیند والد را کپی می‌کند. سپس فرآیند فرزند می‌تواند از execve() برای بارگذاری و اجرای یک برنامه جدید استفاده کند. یک فرآیند با استفاده از _exit() یا exit() خاتمه می‌یابد و والد آن می‌تواند وضعیت خاتمه آن را با استفاده از wait() به دست آورد.

4. مدیریت حافظه: هنر تخصیص

تخصیص حافظه در هپ.

تخصیص هپ. فرآیندها می‌توانند به‌طور دینامیک حافظه را در هپ با استفاده از توابعی مانند malloc() و free() تخصیص دهند. هپ منطقه‌ای از حافظه است که با تخصیص و آزادسازی حافظه بزرگ و کوچک می‌شود. هسته با تنظیم مرز برنامه، هپ را مدیریت می‌کند.

تخصیص پشته. پشته منطقه‌ای از حافظه است که برای ذخیره متغیرهای محلی و اطلاعات تماس تابع استفاده می‌شود. تابع alloca() حافظه را در پشته تخصیص می‌دهد، اما این حافظه به‌طور خودکار زمانی که تابع بازمی‌گردد آزاد می‌شود.

نقشه‌برداری حافظه. فراخوانی سیستمی mmap() یک نقشه‌برداری حافظه ایجاد می‌کند که می‌تواند برای نقشه‌برداری یک فایل به حافظه یا ایجاد یک منطقه حافظه ناشناس استفاده شود. نقشه‌برداری‌های حافظه می‌توانند بین فرآیندها به اشتراک گذاشته شوند و روشی سریع برای IPC فراهم کنند.

5. زمان و زمان‌بندی: کنترل جریان

زمان.

مفاهیم زمان. سیستم‌های UNIX از زمان تقویمی (ثانیه‌ها از زمان آغاز) و زمان فرآیند (زمان CPU استفاده شده توسط یک فرآیند) استفاده می‌کنند. هسته یک ساعت نرم‌افزاری را نگهداری می‌کند که زمان را در واحدهایی به نام jiffies اندازه‌گیری می‌کند.

تایمرها. فراخوانی‌های سیستمی setitimer() و alarm() تایمرهای دوره‌ای را ایجاد می‌کنند که هنگام انقضا سیگنال تولید می‌کنند. این تایمرها می‌توانند برای تعیین زمان‌های انقضا در عملیات مسدودکننده استفاده شوند.

خوابیدن. توابع sleep() و nanosleep() اجرای یک فرآیند را برای یک بازه زمانی مشخص متوقف می‌کنند. تابع POSIX clock_nanosleep() یک روش دقیق‌تر برای خوابیدن ارائه می‌دهد که از یک ساعت مشخص استفاده می‌کند.

زمان‌بندی فرآیند. زمان‌بند هسته تعیین می‌کند که کدام فرآیندها به CPU دسترسی پیدا می‌کنند. فرآیندها دارای یک مقدار nice هستند که بر اولویت آن‌ها تأثیر می‌گذارد. سیاست‌های زمان‌بندی زمان واقعی (SCHED_RR و SCHED_FIFO) کنترل دقیق‌تری بر زمان‌بندی فرآیندها فراهم می‌کنند.

6. سیگنال‌ها: ارتباط ناهمزمان

سیگنال‌ها: مفاهیم بنیادی.

مکانیسم سیگنال. سیگنال‌ها نوعی اعلان ناهمزمان به یک فرآیند هستند که یک رویداد رخ داده است. سیگنال‌ها می‌توانند توسط هسته (مانند استثناهای سخت‌افزاری، ورودی ترمینال)، توسط یک فرآیند دیگر یا توسط خود فرآیند تولید شوند.

مدیریت سیگنال. یک فرآیند می‌تواند تصمیم بگیرد که یک سیگنال را نادیده بگیرد، عمل پیش‌فرض آن را بپذیرد (مانند خاتمه) یا یک مدیریت سیگنال تعیین کند، که تابعی است که هنگام دریافت سیگنال فراخوانی می‌شود.

ماسک سیگنال. یک فرآیند می‌تواند با افزودن سیگنال‌های خاص به ماسک سیگنال خود، تحویل برخی سیگنال‌ها را مسدود کند. سیگنال‌های مسدود شده تا زمانی که آزاد نشوند، در حالت معلق باقی می‌مانند. سیگنال‌ها در صف قرار نمی‌گیرند؛ اگر در حین مسدود بودن، همان سیگنال چندین بار تولید شود، تنها یک بار تحویل داده می‌شود.

API سیگنال. تابع signal() API قدیمی‌تری برای تعیین مدیریت‌کننده‌های سیگنال است، اما قابل حمل نیست. تابع sigaction() روش ترجیحی برای تعیین مدیریت‌کننده‌های سیگنال است، زیرا کنترل بیشتری را فراهم می‌کند و قابل حمل‌تر است.

7. رشته‌ها: اجرای همزمان

رشته‌ها: مقدمه.

رشته‌ها در مقابل فرآیندها. رشته‌ها مکانیزمی برای اجرای همزمان درون یک فرآیند واحد هستند. رشته‌ها همان حافظه مجازی، توصیف‌گرهای فایل و وضعیت‌های سیگنال را به اشتراک می‌گذارند، اما هر رشته دارای پشته و شناسه رشته خود است.

API Pthreads. API Pthreads مجموعه‌ای استاندارد از توابع برای ایجاد، خاتمه و همگام‌سازی رشته‌ها را فراهم می‌کند. تابع pthread_create() یک رشته جدید ایجاد می‌کند و pthread_exit() یک رشته را خاتمه می‌دهد. تابع pthread_join() منتظر خاتمه یک رشته می‌ماند.

همگام‌سازی رشته. رشته‌ها از mutexها و متغیرهای شرطی برای همگام‌سازی دسترسی به منابع مشترک استفاده می‌کنند. Mutexها دسترسی انحصاری به یک متغیر مشترک را فراهم می‌کنند، در حالی که متغیرهای شرطی به رشته‌ها اجازه می‌دهند تا منتظر تغییرات در وضعیت یک متغیر مشترک باشند.

ایمنی رشته. توابع ایمن برای رشته می‌توانند به‌طور همزمان از چندین رشته فراخوانی شوند. توابع غیر ایمن برای رشته باید در برنامه‌های چندرشته‌ای اجتناب شوند. داده‌های خاص رشته و ذخیره‌سازی محلی رشته مکانیزم‌هایی برای ایمن کردن توابع غیر ایمن برای رشته بدون تغییر رابط‌های آن‌ها فراهم می‌کنند.

8. ارتباط بین فرآیندها: اشتراک‌گذاری داده‌ها و همگام‌سازی

مرور کلی ارتباط بین فرآیندها.

مکانیسم‌های IPC. سیستم‌های UNIX مجموعه‌ای از مکانیسم‌ها برای ارتباط بین فرآیندها (IPC) فراهم می‌کنند، از جمله لوله‌ها، FIFOها، صف‌های پیام، semaphoreها، حافظه مشترک و سوکت‌ها. این مکانیسم‌ها می‌توانند برای تبادل داده‌ها و همگام‌سازی اقدامات فرآیندها استفاده شوند.

انتقال داده در مقابل حافظه مشترک. تسهیلات انتقال داده (لوله‌ها، FIFOها، صف‌های پیام، سوکت‌ها) شامل کپی داده‌ها بین فرآیندها است، در حالی که حافظه مشترک به فرآیندها اجازه می‌دهد تا به‌طور مستقیم به همان منطقه حافظه دسترسی پیدا کنند. حافظه مشترک سریع‌تر است، اما نیاز به همگام‌سازی صریح دارد.

IPC سیستم V در مقابل POSIX. مکانیسم‌های IPC سیستم V (صف‌های پیام، semaphoreها، حافظه مشترک) قدیمی‌تر و در دسترس‌تر هستند، اما APIهای آن‌ها پیچیده‌تر و کمتر سازگار با مدل ورودی/خروجی سنتی UNIX هستند. مکانیسم‌های IPC POSIX API ساده‌تر و سازگارتر را فراهم می‌کنند، اما در تمام پیاده‌سازی‌های UNIX در دسترس نیستند.

9. سوکت‌ها: اتصال در شبکه‌ها

سوکت‌ها: مقدمه.

سوکت‌ها به عنوان IPC. سوکت‌ها یک مکانیزم IPC چندمنظوره هستند که می‌توانند برای ارتباط بین فرآیندها در همان میزبان (سوکت‌های دامنه UNIX) یا بین فرآیندها در میزبان‌های مختلف متصل به یک شبکه (سوکت‌های دامنه اینترنت) استفاده شوند.

انواع سوکت. سوکت‌ها به دو نوع اصلی تقسیم می‌شوند: سوکت‌های جریانی (SOCK_STREAM) که یک کانال ارتباطی قابل اعتماد و دوطرفه برای جریان بایت فراهم می‌کنند و سوکت‌های دیتاگرام (SOCK_DGRAM) که ارتباطی غیرقابل اعتماد و بدون اتصال و مبتنی بر پیام را فراهم می‌کنند.

عملیات سوکت. فراخوانی‌های کلیدی سیستم سوکت شامل socket() (ایجاد یک سوکت)، bind() (بستن یک سوکت به یک آدرس)، listen() (علامت‌گذاری یک سوکت جریانی به عنوان غیرفعال)، accept() (پذیرفتن یک اتصال بر روی یک سوکت جریانی در حال گوش دادن) و connect() (اتصال به یک سوکت همتا) است.

سوکت‌های دامنه اینترنت. سوکت‌های دامنه اینترنت از آدرس‌های IP و شماره‌های پورت برای شناسایی نقاط پایانی ارتباط استفاده می‌کنند. توابع getaddrinfo() و getnameinfo() برای تبدیل بین نام‌های میزبان و نام‌های خدمات و نمایش‌های عددی مربوطه استفاده می‌شوند.

10. ترمینال‌ها و ترمینال‌های مجازی: تعامل با کاربر

ترمینال‌ها.

ویژگی‌های ترمینال. ترمینال‌ها دارای مجموعه‌ای از ویژگی‌ها هستند که نحوه عملکرد آن‌ها را کنترل می‌کنند، از جمله کاراکترهای خاص، پرچم‌ها و حالت‌های ورودی/خروجی. این ویژگی‌ها می‌توانند با استفاده از توابع tcgetattr() و tcsetattr() بازیابی و تغییر یابند.

حالت‌های ورودی/خروجی ترمینال. ترمینال‌ها می‌توانند در حالت کانونی (ورودی خط به خط) یا غیرکانونی (ورودی کاراکتر به کاراکتر) عمل کنند. حالت ورودی/خروجی ترمینال توسط پرچم‌های ترمینال کنترل می‌شود.

ترمینال‌های مجازی. ترمینال‌های مجازی (ptys) یک جفت دستگاه مجازی متصل هستند، یک مستر و یک اسلوی. دستگاه اسلو یک رابط ارائه می‌دهد که مانند یک ترمینال عمل می‌کند، در حالی که دستگاه مستر وسیله‌ای برای کنترل اسلو فراهم می‌کند. ترمینال‌های مجازی در برنامه‌های مختلفی از جمله پنجره‌های ترمینال و خدمات ورود به شبکه استفاده می‌شوند.

کنترل ترمینال. فراخوانی سیستمی ioctl() برای انجام مجموعه‌ای از عملیات کنترلی بر روی ترمینال‌ها استفاده می‌شود، از جمله تنظیم ویژگی‌های ترمینال، کنترل خط ترمینال و به‌دست آوردن اندازه پنجره ترمینال.

11. امنیت و قابلیت‌ها: حفاظت از سیستم

نوشتن برنامه‌های امن با امتیازات ویژه.

برنامه‌های ویژه. برنامه‌های ویژه به منابع سیستمی دسترسی دارند که برای کاربران عادی در دسترس نیست. چنین برنامه‌هایی باید با احتیاط بسیار نوشته شوند تا از آسیب‌پذیری‌های امنیتی جلوگیری شود.

کمترین امتیاز. برنامه‌های ویژه باید با کمترین امتیاز لازم برای انجام وظایف خود عمل کنند. این به معنای رها کردن امتیازات زمانی است که به آن‌ها نیاز نیست و به‌طور دائمی رها کردن امتیازات زمانی است که هرگز دوباره به آن‌ها نیاز نخواهد بود.

اعتبارسنجی ورودی. برنامه‌های ویژه باید به دقت تمام ورودی‌ها از منابع غیرقابل اعتماد، از جمله آرگومان‌های خط فرمان، متغیرهای محیطی و داده‌های فایل‌ها و اتصالات شبکه را اعتبارسنجی کنند.

قابلیت‌ها. طرح قابلیت‌های لینوکس امتیاز ویژه سنتی را به واحدهای مجزایی به نام قابلیت‌ها تقسیم می‌کند. این به یک فرآیند اجازه می‌دهد تا تنها امتیازاتی را که نیاز دارد، دریافت کند و در نتیجه پتانسیل آسیب را در صورت نفوذ برنامه کاهش دهد.

12. کتابخانه‌های مشترک: قابلیت استفاده مجدد از کد و کارایی

اصول کتابخانه‌های مشترک.

کتابخانه‌های شیء. کتابخانه‌های شیء فایل‌هایی هستند که شامل کد شیء کامپایل‌شده برای مجموعه‌ای از توابع هستند. کتابخانه‌های ایستا در زمان کامپایل به یک اجرایی لینک می‌شوند، در حالی که کتابخانه‌های مشترک در زمان اجرا بارگذاری می‌شوند.

کتابخانه‌های مشترک. کتابخانه‌های مشترک به چندین فرآیند اجازه می‌دهند تا یک نسخه از کد کتابخانه را در حافظه به اشتراک بگذارند و در نتیجه فضای دیسک و RAM را صرفه‌جویی کنند. کتابخانه‌های مشترک همچنین اجازه می‌دهند تا به‌روزرسانی‌های کتابخانه بدون نیاز به لینک مجدد برنامه‌ها اعمال شوند.

کد مستقل از موقعیت. کتابخانه‌های مشترک باید با استفاده از کد مستقل از موقعیت (PIC) کامپایل شوند که به کد کتابخانه اجازه می‌دهد در هر آدرسی در حافظه بارگذاری شود.

لینک‌گذاری دینامیک. لینک‌کننده دینامیک مسئول بارگذاری کتابخانه‌های مشترک در زمان اجرا و حل ارجاعات نماد است. متغیر محیطی LD_LIBRARY_PATH می‌تواند برای مشخص کردن دایرکتوری‌های اضافی که لینک‌کننده دینامیک باید برای جستجوی کتابخانه‌های مشترک بررسی کند، استفاده شود.

قابلیت دید نماد. کتابخانه‌های مشترک باید تنها نمادهایی را که بخشی از API عمومی آن‌ها هستند، صادر کنند. اسکریپت‌های نسخه می‌توانند برای کنترل قابلیت دید نماد و ایجاد نمادهای نسخه‌بندی شده استفاده شوند.

آخرین به‌روزرسانی::

نقد و بررسی

4.63 از 5
میانگین از 500+ امتیازات از Goodreads و Amazon.

کتاب رابطه‌ برنامه‌نویسی لینوکس با استقبال بسیار مثبت خوانندگان مواجه شده است و آن‌ها به خاطر پوشش جامع آن در زمینه برنامه‌نویسی سیستم لینوکس از آن تمجید می‌کنند. بسیاری این کتاب را به‌عنوان یک مرجع قطعی توصیف کرده و بر توضیحات روشن، مثال‌های عملی و زمینه تاریخی آن تأکید می‌کنند. خوانندگان به عمق، سازماندهی و قابلیت خواندن این کتاب، با وجود حجم قابل توجه آن، ارج می‌نهند. این کتاب به خاطر پیوند دادن مفاهیم نظری با کاربردهای عملی مورد ستایش قرار گرفته و برای یادگیری و مرجع بسیار ارزشمند است. بسیاری از نقدکنندگان زمان قابل توجهی را با این کتاب سپری کرده و آن را برای درک عمیق‌تر از جزئیات لینوکس و فراخوانی‌های سیستم مفید می‌دانند.

درباره نویسنده

مایکل کرریسک نویسنده‌ی کتاب «رابط برنامه‌نویسی لینوکس» است و از سال 1383 نگهدارنده‌ی پروژه‌ی صفحات راهنمای لینوکس بوده است. تجربه‌ی گسترده‌ی او در زمینه‌ی سیستم‌های لینوکس در جامعیت و اعتبار این کتاب مشهود است. سبک نوشتاری کرریسک به خاطر وضوح، اختصار و سازمان‌دهی مناسبش مورد تحسین قرار گرفته و موضوعات پیچیده را برای خوانندگان قابل فهم می‌سازد. تعهد او به این موضوع در پوشش کامل کتاب و سال‌ها تلاشی که برای خلق آن صرف شده، نمایان است. نقش کرریسک در نگهداری مستندات لینوکس به احتمال زیاد به درک عمیق او از این سیستم کمک کرده و او این درک را به‌طور مؤثری از طریق نوشتارش به اشتراک می‌گذارد.

0:00
-0:00
1x
Dan
Andrew
Michelle
Lauren
Select Speed
1.0×
+
200 words per minute
Create a free account to unlock:
Requests: Request new book summaries
Bookmarks: Save your favorite books
History: Revisit books later
Recommendations: Get personalized suggestions
Ratings: Rate books & see your ratings
Try Full Access for 7 Days
Listen, bookmark, and more
Compare Features Free Pro
📖 Read Summaries
All summaries are free to read in 40 languages
🎧 Listen to Summaries
Listen to unlimited summaries in 40 languages
❤️ Unlimited Bookmarks
Free users are limited to 10
📜 Unlimited History
Free users are limited to 10
Risk-Free Timeline
Today: Get Instant Access
Listen to full summaries of 73,530 books. That's 12,000+ hours of audio!
Day 4: Trial Reminder
We'll send you a notification that your trial is ending soon.
Day 7: Your subscription begins
You'll be charged on Mar 22,
cancel anytime before.
Consume 2.8x More Books
2.8x more books Listening Reading
Our users love us
100,000+ readers
"...I can 10x the number of books I can read..."
"...exceptionally accurate, engaging, and beautifully presented..."
"...better than any amazon review when I'm making a book-buying decision..."
Save 62%
Yearly
$119.88 $44.99/year
$3.75/mo
Monthly
$9.99/mo
Try Free & Unlock
7 days free, then $44.99/year. Cancel anytime.
Settings
Appearance
Black Friday Sale 🎉
$20 off Lifetime Access
$79.99 $59.99
Upgrade Now →