نقشه نرمافزار (Software map) و محیط توسعه نرمافزار چه مفاهیمی هستند؟
یکی از مهمترین موضوعاتی که مهندسان نرمافزار و به ویژه برنامهنویسان باید با آن آشنا باشند و متاسفانه در دانشگاه به درستی به آن پرداخته نمیشود مفهوم نقشه نرمافزار و محیط توسعه نرمافزار است.
برنامهنویسانی کمی را پیدا میکنید که در ارتباط با نقشه نرمافزار اطلاعات کافی داشته باشند یا پروژههای خود را بر مبنای نقشه نرمافزار آماده کنند. در این مطلب قصد داریم به شکل کوتاه توضیحی در ارتباط با این مفهوم ارائه کنیم.
نقشه نرمافزار چیست؟
نقشههای نرمافزاری بر پایه اطلاعات عینی هستند و بر پایه تجزیه و تحلیل کد و اطلاعات وارد شده از سیستمهای مخزن نرمافزار، اطلاعات از کدهای منبع یا ابزارهای توسعه نرمافزار و ابزارهای برنامهنویسی تعیین میشوند.
بهطور خاص، نقشههای نرمافزاری به یک زبان برنامهنویسی، زبان مدلسازی یا مدل فرایند توسعه نرمافزار بستگی ندارد. نقشه نرمافزاری (Software mapبه اطلاعات ایستا، پویا و تکاملی اشاره دارد که در ارتباط با سامانههای نرمافزاری و فرایندهای توسعه نرمافزار آماده میشوند و به صورت دوبعدی یا سهبعدی اطلاعاتی در اختیار تیم توسعه یا مهندس کیفیت میدهند.
کاربردهای اصلی نقشه نرمافزار در ارتباط با تحلیل مخاطره و نظارت بر کیفیت کد، فعالیت تیم، پیشرفت توسعه نرمافزار، بهبود اثربخشی مهندسی نرمافزار و نگهداری از نرمافزار است.
نقشههای نرمافزاری میتوانند اطلاعات مربوط به توسعه نرمافزار، کیفیت نرمافزار و دینامیک سیستم را با نقشهبرداری از این که اطلاعات بر روی متغیرهای تصویری عناصر نقشه درخت مانند اندازه مساحت، ارتفاع، رنگ یا بافت را ترکیب کنند.
آنها میتوانند به صورت منظم مشخص شوند، بهطور خودکار تولید شوند و توسط الگوها سازماندهی شوند. نقشههای نرمافزاری از تکنیکهای نقشه نگاری دقیقی که به خوبی تعریف شدهاند استفاده میکنند و از استعاره مدل شهر سهبعدی استفاده میکنند تا فضای اطلاعاتی پیچیده و انتزاعی را بیان کنند.
برنامهها
نقشههای نرمافزاری بهطور کلی امکان ارتباطات قابل فهم و مؤثر در زمینههای خطرات و هزینههای پروژههای توسعه نرمافزار را به سهامداران مختلف مانند تیم مدیریت و توسعه میدهد. آنها وضعیت برنامههای کاربردی و سیستمهایی را که در حال حاضر در حال توسعه یا توسعه بیشتر هستند را برای رهبران پروژه و مدیریت در یک نگاه برقرار میکنند.
یک جنبه کلیدی برای این تصمیمگیری، این است که نقشههای نرمافزاری، زمینه ساختاری مورد نیاز برای تفسیر صحیح این شاخصهای عملکرد را فراهم میکند».
به عنوان یک وسیله ارتباطی، نقشههای نرمافزاری به عنوان فضاهای باز و شفاف اطلاعات عمل میکنند که اولویتهای کیفیت کد و ایجاد توابع جدید را قادر میسازد که در برابر یکدیگر تعامل میسازد و برای بهبود فرایند توسعه نرمافزار اقدامهای لازم را انجام دهند.
زمانی که فرآیند ساخت پروژههای نرمافزار به طول میانجامد پیچیدگیها و مشکلات زیادی پدید میآید که در بلندمدت فرسودگی تیم توسعه را به همراه دارد. از طرفی ممکن است برخی ویژگیهای سیستم نادیده گرفته شوند و در نهایت کیفیت کدهایی که نوشته میشوند کم شود.
با توجه به اینکه نگهداری از نرمافزارها پیچیده و هزینهبر است سازندگان بخش مهمی از زمان خود را صرف درک ساختار و رفتار سیستم میکنند. ایده کلیدی نقشههای نرمافزاری، مقابله با این مشکلات بهینهسازی با فراهم آوردن وسیلههای ارتباطی تأثیرگذار برای بستن شکافهای موجود است.
نقشههای نرمافزاری را میتوان بهطور خاص به عنوان ابزار تحلیلی و معرفی سیستمهای اطلاعاتی کسبوکار، متخصص در تجزیه و تحلیل دادههای مربوط به نرمافزار استفاده کرد.
علاوه بر این، نقشههای نرمافزاری به عنوان سیستمهای توصیه برای مهندسی نرمافزار عمل میکنند. نقشههای نرمافزاری به اطلاعات مربوط به نرمافزار محدود نمیشوند و میتوانند شامل هر گونه اطلاعات سلسله مراتبی سیستم همانند اطلاعات نگهداری از مصنوعات فنی پیچیده باشند.
نقشههای نرمافزاری از سلسله مراتب مفاهیم اجرای پیادهسازی نرمافزار مانند فایلهای کد منبع برای ساخت یک نقشه درخت استفاده میکنند.
ارتفاع یک ساختمان مجازی میتواند متناسب با پیچیدگی واحد کد (به عنوان مثال، ترکیبی از معیارهای نرمافزاری) باشد. مساحت زمین یک ساختمان سهبعدی مجازی میتواند متناسب با تعداد خطوط کد در ماژول باشد.رنگ میتواند وضعیت توسعه فعلی را بیان کند، به عنوان مثال، چند توسعهدهنده در حال تغییر / ویرایش واحد کد هستند.
با این پیکربندی نمونه، نقشه نرمافزار نقاط مهمی را در کد منبع با رابطه با جنبههای فرایند توسعه نرمافزار را نشان میدهد. برای مثال در یک نگاه مشخص میشود که باید اصطلاحاتی نظیر پیادهسازی تغییرات در کوتاهترین زمان، ارزیابی سریع تأثیر تغییرات در یک مکان روی عملکرد بخشهای دیگر نرمافزار، کاهش پیچیدگیها که منجر به فرایندهای کنترل نشده در کاربرد هستند، پیدا کردن سریعتر خطاها، ویرایش پارادیمی که برای توسعه استفاده شده و… انجام شود.
الگوریتمهای طرحبندی
برای ساخت نقشههای نرمافزاری از روشهای چیدمان متفاوت برای تهیه نقشه فضایی اساسی و مولفههای استفاده میشوند. بهطور مثال، میتوان از الگوریتمهای نقشه درخت که در ابتدا سلسله مراتب نرمافزار را در یک ناحیه مستطیلی تودرتو اجرا میکنند یا الگوریتمهای (Voronoi-map)که ابتدا سلسله مراتب نرمافزار را با ایجاد یک نقشه Voronoi طراحی میکنند استفاده کرد.
در مقایسه با الگوریتمهای منظم (treemap treemap)، که چیدمان قطعی را فراهم نمیکنند، الگوریتم چیدمان برای(Voronoi treemaps) میتواند تا درجه بالایی از شباهت چیدمان برای سلسلهمراتب مختلف را فراهم کند. رویکردهای مشابهی برای مورد مبتنی بر نمودار درختی وجود دارد.
توابع نقشههای نرمافزاری و روشهای نقشههای نرمافزاری به تجسم علمی تجسم نرمافزاری و تصویرسازی اطلاعات تعلق دارند. آنها یک مفهوم و تکنیک کلیدی در زمینه تشخیص نرمافزار تشکیل میدهند. آنها همچنین در تجزیه و تحلیل نرمافزار کاربرد دارند. نقشههای نرمافزاری به صورت وسیعی توسعهیافته و مورد تحقیق قرار گرفتهاند، به عنوان مثال، در موسسه(Hasso Plattner) برای مهندسی سیستمهای فناوری اطلاعات، به ویژه برای سیستمهای پیچیده فناوری اطلاعات استفاده شدند.
محیط استقرار نرمافزار چیست؟
در توسعه نرمافزار، محیط یک سیستم کامپیوتری است که نرمافزار یا یک مولفه نرمافزاری روی آن استقرار یافته و اجرا شده است.
در حالات ساده، به عنوان مثال توسعه دادن یک برنامه و اجرای بلافاصله آن روی همان سیستم ممکن است تنها به یک محیط نیاز داشته باشد، اما در حالات صنعتی و تجاری بهطور معمول یک محیط با عنوان توسعه (Development) برای تغییرات اصلی و توسعه در نظر گرفته میشود و از طرف دیگر محیطی با عنوان محصول نهایی (Production) برای کاربر نهایی استفاده میشود.
این فرایند ساختار مدیریت انتشار نرمافزار در خیلی از مشکلات به فازهای استقرار (Deployment)، آزمایش (Testing) و عقبگرد (Rollback) کمک میکند.
محیطها ممکن است به طور قابل توجهی با یکدیگر تفاوت داشته باشند: به طور معمول محیط توسعه یک فضای کاری تنها برای توسعه دادن نرمافزار است در حالی که در محیط محصول نهایی احتمالاً شاهد متصل بودن یک شبکه عظیم از ماشینهای توزیع شده مرکز داده یا ماشین مجازیهای راینش ابری باشید.
معماریها
محیطهای استقرار تفاوتهای قابل توجهی با یکدیگر دارند، اما بهطور کلی نقطه شروع آنها از محیط توسعه (DEV) بوده و به محیط محصول نهایی (PROD) ختم میشود.
یکی از معماریهای استقرار که بهطور متداول استفاده میشود عبارت است از توسعه، آزمایش، نمایش، محصول نهایی (DEV, TEST, STAGING, PROD) که با ترتیب ذکر شده نرمافزار روی محیطها استقرار مییابد. علاوه بر این محیطهای استقرار دیگری نیز وجود دارند که بهطور کلی برای فرایند تولید نرمافزار در نظر گرفته نمیشوند از جمله تضمین کیفیت (Quality Assurance) که در اختیار نیروهای آزمایش قرار میگیرند، جعبه شنی (Sandbox) که برای آزمایش کردن محصول توسط خود توسعهدهندگان استفاده میشود.
در مواقع اضطراری محیطی با عنوان بازیابی فاجعه (Disaster Recovery) در نظر گرفته میشود که در حالتی که برای نسخه نهایی مشکلی پیش آید از این محیط استفاده میشود.
یکی دیگر از معماریها عبارت است از توسعه، آزمایش، تست پذیرش (Acceptance testing) و محصول نهایی که به اختصار DTAP گفته میشود. استقرار نرمافزاربه تمامی فعالیتهایی که یک نرمافزار را برای استفاده آماده میکند گفته میشود تا در نهایت نرمافزار راهاندازی شود.
فرایند استقرار عمومی شامل چند فعالیت مرتبط به یکدیگر و تغییرات احتمالی بین آنها میباشد. این فعالیتها میتوانند از طرف توسعهدهنده نرمافزار، از طرف کاربر یا از طرف هر دوی آنها صورت پذیرند. از آنجا که هر سیستم نرمافزاری منحصر به فرد است، فرایندهای دقیق یا الگوریتمهای درونی هر فعالیت به سختی میتوانند تعریف شوند؛ بنابراین «استقرار» باید به عنوان یک فرایند کلی تفسیر شود که باید مطابق با الزامات خاص یا مشخصات آن سفارشی شود.
در استقرارهای نرمافزاری قبل از اینترنت، استقرارها (و عملیات مربوط نزدیک به آن) از امور ضروری پر هزینه، نادر و حجیم بودند. بنابر این قابل بحث است که با گسترش اینترنت، پایان دادن به توسعه سریع نرمافزار امکانپذیر میشود.
در واقع ظهور محاسبات ابری و نرمافزاری به عنوان یک سرویس به این معنی است که نرمافزارها میتوانند در بستر اینترنت به تعداد زیادی از کاربران در عرض چند دقیقه عرضه شوند. این همچنین به این معنا است که بهطور معمول، برنامهریزیهای استقرار در حال حاضر توسط تأمینکننده نرمافزار تعیین میشود و نه توسط کاربران.
چنین انعطافپذیری منجر به افزایش تحویل پیوسته به عنوان یک گزینه در دسترس بهطور ویژه برای برنامههای کاربری تحت وب با خطر ریسک کم میباشد.
فعالیتهای استقرار
انتشار بر پایه فرایند توسعه نرمافزار تکمیل شدهاست وگاهی اوقات به عنوان بخشی از فرایند توسعه به جای فرایند استقرار طبقهبندی میشود؛ و شامل عملیات آمادهسازی برای مونتاژ و انتقال به سیسنمهای کامپیوتری میباشد.
نصب و فعال سازی
در سیستمهای ساده، نصب شامل ایجاد نوع فرمان (رایانش)، میانبر، اسکریپت یا سرویس برای اجرای نرمافزار (به صورت دستی یا خودکار) میباشد. در سیستمهای پیچیدهتر ممکن است نصب شامل پیکربندی سیستم (احتمالاً با سؤال نهایی از کاربران درباره استفاده مورد نظر آنها یا بهطور مستقیم درباره پیکربندی سیستم از آنها سؤال شود) و ساخت زیر سیستمهای مورد نیاز برای استفاده باشد.
غیرفعال سازی
غیرفعال سازی عملکردی برعکس فعالسازی دارد و اشاره به خاموش کردن هر جزء در حال اجرای سیستم را دارد.
حذف نصب
حذف نصب عملکردی خلاف نصب دارد و اشاره به حذف سیستم یا نرمافزاری دارد که دیگر لازم نیست.
بهروز رسانی
فرایند به روزرسانی، تمام یا قسمتی از آخرین نسخه منتشر شده یک نرمافزار سیستم را جایگزین آن میکند. این فرایند معمولاً شامل غیرفعال سازی و نصب مجدد میباشد. در سیستمهایی مانند لینوکس، با استفاده مدیریت بسته سیستم نسخههای قدیمی نرمافزار بهطور خودکار به عنوان بخشی از این فرایند حذف میشوند.
بهروز رسانی خودکار
مکانیسمهایی برای نصب به روز رسانی در برخی سیستمها (یا در برخی سیستم عاملها مانند لینوکس، اندروید و iOS)ساخته شدهاست. مکانیسمهایی از این قرآیندهای به روز رسانی کاملاً خودکار به کاربران ارائه شدهاست.Norton Internet Security نمونه ای از یک سیستم نیمه اتوماتیک برای بازیابی و نصب بروز رسانیها میباشد.
قوانین استقرار
پیچیدگی و تنوع محصولات نرمافزاری باعث افزایش نقش تخصصی قوانین برای هماهنگی و مهندسی فرایند استقرار میشود. در نرمافزارهای دستکتاپ کاربران نهایی نیز هنگامی که یک بسته نرمافزاری را روی دستگاه خود نصب میکنند، به یک توسعه دهنده نرمافزار تبدیل میشوند.