محمد جوادی - SMJ
محمد جوادی - SMJ
خواندن ۷ دقیقه·۳ سال پیش

انسیبل چیست؟

با سلام خدمت شما همراهان گرامی.

بعد از سری ۹ قسمتی چطور با داکر کار کنیم ایندفعه به یکی دیگر از سری توانایی‌های یک مهندس دواپس می‌پردازیم.

تصور کنید که سرویس بسیار بزرگی متشکل از چندین ماشین مجازی در اختیار دارید و نیاز است در هر کدام از ماشین‌ها یک دستور اجرا کنید،‌ یک خط از یک فایل را تغییر دهید یا حتی یک فایل را بر روی هر کدام اجرا کنید و…

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

یکی از ابزارهایی که مهندسان دواپس برای فرار از این مشکل از آن استفاده می‌کنند انسیبل است.

انسیبل ساخته شده تا اتفاقاتی که نیاز داریم در چندين سرور یا ماشین مجازی به صورت دسته بندی و هدفمند برای رسیدن به یک مقصود داریم را از داخل یک سرور انجام دهد.


انسیبل چطور کار می‌کند؟

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

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


دستورات در انسیبل چطور وارد می‌شوند؟

در مفهوم انسیبل برای اجرا و انجام یک اتفاق از یک سری ابزار به اسم ماژول‌ها استفاده می‌کنیم.

مثلا در نظر داشته باشید در هنگام تعمیر ماشین خود به یک پیش بر می‌خورید؛ اصولا اولین کاری که می‌کنید آن است که ابزار مورد نظر برای انجام آن کار را برداشته و با آن ابزار فعالیت مورد نظر خود را انجام می‌دهید.

در انسیبل هم همین موضوع صادق است و برای هر کدام از فعالیت های مورد نیاز خودمان از یک ابزار استفاده می‌کنیم.

مثلا برای اجرای یک اسکریپت در داخل سرور های هدف از ماژول script و برای اجرای یک دستور در شل از ماژول shell استفاده می‌کنیم.

به طور کلی الگوی کلی وارد کردن دستور در انسیبل به شکل زیر می‌باشد:

ansible TARGET -i INVENTORY -m MODULE -a ‘ARGUMENTS’

در سطر بالا در قسمت TARGET قسمتی از اینونتوری و یا مخزن مورد انتخاب ما در انسیبل انتخاب می‌شود.

در قسمت INVENTORY فایل مخزن مورد نظر که دستور مورد نظر ما در آن اجرا می‌شود قرار خواهد گرفت.

در قسمت MODULE ماژول یا ابزار مورد نظر ما از انسیبل که قرار است از آن استفاده کنیم وارد می‌شود.

در قسمت ARGUMENTS آرگومانت ها یا اجزای اجرایی و دستورات نوع استفاده از ابزار مورد نظر خود را وارد می‌کنیم.


تنظیمات اولیه برای شروع کار با انسیبل چیست؟

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


اینونتوری یا مخزن در انسیبل چیست؟

اولین موضوعی که بعد از شروع به یادگیری از انسیبل به آن بر می‌خوریم مخزن انسیبل است.

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

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

ابتدا در مرحله اول نوع تعریف هاست و یک سری از قسمت‌های مورد نظر برای اتصال به هاست را مورد بررسی قرار می‌دهیم:

در ابتدایی‌ترین قسمت این فایل نام هاست مورد نظر را در ابتدای کار وارد می‌کنیم بدین صورت که مثلا هاست اول را با نام host-1 در ابتدای خط به روش زیر می‌نویسیم:

host-1

در قسمت بعدی آیپی و یا آدرس این هاست را با فاصله نسبت به این قسمت با الگور ansible_host=IP (IP نمایانگر آدرس آیپی سرور می‌باشد) وارد می‌کنیم، به صورت زیر:

host-1 ansible_host=10.0.0.5

در قسمت بعد می‌توانیم نوع ارتباط خودمان با هاست مورد نظر را تعیین کنیم مثلا در صورتی که سرور مقصد از سیستم عامل لینوکس استفاده می‌کند ارتباط ما با این سرور از طریق ssh و در صورتی که سرور مقصد از سیستم عامل ویندوز استفاده می‌کند از طریق راه ارتباطی winrm استفاده می‌کنیم. تعریف این قسمت به روش زیر می‌باشد:

