نویسنده(های) اصلی | رابرت کوجشال، کلیف اسپنسر |
---|---|
توسعهدهنده(ها) | تاد سی. میلر |
انتشار اولیه | تقریباً 1980[۱] |
انتشار پایدار | 1.9.11p3
/ ۲۱ ژوئن ۲۰۲۲[۲] |
مخزن | |
نوشتهشده با | C |
سیستمعامل | شبهیونیکس |
نوع | Privilege authorization |
مجوز | ISC-style[۳] |
وبگاه |
sudo نرمافزاری در خط فرمان سیستمعاملهای یونیکس و شبهیونیکس است که به کاربرها امکان میدهد تا برنامهها را با دسترسی کاربری دیگر —بدون خروج کاربر کنونی از سیستم— اجرا کنند. کاربر هدف معمولاً کاربر اصلی سیستمعامل یا کاربر ریشه (به انگلیسی: root user) است که البته میتواند هر کاربر دیگری نیز باشد. کاربرد معمول این دستور در اجرای برنامهها و فرمانهایی است که نیاز به سطح دسترسی کاربر ریشه دارند؛ مانند نصب نرمافزار، تغییر در پروندههای سیستمی و بیشتر پروندههایی که در زیرشاخههای مهم سیستمعامل قرار دارند. اجازهٔ دسترسی به فرمان سودو فقط به کاربرانی داده میشود که قبلاً برای سیستم تعریف شده باشند. این گروه از کاربران «سودوگران» (به انگلیسی: sudoers) نام دارند و با ویرایش پروندهٔ sudoers در مسیر /etc میتوان تنظیمات مربوط را ویرایش کرد؛ که البته ویرایش این پرونده خود منوط به داشتن دسترسی کاربر ریشه است. در بیشتر توزیعها اجازهٔ اجرای فرمان سودو به همهٔ کاربران بهطور پیشفرض داده شدهاست. sudo معمولاً به صورت پیشفرض در توزیعهای شبهیونیکس وجود دارد اما در توزیعهای سادهگرا مثل آرچ لینوکس ممکن است به صورت پیشفرض وجود نداشته باشد.
پس از اجرای دستور sudo
از کاربر رمز عبور خواسته میشود که در حالت پیشفرض و در هنگام گریز به فضای کاربر ریشه، رمز عبور خود اوست. گرچه میتوان با ویرایش پروندهٔ sudoers که در مسیر /etc قرار دارد، و با افزودن %sudo ALL=NOPASSWD: ALL
از درخواست رمز عبور جلوگیری کرد. با استفاده از پارامتر -i و درج رمز عبور، سیستم بهطور مجازی وارد حساب کاربر ریشه میشود؛ و همچنین با پارامتر -u user میتوان وارد حساب یک کاربر دیگر شد (user نام کاربر هدف است) و دستورهایی را که فقط کاربر هدف مجاز به اجرای آن است اجرا کرد یا به زیرپوشههای شخصی آن کاربر دست پیدا کرد.
sudo [-n] -h | -K | -k | -L | -V | -v
توضیح اختیارات:
sudo -i
و از طرف کاربر ریشه اجرا شود، پس از نمایش نسخهٔ کنونیِ سودو، موارد پیشفرض فرمان و آدرسهای شبکه محلی سیستم را نمایش میدهد.نیز:
sudo -l[l] [-AnS] [-g groupname|gid] [-U username] [-u username|uid] [command]
توضیح:
sudo -l
اجرا شود فهرست تمام فرمانهایی را که کاربر میتواند (یا نمیتواند) اجرا کند نمایش میدهد. اگر بعد از l-، دستوری که اجرای آن توسط سودوگران مجاز باشد (مثلاً sudo -l apt-get
) نوشته شود، مسیر آن دستور و آرگومانهای خط فرمان نمایش مییابد و در صورت مجاز نبودن اجرای دستور، از خط فرمان سودو خارج میشود.برای فهرست کردن پوشههایی که دسترسی کاربر معمولی به آنها غیرمجاز است؛ مثلاً:
user@localhost:/$ sudo ls /root
برخی دستورها در محیط اولیه سودو اجرا نمیشوند. این دستورها را باید در زیربدنه اجرا کرد:
user@localhost:/$ sudo sh -c "cd /root"
دستور زیر، درخواست کاربر user مبنی بر نصب نرمافزار fontforge است:
user@localhost:/$ sudo apt-get install fontforge
دستور visudo ابزاری برای ویرایش پروندهٔ /etc/sudoers توسط نرمافزار vi (یا هر ویرایشگر دیگری که توسط متغیر محیطی EDITOR مشخص شده باشد) است. اجرای visudo باید از طرف کاربر ریشه باشد:
user@localhost:/$ sudo visudo
همچنین دستورهای kdesudo و gksudo نیز برای استفاده در واسط گرافیکی کاربر به کار میروند.
در مایکروسافت ویندوز نیز دستور Run as (administrator/user) اجازهٔ اجرای ابزارهای خاص و برنامهها را با مجوز کاربری دیگر فراهم میکند.
<ref>
غیرمجاز؛ متنی برای یادکردهای با نام todmil7
وارد نشده است. (صفحهٔ راهنما را مطالعه کنید.).
{{cite web}}
: External link in |ناشر=
(help){{cite web}}
: External link in |ناشر=
(help); Unknown parameter |نشانی نویسنده=
ignored (help) بایگانیشده در ۲۲ ژوئیه ۲۰۱۱ توسط Wayback Machine{{cite web}}
: External link in |ناشر=
(help)