660 likes | 957 Views
معماري سرويس گرا و سيستم هاي مديريت فرايند كسب و كار Service Oriented Architecture and Business Process Management Systems. حسين مرادي hsmoradi@gmail.com IT Expert.ir اولین همایش فناوری اطلاعات بیرجند آذر 85. سازمان هاي نوين . اهداف راهبردي سازمان هاي نوين افزايش اثربخشي و كارايي سازمان
E N D
معماري سرويس گرا و سيستم هاي مديريت فرايند كسب و كارService Oriented Architecture andBusiness Process Management Systems حسين مرادي hsmoradi@gmail.com IT Expert.ir اولین همایش فناوری اطلاعات بیرجند آذر 85
سازمان هاي نوين • اهداف راهبردي سازمان هاي نوين • افزايش اثربخشي و كارايي سازمان • كسب جايگاه مناسب در بين رقبا • بالا رفتن رضايت مشتريان • راه حل چيست؟ • استفاده از سيستم هاي مديريتي مناسب جهت هدايت سازمان • استفاده از فناوري هاي مناسب براي فرموله كردن سيستم هاي مديريتي
IT به عنوان توانمندساز • براي رسيدن به اهداف راهبردي سازماني و بهبود سازمان بايد از ابزارهاي توانمندساز مناسب استفاده شود. • يكي از مهمترين ابزارهاي توانمند ساز، IT مي باشد. • اما سوال اين است كه بايد از كدام فناوري ها استفاده شود.؟ • شايد جواب دهيد از جديدترين ها !!؟
ارتباط بهرهوري با IT • آيا لزوماً سرمايهگذاري در IT منجر به افزايش بهرهوري ميشود؟ • آيا لزوماً سرمايهگذاري در IT منجر به تقويت مزيت رقابتي ميشود؟ • نه! • چرا؟ • عامل كليدي تقويت مزيت رقابتي با استفاده از IT، سرمايهگذاري بيشتر در آن نيست، بلكه بكارگيري و استفاده مؤثر از آن در ارتباط با عملكرد سازمان است. 4
فراز و نشيب انتظارات از فناوري هاي مختلف Do not join in just because it is "in" Positive Hype NegativeHype Do not miss out just because it is "out" Peak of InflatedExpectations TechnologyTrigger Trough ofDisillusionment Slope ofEnlightenment Plateau ofProductivity Maturity
راه حل چيست؟ معماري سازماني • طراحي مناسب معماري سازماني به صورتي • هدفمند، منسجم، يكپارچه و انعطاف پذير فرايند معماري سازماني گذر از وضع موجود به وضع مطلوب تحليل شكاف شناسايي وضع مطلوب تحليل وضع موجود
معماري سازماني چيست؟ • با استفاده از اين معماري، مشخص مي شود كه • چه اطلاعاتي (What) • بر اساس چه فرايندي (How) • درهنگام وقوع چه رخدادي (When) • در چه مكاني (Where) • به چه افرادي (Who) • و با چه هدفي (Why) • داده شود تا سازمان به اهداف راهبردي تعيين شده در طرح كلان IT خود نائل شود.
مانيتورينگ مدلسازي و اجرا بهبود سيستم هاي IT< توانمندساز معماري سازماني • فرايندهاي كسب و كار • اطلاعات • افراد سه جنبه اصلي معماري سازماني از نظر معماران نرم افزار انتظارات مديران ارشد از سيستم هاي نرم افزاري
فرايندهاي كسب و كار سازماني از بالاترين نما Vendors, Suppliers Organization Customers Distribution Logistics, Services Purchasing Finance R & D Production Sales Distribution Product development Order fulfillment Planning, resourcing, and control Customer service فرايندهاي كسب و كار، معمولا واحدهاي وظيفه اي سازمان و يا مرزهاي سازماني را قطع مي كنند و در كنار يكديگر براي مشتري يا بازار ارزش ايجاد مي كنند.
فرايند برآورد سفارش مشتري با جزئيات بيشتر • مولفه هاي فرايند كسب و كار • ورودي (درخواست كاركنان، همكاران تجاري، بازار، مشتريان و ...) • خروجي (اطلاعات، ارائه خدمات يا محصولات و ...) • فرايند (مجموعه اي از فعاليت هاي كسب و كار است كه در كنار يكديگر براي مشتري يا بازار ارزش ايجاد مي كند) input output
وظيفه فرايند: ايجاد هماهنگي • وظيفه فرايندهاي كسب و كار، ايجاد هماهنگي بين افراد و واحدهاي وظيفه اي سازمان در گردش اطلاعات، تعهدات سازماني، اسناد و منابع فيزيكيمي باشد. • هدف مديريت گردش اطلاعات • رساندن اطلاعات مناسب به افراد مناسب و در زمان مناسب • هدف مديريت گردش تعهدات سازماني • هماهنگي واحدهاي سازماني و افراد آن با يكديگر • هدف مديريت گردش اسناد و منابع فيزيكي سازمان • بهره برداري حداكثري از منابع سازمان در جهت نيل به اهداف آن
دسته بندي فرايندهاي كسب و كار • فرايندهاي بين سازماني • فرايندهايي كه سازمان هاي مختلف را هماهنگ مي كند • فرايندهاي درون سازماني در بالاترين سطح • فرايندهايي كه واحدهاي وظيفه اي سازمان را هماهنگ مي كند • فرايندهاي درون سازماني در پايين ترين سطح • فرايندهايي كه افراد مختلف يك دپارتمان و سيستم هاي IT آن را هماهنگ مي كند
فرايند مديريت زنجيره تامين كه چندين سازمان را هماهنگ مي كند
فرايندهاي درون سازماني كه واحدهاي وظيفه اي سازمان را قطع مي كند
سوال:آيا با كمك معماري هاي سنتي مانند شي گرايي يا توسعه مبتني بر مولفه مي توان سيستم هاي فوق را به صورت كامل طراحي و اجرا كرد؟ علت چيست؟ چون محور اصلي مدلسازي در تحليل شي گرا يا توسعه مبتني بر مولفه، منابع سازماني (منابع اطلاعاتي، فيزيكي و انساني) بوده و فرايندهاي كسب و كار در مرحله بعدي قرار دارد. جواب:خير !؟
ساير مشكلات استفاده از معماري هاي سنتي براي سيستم هاي سازماني نوين غير استاندارد بودن فرايندهاي كسب و كار عدم يكپارچه سازي آسان با ساير سيستم ها عدم انعطاف پذيري در برابر تغييرات عدم توسعه پذيري
يك سيستم نوين با محوريت فرايند كسب و كار يك سيستم سنتي با محوريت منابع سازماني
راه حل پيشنهادي ما استفاده از سيستم هاي مديريت فرايند كسب و كار بر مبناي معماري سرويس گرا
تكامل استفاده مجدد در نرم افزار با توسعه معماري هاي جديد، عنصر اصلي تشكيل دهنده معماري تكامل مي يابد
عناصر اصلي هر برنامه • دو عنصر اصلي هر برنامه (Program) • الگوريتم • ساختار داده اي در رويكردهاي مختلف توسعه نرم افزار، جاي اين عناصر با هم عوض مي شود
روند ظهور رويكردهاي توسعه محصولات نرم افزاري Service-Oriented-Architecture Early service Orientation Component Based Development Distributed Object Technologies Object Oriented Programming Functional Programming
برنامه نويسي ساخت يافته (فراخواني رويه ها) 1- الگوريتم (رويه ها يا توابع) 2- ساختار داده اي (داده ها)
برنامه نويسي شي گرا (اشيا و پيغام ها) 1- ساختار داده اي (اشيا) 2-الگوريتم (متدها و پيغام ها)
برنامه نويسي سرويس گرا (سرويس و پياده سازي آن) 1- الگوريتم (سرويس) 2-ساختار داده اي(پياده سازي آن)
فلسفه سرويس گرايي، نرم افزار به صورت سرويس مصرف سرويس از طريق هر دستگاه، پلتفرم، سيستم عامل و زبان برنامه نويسي ارائه سرويس به صورت Plug and Play ارسال و دريافت پيغام در قالب استاندارد
Service interface Service Implementation سرويس چيست؟ • چند نمونه سرويس • سرويس محاسبه ماليات • سرويس برآورد سفارش مشتري • عناصر تشكيل دهنده يك سرويس • رابط سرويس (Service interface) • تعريف هويت يك سرويس و نحوه فراخواني آن • پياده سازي سرويس (Service implementation) • واقعيت بخشيدن به سرويس • طراحي و دستكاري اين دو عنصر به صورت مستقل
Service Broker Service requests توپولوژي معماري سرويس گرا • دلال سرويس (رجيستري) • يك جزء اختياري • سرويس دهنده • انتشار مشخصات و آدرس سرويس بر روي دلال • مصرف كننده سرويس • دريافت مشخصات و آدرس سرويس از دلال
Service Interface سناريوي مصرف سرويس Fn() Service Consumer Fn() Service Implementation Service Provider ServiceLogic Data
سناريوي مصرف يك سرويس با كمك يك رجييستري
مشخصه هاي معماري سرويس گرا • تقسيم عملكرد سيستم به سرويس هاي مجزا • پيوند ضعيف بين سرويس ها (loosely coupling) • خودمختار بودن (autonomous) سرويس ها • استقلال سرويس ها از پروتكل و پلتفرم • استاندارد بودن سرويس ها
دسته بندي سرويس ها • سرويس هاي درون سازماني • سرويس هاي تمام خودكار (دريافت سرويس از ماشين) • سرويس هاي نيمه خودكار (دريافت سرويس از انسان با كمك ماشين) • سرويس هاي برون سازماني • سرويس هاي دريافتي از همكاران تجاري • سرويس هاي دريافتي از ارائه دهندگان سرويس هاي نرم افزاري
Coordination oriented Build to change Incrementally built and deployed گذر از برنامه كاربردي محوري به سرويس گرايي From To • Function oriented • Build to last • Prolonged development cycles Enterprise solutions Loosely coupled Message oriented Abstraction Application silos Tightly coupled Object oriented Known implementation Source: Microsoft (Modified)
مراحل بلوغ SOA Maturity of SOA Process-DrivenSOA Agility and Flexibility Multi-LevelSOA SimpleSOA Complexity
Online Ordering Application Warehouse Application Inventory Management Customer Management Order Management Simple SOA Presentation Layer Basic ServiceLayer
Multi-Level SOA Online Ordering Application PresentationLayer IntermediateService Layer Order and Ship Basic Service Layer InventoryManagement Customer Management Order Management
OrderCancellationService Process-Driven SOA Online Ordering Application PresentationLayer Business ProcessService Layer CatalogService IntermediateService Layer Order and Ship Basic Service Layer InventoryManagement Customer Management Order Management
تكامل معماري برنامه كاربردي • گام بعدي مديريت فرايند است
مسير حركت به سمت سيستم هاي BPM مشابه مسير حركت به طرف DBMS است
سيستم هاي مديريت فرايندهاي كسب و كار • ايده اصلی، كنار هم آوردن • فرآيندهاي كسب و كار • اطلاعات • افراد • سيستم مديريت فرآيند کار • خودکار سازی فرآيندهای افقی • با توجه به امكانات طراحي، استقرار، اجرا، تعامل، گزارش گيري و بهبود فرايندها • مديريت پذيری عمودی (با توجه با استفاده از SOA)