host-1 ansible_host=10.0.0.5 ansible_connection=ssh

در قسمت بعد یوزر یا نام کاربری که انسیبل از آن استفاده می‌کند تا اتفاقات مورد نظر خود در سرور هاست انجام دهد را وارد می‌کنیم مثلا در مثال مطرح شده از کاربر root استفاده می‌کنیم و قسمت مورد نظری که باید در آن تعریف شود به نام ansible_user را به شرح زیر پر می‌نماییم:

host-1 ansible_host=10.0.0.5 ansible_connection=ssh ansible_user=root


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


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


به طور مثال فکر کنید چند هاست با الگوی زیر در یک فایل مخزن گزارش شده اند:

host-1 ansible_host=10.0.0.5 ansible_connection=ssh ansible_user=root
host-2 ansible_host=10.0.0.6 ansible_connection=ssh ansible_user=root
host-3 ansible_host=10.0.0.7 ansible_connection=ssh ansible_user=root
host-4 ansible_host=10.0.0.8 ansible_connection=ssh ansible_user=root

حال یک گروه از این هاست ها بر روی خود وب سرور داشته و گروه دیگری از این هاست ها بر روی خود دیتا بیس دارند و گروهی نیز اپلیکیشن را بر عهده دارند.

مثلا سرور دیتابیس در هاست ۱ و ۳ قرار داشته و سرور اپلیکیشن در هاست ۲ و سرور وب سرور در هاست ۴ قرار داشته باشد.

در حالت زیر می‌توانیم یگ گروه از هاست های بالا را تعریف کنیم که هر دو دیتا بیس باشند.

به صورت زیر می‌توان یک گروه در مخزن انسیبل ایجاد کرد:

[database]
host1
host3


و فایل کلی اینونطوری ما با توجه به توضیح بالا می‌تواند به حالت زیر ساخته شود:


host-1 ansible_host=10.0.0.5 ansible_connection=ssh ansible_user=root
host-2 ansible_host=10.0.0.6 ansible_connection=ssh ansible_user=root
host-3 ansible_host=10.0.0.7 ansible_connection=ssh ansible_user=root
host-4 ansible_host=10.0.0.8 ansible_connection=ssh ansible_user=root
[database]
host1
host3
[webserver]
host4
[app]
host2


(در نظر داشته باشید که گروه ها می‌توانند تنها یک عضو داشته باشند و این موضوع هیچ اشکالی ندارد حتی اگر برای تغییر نام یک هاست باشد.)


نوع دیگر از گروه ها آن است که گروهی ساخته شود و زیر شاخه هایش گروه های دیگری باشند.

در این صورت برای تعریف این گروه ها از عبارتی همچون عبارت زیر استفاده می‌کنیم:

[GROUP:children]

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

به طور مثال برای این که گروهی به اسم all متشکل از تمامی هاست های مثال قبل را داشته باشیم بدین صورت این گروه را معرفی می‌کنیم:

[all:children]
database
webserver
app


در نتیجه فایل نهایی مخزن ما به صورت زیر خواهد بود:


host-1 ansible_host=10.0.0.5 ansible_connection=ssh ansible_user=root
host-2 ansible_host=10.0.0.6 ansible_connection=ssh ansible_user=root
host-3 ansible_host=10.0.0.7 ansible_connection=ssh ansible_user=root
host-4 ansible_host=10.0.0.8 ansible_connection=ssh ansible_user=root
[database]
host1
host3
[webserver]
host4
[app]
host2
[all:children]
database
webserver
app


این بود از اولین سری از قسمت‌های سریالی آموزش کاربردی انسیبل که قصد داریم به صورت هفتگی این سری را با همدیگر جلو ببریم.

امیدوارم توضیحات من برای شما در یادگیری انسیبل کاربردی باشد.

در صورتی که انتقاد یا پیشنهادی درباره این مقاله دارید می‌توانید با بنده در میان گذاشته تا سوالات شما حل شده یا در مقالات بعدی تصحیح شود.

با تشکر از تیم ابرآراز که فرصت ارائه این مقاله را در اختیار من گذاشت.

تا هفته بعد...


ansiblelinuxانسیبل
شاید از این پست‌ها خوشتان بیاید