base_tutorial/6-MariaDB/Install MariaDB on Ubuntu 22.04.md
2025-04-09 10:17:16 +03:30

184 lines
12 KiB
Markdown

<p dir="rtl" align="center"> بسم الله الرحمن الرحیم </p>
# <p dir="rtl" align="center">نحوه نصب MariaDB در Ubuntu 22.04</p> #
<p dir="rtl" align="right">معرفی
<br>
MariaDB یک سیستم مدیریت پایگاه داده رابطه‌ای منبع باز است که معمولاً به عنوان جایگزینی برای MySQL به عنوان بخش پایگاه داده پشته <br>محبوب LAMP (Linux، Apache، MySQL، PHP/Python/Perl) استفاده می‌شود. در نظر گرفته شده است که جایگزینی برای MySQL باشد.
<br>
نسخه کوتاه این راهنمای نصب شامل این سه مرحله است:<br>
<br>
فهرست بسته خود را با استفاده از apt به روز کنید<br>
بسته mariadb-server را با استفاده از apt نصب کنید. این بسته همچنین ابزارهای مرتبط را برای تعامل با MariaDB می‌کِشد<br>
اسکریپت امنیتی mysql_secure_installation را اجرا کنید تا دسترسی به سرور را محدود کنید
</p>
<p dir="rtl" align="right">به روز رسانیها را بررسی کنید و قبل از انجام هر اقدام دیگری آنها را نصب کنید. </p>
```groovy
sudo apt update
sudo apt install mariadb-server
sudo mysql_secure_installation
```
## <p dir="rtl" align="right"> گام اول: نصب MariaDB </p> ##
<p dir="rtl" align="right">از زمان نگارش این مقاله، مخازن APT پیش‌فرض اوبونتو 22.04 شامل MariaDB نسخه 10.5.12 است.
برای نصب آن، فهرست بسته را در سرور خود با apt به روز کنید:</p>
```groovy
sudo apt update
```
سپس بسته را نصب کنید:
```groovy
sudo apt install mariadb-server
```
<p dir="rtl" align="right">این دستورات MariaDB را نصب می‌کنند، اما از شما خواسته نمی‌شود رمز عبور تعیین کنید یا تغییرات دیگری در پیکربندی انجام دهید. از آنجایی که پیکربندی پیش‌فرض نصب MariaDB شما را ناامن می‌کند، از اسکریپتی استفاده می‌کنید که بسته mariadb-server برای محدود کردن دسترسی به سرور و حذف حساب‌های استفاده نشده ارائه می‌کند.</p>
## <p dir="rtl" align="right">گام دوم - پیکربندی MariaDB </p> ##
<p dir="rtl" align="right"> برای نصب های جدید MariaDB، گام بعدی اجرای اسکریپت امنیتی موجود است. این اسکریپت برخی از گزینه های پیش فرض کمتر امن را برای مواردی مانند ورود به سیستم ریشه از راه دور و کاربران نمونه تغییر می دهد.</p>
<br>
<p dir="rtl" align="right">اسکریپت امنیتی را اجرا کنید:</p>
```groovy
sudo mysql_secure_installation
```
<p dir="rtl" align="right">این شما را از طریق یک سری دستورات راهنمایی می کند که در آن می توانید برخی تغییرات را در گزینه های امنیتی نصب MariaDB خود ایجاد کنید. اولین اعلان از شما می خواهد که رمز عبور اصلی پایگاه داده فعلی را وارد کنید. از آنجایی که هنوز یکی را تنظیم نکرده‌اید، ENTER را فشار دهید تا «none» را نشان دهید.
</p>
<br>
<p dir="rtl" align="right" style="background-color: rgb(50, 50, 50); color:white">
خروجی:
<br>
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB<br>
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!<br>
<br>
In order to log into MariaDB to secure it, you'll need the current<br>
password for the root user. If you've just installed MariaDB, and<br>
you haven't set the root password yet, the password will be blank,<br>
so you should just press enter here.<br>
<br>
Enter current password for root (enter for none):<br>
</p>
<p dir="rtl" align="right">از شما پرسیده می شود که آیا می خواهید به احراز هویت سوکت یونیکس سوئیچ کنید. از آنجایی که از قبل یک حساب ریشه محافظت شده دارید، می توانید از این مرحله صرف نظر کنید. n را تایپ کرده و سپس ENTER را فشار دهید.</p>
<br>
<p dir="rtl" align="right" style="background-color: rgb(50, 50, 50); color:white">
خروجی:
<br>
. . .
Setting the root password or using the unix_socket ensures that nobody<br>
can log into the MariaDB root user without the proper authorisation.<br>
<br>
You already have your root account protected, so you can safely answer 'n'.<br>
<br>
Switch to unix_socket authentication [Y/n] n<br>
</p>
<p dir="rtl" align="right">
بعداً، در صورتی که احراز هویت سوکت برای مورد استفاده شما مناسب نباشد، نحوه راه‌اندازی یک حساب اداری اضافی برای دسترسی رمز عبور را بررسی خواهید کرد.
<br>
از آنجا، می‌توانید Y و سپس ENTER را فشار دهید تا پیش‌فرض‌ها را برای تمام سؤالات بعدی بپذیرید. با این کار برخی از کاربران ناشناس و پایگاه داده آزمایشی حذف می‌شوند، ورود به سیستم ریشه از راه دور غیرفعال می‌شود و این قوانین جدید بارگیری می‌شود تا MariaDB فوراً تغییراتی را که ایجاد کرده‌اید پیاده‌سازی کند.
<br>
با آن، پیکربندی امنیتی اولیه MariaDB را به پایان رساندید. مرحله بعدی یک مرحله اختیاری است، اگرچه اگر ترجیح می دهید با یک رمز عبور در سرور MariaDB خود احراز هویت شوید، باید آن را دنبال کنید.
</p>
## <p dir="rtl" align="right">گام سوم- (اختیاری) ایجاد یک کاربر اداری که از احراز هویت رمز عبور استفاده می کند</p>
<p dir="rtl" align="right">
در سیستم‌های اوبونتو که MariaDB 10.5 را اجرا می‌کنند، کاربر root MariaDB به‌طور پیش‌فرض و نه با رمز عبور، با استفاده از افزونه unix_socket احراز هویت می‌شود. این امر در بسیاری از موارد امنیت و قابلیت استفاده بیشتر را فراهم می‌کند، اما همچنین می‌تواند در مواردی که نیاز به اجازه دادن به یک برنامه خارجی (مثلاً phpMyAdmin) حقوق مدیریتی دارید، شرایط را پیچیده‌تر کند.
<br>
از آنجایی که سرور از حساب ریشه برای کارهایی مانند چرخش گزارش و راه‌اندازی و توقف سرور استفاده می‌کند، بهتر است جزئیات احراز هویت حساب ریشه را تغییر ندهید. تغییر اعتبار در فایل پیکربندی /etc/mysql/debian.cnf ممکن است در ابتدا کار کند، اما به‌روزرسانی‌های بسته به طور بالقوه می‌توانند این تغییرات را بازنویسی کنند. به جای تغییر حساب ریشه، نگهدارندگان بسته توصیه می کنند یک حساب اداری جداگانه برای دسترسی مبتنی بر رمز عبور ایجاد کنید.
<br>
برای این منظور، یک حساب کاربری جدید به نام admin با همان قابلیت‌های اکانت root ایجاد می‌کنیم، اما برای احراز هویت رمز عبور پیکربندی شده است. درخواست MariaDB را از ترمینال خود باز کنید:
</p>
```groovy
MariaDB [(none)]> sudo mariadb
```
<p dir="rtl" align="right">
سپس یک کاربر جدید با حقوق ریشه و دسترسی مبتنی بر رمز عبور ایجاد کنید. حتماً نام کاربری و رمز عبور را تغییر دهید تا با تنظیمات برگزیده شما مطابقت داشته باشد:
</p>
```groovy
MariaDB [(none)]> GRANT ALL ON *.* TO 'admin'@'localhost' IDENTIFIED BY 'password' WITH GRANT OPTION;
```
<p dir="rtl" align="right">
برای اطمینان از ذخیره و در دسترس بودن آنها در جلسه جاری، امتیازات را پاک کنید:
</p>
```groovy
MariaDB [(none)]> FLUSH PRIVILEGES;
```
<p dir="rtl" align="right">
پس از این، از پوسته MariaDB خارج شوید:
</p>
```groovy
MariaDB [(none)]> exit;
```
<p dir="rtl" align="right">
در نهایت، اجازه دهید نصب MariaDB را آزمایش کنیم.
</p>
مرحله 4 - آزمایش MariaDB
<p dir="rtl" align="right">
هنگامی که از مخازن پیش فرض نصب می شود، MariaDB به طور خودکار شروع به اجرا می کند. برای تست این، وضعیت آن را بررسی کنید.
</p>
```groovy
sudo systemctl status mariadb
```
<p dir="rtl" align="right">
خروجی مشابه زیر دریافت خواهید کرد:
</p>
<p style="background-color: rgb(50, 50, 50); color:white">
Output
● mariadb.service - MariaDB 10.5.12 database server<br>
Loaded: loaded (/lib/systemd/system/mariadb.service; enabled; vendor preset: enabled)<br>
Active: active (running) since Fri 2022-03-11 22:01:33 UTC; 14min ago<br>
Docs: man:mariadbd(8)<br>
https://mariadb.com/kb/en/library/systemd/<br>
. . .
</p>
<p dir="rtl" align="right">
اگر MariaDB اجرا نمی شود، می توانید آن را با دستور sudo systemctl start mariadb شروع کنید.
<br>
برای بررسی بیشتر، می‌توانید با استفاده از ابزار mysqladmin، که یک کلاینت است که به شما امکان اجرای دستورات مدیریتی را می‌دهد، به پایگاه داده متصل شوید. به عنوان مثال، این دستور می گوید که با استفاده از سوکت یونیکس به عنوان root به MariaDB متصل شوید و نسخه را برگردانید:
</p>
```groovy
sudo mysqladmin version
```
خروجی مشابه این را دریافت خواهید کرد:
<p style="background-color: rgb(50, 50, 50); color:white">
output
mysqladmin Ver 9.1 Distrib 10.5.12-MariaDB, for debian-linux-gnu on x86_64 <br>
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.<br>
<br>
Server version 10.5.12-MariaDB-1build1<br>
Protocol version 10<br>
Connection Localhost via UNIX socket<br>
UNIX socket /run/mysqld/mysqld.sock<br>
Uptime: 15 min 53 sec<br>
<br>
Threads: 1 Questions: 482 Slow queries: 0 Opens: 171 Open tables: 28 Queries per second avg: 0.505<br>
</p>
## <p dir="rtl" align="right">نتیجه </p> ##
<p dir="rtl" align="right">
در این راهنما شما سیستم مدیریت پایگاه داده رابطه‌ای MariaDB را نصب کردید و با استفاده از اسکریپت mysql_secure_installation که با آن نصب شده بود، آن را ایمن کردید. شما همچنین این گزینه را داشتید که یک کاربر اداری جدید ایجاد کنید که از احراز هویت رمز عبور قبل از آزمایش عملکرد سرور MariaDB استفاده می کند.<br>
<br>
اکنون که یک سرور MariaDB در حال اجرا و ایمن دارید، در اینجا چند نمونه از مراحل بعدی که می توانید برای کار با سرور بردارید، در اینجا مشاهده کنید:<br>
</p>
* Learn how to import and export databases
* Practice running SQL queries
* Incorporate MariaDB into a larger application stack
## <p dir="rtl" align="right">[منبع](https://www.digitalocean.com/community/tutorials/how-to-install-mariadb-on-ubuntu-22-04) </p> ##
<p dir="rtl" align="center"> صلوات </p>