RAČUNALNIŠTVO V OBLAKU
Transcription
RAČUNALNIŠTVO V OBLAKU
Uvod v računalništvo v oblaku RAČUNALNIŠTVO V OBLAKU Univerza v Ljubljani, FRI Center za računalništvo v oblaku www.cloud.si Robert Dukarić, Rok Povše, Matjaž B. Jurič Vsebina Definicija Storitveni modeli računalništva v oblaku Ključne karakteristike SWOT analiza Upravljanje oblaka Načrtovanje kapacitet in elastičnost v oblaku Arhitekturna zasnova računalništva v oblaku Infrastruktura kot storitev (IaaS) Analiza IaaS produktov Platforma kot storitev (PaaS) Java EE 7 in oblak Podatkovna shramba v oblaku Analiza PaaS produktov Programska opreme kot storitev (SaaS) Namestitveni modeli Uporaba javnih oblakov Migracija v oblak Prenosljivost oblačnih storitev med ponudniki Izhodna strategija 2 1 Uvod v računalništvo v oblaku Definicija Računalništvo, pri katerem so dinamično razširljiva in pogosto virtualizirana računalniška sredstva na voljo kot storitev preko interneta. Wikipedia Slog računalništva, kjer so masivno skalabilne IT zmogljivosti dostavljene zunanjim odjemalcem kot storitev, z uporabo internetnih tehnologij. Gartner Nabor disciplin, tehnologij in poslovnih modelov za prikaz IT virov kot storitev na zahtevo. Burton 3 Definicija Množico skalabilnih računalniških virov za gostovanje, ki omogočajo zaračunavanje glede na dejansko porabo. Forrester Model za omogočanje omrežnega dostopa do deljenih računalniških virov (omrežje, strežniki, shramba, aplikacije in storitve), ki so lahko rapidno oskrbovane in izdane z minimalnim trudom vodstva oziroma z interakcijo ponudnika storitve. NIST Gre za aplikacije, strojno opremo in sistemsko programsko znotraj podatkovnih centrov, ki so dostavljene kot storitev preko medmrežja. UC Barkley 4 2 Uvod v računalništvo v oblaku Definicija 5 Definicija PaaS Elastičnost SaaS IaaS Samopostrežba Javni Avtomatizacija Privatni Tipi … Karakteristike Hibridni Namestitveni modeli Znižanje stroškov Večja agilnost Lokalno Prednosti Računalništvo v oblaku Lokalnost … Oddaljeno Distribuirano Sorodne tehnologije Deležniki Storitveno usmerjena arhitektura (SOA) Mrežno računalništvo Organizacije Ponudniki Odjemalci Virtualizacija … 6 3 Razvijalci Uvod v računalništvo v oblaku Tipi računalništva v oblaku SaaS • Software as a Service Odjemalci PaaS • Platform as a Service Razvijalci IaaS • Infrastructure as a Service Administrator 7 Ključne karakteristike Ključne karakteristike računalništva v oblaku lahko obravnavamo iz treh aspektov: • Nefunkcionalni aspekt: – Obravnava lastnosti sistema raje kot specifične tehnološke zahteve. Med ponudniki se zelo razlikujejo. • Poslovni aspekt: – Ključen razlog za vpeljavo računalništva v oblaku v poslovne organizacije. • Tehnični aspekt: – Gre za realizacijo nefunkcionalnega in poslovnega aspekta. Nefunkcionalni aspekt: • Elastičnost • Zanesljivost • Kvaliteta storitev (QoS) • Agilnost in prilagodljivost • Razpoložljivost • Dostopnost 8 4 Uvod v računalništvo v oblaku Ključne karakteristike Poslovni aspekt: • • • • • • Znižanje stroškov Pay-as-you-go model Izboljšan čas na trg (Time to market) Donosnost naložbe (ROI) Pretvorba CAPEX v OPEX Green IT 9 Ključne karakteristike Tehnični aspekt: • • • • • • • • • Virtualizacija Večnajemniški model Varnost, zasebnost in skladnost s predpisi Samopostrežba Avtomatizacija Upravljanje s podatki API-ji in programska podpora Merjenje Orodja za razvoj, upravljanje in nadzor 10 5 Uvod v računalništvo v oblaku SWOT analiza Prednosti (Strengths): • • • • • • Znanje in izkušnje iz sorodnih področij in tehnologij. Izkušnje pri razvoju aplikacij za potrebe gospodarstva. Številne raziskave in izgradnja odprtokodnih tehnologij. Močna skupnost iz področja raziskav SOA in distribuiranih sistemov. Velika sinergija med raziskavami in industrijo. Oskrbovanje kompleksnih procesov kot storitev namesto oskrbovanja nizko-nivojske infrastrukture. • Močna industrija telekomunikacij. • Številne uspešne zgodbe in primeri uporabe po svetu. 11 SWOT analiza Slabosti (Weaknesses): • • • • • • • Pomanjkanje infrastrukture (podatkovnih centor) v Evropi. Majhen poudarek na razvoju novih Cloud tehnologij v Evropi. Večina ponudnikov računalništva v oblaku je v ZDA. Ni prisotne platforme, ki bi omogočila izbiro različnih ponudnikov. Pomanjkanje standardov in interoperabilnosti. Izguba fizičnega nadzora nad lastnimi podatki. Zaklepanje znotraj ponudnika. 12 6 Uvod v računalništvo v oblaku SWOT analiza Priložnosti (Opportunities): • Veliko izkušenj in vključevanja v standardizacijo oblaka. • Potreba po novih podatkovnih centrih po svetu. • Povečan interes po računalništvu v oblaku s strani industrije in akademske sfere. • Oblak predstavlja močan temelj za razvoj mobilnih in tabličnih aplikacij. • Povečana konkurenčnost in produktivnost ponudnikov storitev pri adapciji privatnih, hibridnih in javnih oblakov. • Podpora MSP-jev in „start-up“ podjetjem z izboljšanim ROI-jem. • Novi poslovni modeli za produkte in uporabnike oblaka. • Težnja po premiku iz mrežnega računalništva v računalništvo v oblaku. 13 SWOT analiza Grožnje (Threats): • Za izgradnjo infrastrukture za računalništvo v oblaku so potrebne velike investicije. • Velika odvisnost od zunanjih (neevropskih) ponudnikov. • Latenca je zaradi zagotavljanja federacije oblakov lahko velika. • Zaupanje podatkov in aplikacij tretji organizaciji. • Zagotovitev kontinuitete poslovanje v primeru bankrota ponudnika. • Regulativa na lokalni, nacionalni in internacionalni ravni (US Patriot Act, EU Privacy Law, …). 14 7 Uvod v računalništvo v oblaku Upravljanje oblaka Lokalno IaaS PaaS SaaS Aplikacije Aplikacije Aplikacije Aplikacije Podatki Podatki Podatki Podatki Izvajalno okolje Izvajalno okolje Izvajalno okolje Izvajalno okolje Vmesna programska oprema Vmesna programska oprema Vmesna programska oprema Vmesna programska oprema Operacijski sistem Operacijski sistem Operacijski sistem Operacijski sistem Virtualizacija Virtualizacija Virtualizacija Virtualizacija Strežniki Strežniki Strežniki Strežniki Shramba Shramba Shramba Shramba Omrežje Omrežje Omrežje Omrežje Upravlja ponudnik Upravlja uporabnik 15 Klasično načrtovanje kapacitet Predvidena obremenitev KAPACITETA Primanjkljaj kapacitet Cena na enoto kapacitete Presežek kapacitet Fiksna cena kapacitet Dejanska obremenitev ČAS 16 8 Uvod v računalništvo v oblaku Elastičnost v oblaku KAPACITETA Ni primanjkljaja kapacitet Znižanje začetne investicije Alocirana kapaciteta Ni presežka kapacitet Predvidena obremenitev V primeru manjše obremenitve se kapacitete samodejno znižajo (in s tem stroški) Dejanska obremenitev ČAS 17 INFRASTRUKTURA KOT STORITEV 9 Uvod v računalništvo v oblaku Definicija Zmožnost oskrbovanja procesnih, podatkovnih in omrežnih kapacitet ter drugih računalniških virov. Uporabnik lahko postavi in zaganja poljubno programsko opremo, ki vključuje operacijski sistem in aplikacije. Le-ta ne upravlja in nadzira infrastrukture oblaka, temveč ima nadzor nad operacijskim sistemom, shrambo, postavljenimi aplikacijami in ima običajno omejen nadzor nad omrežnimi komponentami. NIST 19 Ključne karakteristike Virtualizacija Avtomatizacija in orkestracija Cloudbursting Federacija Elastičnost in skalabilnost Samopostrežba Večnajemniški model Merjenje storitev Konsolidacija in centralizacija Migracija virtualcev Replikacija podatkov 20 10 Uvod v računalništvo v oblaku Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in mrežno računalništvo: Skaliranje Distribuirani sistemi Super-računalniki Mrežno računalništvo Računalništvo v oblaku Gruče Web 2.0 Aplikacijska usmerjenost Storitvena usmerjenost 21 Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in mrežno računalništvo: • Poslovni model: – Računalništvo v oblaku: o „Pay-as-you-go“ model – plačamo za storitve, ki jih dejansko porabimo. – Mrežno računalništvo: o Projektno orientirano – uporabniki oziroma skupnost dobi na voljo določeno število enot (npr. CPE ur), ki jih lahko porabi. • Arhitektura: Omrežno računalništvo Računalništvo v oblaku Aplikacija Aplikacija Kolektiv Platforma Viri Enotni viri Povezljivost Infrastruktura Infrastruktura 22 11 Uvod v računalništvo v oblaku Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in mrežno računalništvo: • Arhitektura: – Računalništvo v oblaku: o Infrastruktura – predstavlja računalniške vire na nivoju strojne opreme, kot so izvajalna enota, shramba in omrežje. o Enotni viri – vsebujejo vire, ki so virtualizirani in izpostavljeni višjim nivojem in končnim uporabnikom kot integrirane vire (npr. virtualne stoje, gruče, logični datotečni sistem, podatkovna baza, itn.) o Platforma – dodaja zbirko specifičnih orodij, vmesno programsko opremo in storitve nad enotne vire, da bi ponudila platformo za razvoj, izvajanje in postavitev aplikacij. o Aplikacija - predstavlja aplikacije, ki se izvajajo v oblaku. 23 Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in mrežno računalništvo: • Arhitektura: – Omrežno računalništvo: o Infrastruktura – ponuja dostop do virov, kot so izvajalna enota, shramba in omrežje, repozitorij programske kode. Infrastruktura se pri omrežnem računalništvu nanaša na upravljavce lokalnih virov. o Povezljivost – definira temeljne komunikacijske in avtentikacijske protokole za varne omrežne transakcije (GSI protokol). o Viri – definira protokole za objavo, odkrivanje, pogajanje, spremljanje in zaračunavanje deljenih operacij na individualnih virih (GRAM in GridFTP protokola). o Kolektiv – zajema interakcije med kolekcijami virov, imeniškimi storitvami, kot so storitve za odkrivanje in spremljanje (MDS) ter storitve za razporejanje in posredovanje (Condor-G in Nimrod-G). o Aplikacija – predstavlja aplikacije zgrajene na protokolih in API-jih, ki operirajo v VO (Virtual Organization) okolju. 24 12 Uvod v računalništvo v oblaku Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in mrežno računalništvo: Funkcionalnost Mreža (Grid) Oblak (Cloud) Deljenje virov Kolaboracija (VO-ji, deljenje datotek). Dodeljeni viri niso deljeni. Virtualizacija Virtualizacija podatkov in računalniških virov. Virtualizacija platform programske in strojne opreme. Varnost Varnost preko delegacije poverilnic (credentials). Varnost preko izolacije. Arhitektura Storitveno usmerjena. Uporabniško izbrana arhitektura. Odvisnost programske opreme Domensko odvisna programska oprema. Domensko neodvisna programska oprema. Platformsko zavedanje Odjemalec mora biti „Grid-enabled“. Ponudnikova programska oprema deluje v kostumiziranem okolju. Skalabilnost Skalabilnost vozlišč in strani. Skalabilnost vozlišč, strani in strojne opreme. Samopostrežba Možnost ponovnih nastavitev. Možnost ponovnih nastavitev, samo-popravila (self-healing). Stopnja centralizacije Decentraliziran nadzor. Centraliziran nadzor. Uporabnost Težavnost upravljanja. Uporabniku prijazen. Standardizacija Standardizacija in interoperabilnost. Pomanjkanje standardov za interoperabilnost oblaka. Plačilni model Rigiden. Fleksibilen. QoS zagotovila Omejena podpora. Omejena podpora, osredotočena na razpoložljivost in neprekinjeno delovanje. 25 Vir: http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.176.6131&rep=rep1&type=pdf Primerjava s sorodnimi tehnologijami Računalništvo v oblaku in virtualizacija: • Virtualizacija – Zmožnost izvajanja več operacijskih sistemov na enojnem fizičnem sistemu in zmožnost deljenja virov strojne opreme. Virtualizacija Elastičnost Izolacija • Računalništvo v oblaku Konsolidacija Samopostrežba Avtomatizacija 26 13 Uvod v računalništvo v oblaku Amazon Javni ponudnik storitev računalništva v oblaku Storitve so na voljo na samopostrežen način (Self Service) Zaračunavanje po porabi (Pay As You Go) Poln dostop do virtualiziranih storitev EC2 je na voljo v več regijah (Regions) • US-West Oregon, US-West N. California, US-East Virginia, EU-West Ireland, Asia Pacific Singapore, Asia Pacific Tokyo Znotraj vsake regije je na voljo več con za dostop (Availability Zones) npr, za EU-West Ireland: • eu-west-1a,eu-west-1b,wu-west-1c 27 Amazon Na nivoju IaaS so na voljo storitve: EC2, S3, Amazon CloudWatch, Amazon CloudFront, EBS. EC2 (Elastic Compute Cloud) • • • • • Zagotavljanje izvajalnih kapacitet (virtualni stroji) Na voljo so predkonfigurane slike (AMI - Amazon Machine Image) Izberemo želeno konfiguracijo strojne opreme Določimo nastavitve za dostop (ključi) Možnosti samodejnega skaliranja, izenačevanja obremenitev, postavitev na več lokacij, povezovanje za HPC, … • Plača se po porabi (št ur, konfiguracija, AMI) 28 14 Uvod v računalništvo v oblaku Amazon Primer obračunavanja za nove Linux/Windows instance Primer posebne instance: 29 Amazon S3 (Simple Storage Service) • • • • Preprosta shramba na internetu. Dostop do preko podatkov preko REST in SOAP vmesnikov Objekte, velike do 5 TB je mogoče brati, pisati in brisati Organizacija objektov je najbolj podobna datotečni strukturi (primer uporabe: Dropbox) SimpleDB • • • • Ne-relacijska NoSQL podatkovna baza Podatki dostopni preko spletnih storitev Urejenost podatkov je urejena v domene in atribute Urejenost je analogna preglednici (Excel), kjer je domena en dokument ali List/Stran, atributi pa so imena vertikalnih stolpcev po katerih lahko iščemo 30 15 Uvod v računalništvo v oblaku Amazon Amazon CloudWatch • Storitev za spremljanje delovanja storitev • Zbrane podatke je poleg grafov mogoče prejeti tudi programsko • Osnovno spremljanje na 5 minutni interval je brezplačno Amazon CloudFront • Storitev za dostavo vsebin z uporabniku bližje lokacije • Hramba je v obliki S3 bucketa. • Plačevanje po prenosu podatkov in številu zahtevkov 31 OpenStack Uvod: • Predstavlja kolekcijo odprtokodnih tehnologij, ki ponujajo skalabilno in modularno IaaS rešitev v oblaku. • Vsebuje kolekcijo odprtokodnih projektov, ki jih vzdržuje celotna skupnost in ponuja operacijsko platformo in orodja za orkestracijo oblakov. • Trenutno ponuja tri komponente: Compute, ObjectStorage in Image Service. • Je kompatibilen z EC2 in S3 vmesniki. • V OpenStack skupnosti danes sodeluje več kot šestdeset vodilnih podjetij, kot so Rackspace, NASA, IBM, Cisco, Citrix, Dell, Intel, Microsoft in Facebook. 32 16 Uvod v računalništvo v oblaku OpenStack Arhitektura: Mobilne aplikacije, spletni odjemalci, poslovno informacijski sistemi… API sloj OpenStack Compute OpenStack Object Storage OpenStack Image Service OpenStack Identity OpenStack Dashboard 33 OpenStack Arhitektura: • OpenStack Compute (Nova) – ponuja orodje za orkestracijo oblaka in vključuje zaganjanje instanc, upravljanje omrežja in nadziranje dostopa do oblaka različnim uporabnikom. – Kompatibilen z Amazon EC2 vmesnikom. 34 17 Uvod v računalništvo v oblaku OpenStack Arhitektura: • OpenStack Compute (Nova) 35 OpenStack Arhitektura: • OpenStack Object Storage (Swift) – Omogoča izdelavo redundantne in skalabilne shrambe objektov, ki uporablja gruče standardiziranih strežnikov za shrambo ogromne količine podatkov. – Je kompatibilen z Amazon S3 vmesnikom. – Izvira iz Rackspace storage tehnologije (Cloud Files). 36 18 Uvod v računalništvo v oblaku OpenStack Arhitektura: • OpenStack Object Storage (Swift) 37 OpenStack Arhitektura: • OpenStack Image Service (Glance) – ponuja odkrivanje, registracijo in dostavo storitev za virtualne diskovne slike. Omogoča nalaganje privatnih in javnih slik v različnih formatih, kot so VHD, VDI, qcow2, VMDK ter OVF. Image: • Format diska, format vsebnika, velikost, … Image Property: • Poljubni metapodatki slik. 38 19 Uvod v računalništvo v oblaku OpenStack Upravljanje: • • • • • Upravljanje virtualnih omrežij. Upravljanje s slikami virtualnih strojev. Upravljanje z virtualnimi stroji. Upravljanje podatkovne shrambe. Upravljanje z uporabniki in skupinami. • Orodja: – VNC Console in Euca2ools – administrativna konzola. – OpenStack Dashboard – samopostrežni spletni portal (Horizon). Namestitveni modeli: P J H 39 OpenStack OpenStack Dashboard – samopostrežni spletni portal. 40 20 Uvod v računalništvo v oblaku OpenNebula Uvod: • OpenNebula je odprtokodno fleksibilno orodje za gradnjo privatnih, javnih in hibridnih IaaS oblakov. • Ponuja uporabnikom infrastrukture elastično platformo za hitro dostavo in skalabilnost storitev, da bi ugodili dinamičnim potrebam. • OpenNebule orkestrira tehnologije shrambe, omrežja, virtualizacije, spremljanja in varnosti, da bi omogočil izvajanje storitev na distribuirani infrastrukturi. • Storitve se izvajajo v virtualnih strojih, ki se nato nadzirajo in kontrolirajo v oblaku z uporabo OpenNebula Operations Center (SunStone) ali katerim izmed OpenNebula vmesnikov. • Ima Java RPC API za upravljanje z oblakom -> enostavno nadgrajevanje funkcionalnosti. • Razširitev Event handlinga, pošiljanje e-pošte ob določenih dogodkih (manipulacija hostov/instanc). – www.cloud.si 41 OpenNebula Gonilniki Jedro Orodja Arhitektura: Razporejevalnik SQL bazen CLI Ostala orodja Upravitelj zahtevkov (izpostavlja XML-RPC API) Upravitelj VM-jev Gonilnik za prenos Upravitelj gostiteljev Gonilnik VM-jev Upravitelj prenosov Gonilnik informacij Če želimo uporabljati drug hipervizor… 42 21 Uvod v računalništvo v oblaku OpenNebula Arhitektura: Orodja: • CLI – namenjen administratorjem in uporabnikom za manualno manipulacijo z virtualno infrastrukturo. • Razporejevalnik – omogoča administratorjem, da določijo politiko namestitve virtualnih strojev na fizičnih virih. Gonilniki: • OpenNebula podpira dodatne module za interakcijo s specifično vmesno programsko opremo, kot so hipervizorji, oblačne storitve, mehanizmi za prenos datotek ali informacijske storitve. Ti moduli so poimenovani kot gonilniki. 43 OpenNebula Arhitektura: Jedro: • Upravitelj zahtevkov – izpostavlja XML-RPC vmesnik s katerim ločuje funkcionalnosti jedra OpenNebule od zunanjih komponent, kot je na primer Scheduler. • Upravitelj virtualnih strojev – zadolžen za upravljanje in nadzor virtualnih strojev. Ponuja dodaten nivo abstrakcije za ukaze namenjene hipervizorju. • Upravitelj prenosov – dogovoren za prenose vseh datotek (npr. prenos slik VM-jev) potrebnih za pravilno postavitev virtualnih strojev. • Upravitelj virtualnih omrežij – omogoča kreiranje virtualnih omrežij, pri čemer sledi zapisom (IP in MAC naslovom), ki jih virtualni stroji uporabljajo. • Upravitelj gostiteljev - namenjena upravljanju in nadzoru fizičnih gostiteljev, pri čemer uporablja za to primerne gonilnike. • Podatkovna baza – hrani informaciije, potrebne za upravljanje oblaka (temelji na podatkovni bazi SQLite3). 44 22 Uvod v računalništvo v oblaku OpenNebula Upravljanje: • • • • • Upravljanje z gostitelji in gručami. Upravljanje s slikami virtualnih strojev. Upravljanje z instancami virtualnih strojev. Upravljanje z uporabniki/skupinami. Upravljanje z omrežjem. • Orodja: – SunStone – grafični vmesnik. – Ukazna vrstica. Namestitveni modeli: P J H 45 Eucalyptus Uvod: • V osnovi je bil Eucalyptus zasnovan za podporo visoko zmogljivemu računanje (High Performance Computing - HPC) na univerzi v Kaliforniji. • Gre za odprtokodno programsko opremo, ki temelji na Linuxu in implementira skalabilne privatne in hibridne oblake znotraj obstoječe infrastrukture IT organizacij. • Podpira integracijo z Amazon EC2 in S3 storitvami javnega oblaka in na tak način omogoča zmožnosti postavitve hibridnega oblaka. • Lahko nameščen brez dodatnih modifikacij na vseh večjih Linux distribucijah, kot so Ubuntu/CentOS, openSUSE, in Debian. • Razširitev za samodejno skaliranje. • Integracija z Ganglia in Nagios odprto-kodnimi monitoring sistemi. – www.cloud.si 46 23 Uvod v računalništvo v oblaku Eucalyptus Arhitektura: Spletni brskalnik SOAP orodja REST orodja Nadzornik oblaka (CLC) Walrus Gruča B Gruča A Nadzornik gruče (CC) Nadzornik gruče (CC) Nadzornik shrambe (SC) Nadzornik vozlišč (NC) Nadzornik vozlišč (NC) Nadzornik vozlišč (NC) Nadzornik vozlišč (NC) Nadzornik vozlišč (NC) Nadzornik vozlišč (NC) Nadzornik shrambe (SC) 47 Eucalyptus Arhitektura: • Nadzornik oblaka (CLC) - zadolžen za izpostavljanje in upravljanje spodaj-ležečih virtualiziranih virov (strežniki, omrežje in shramba) preko standardnih API—jev (Amazon EC2) in spletnih uporabniških vmesnikov. • Walrus – omogoča shrambo trajnih podatkov, ki so organizirani kot vedra (buckets) in objekti. Je kompatibilen z Amazon S3 vmensikom. • Nadzornik gruče (CC) – združuje informacije o virtualnih strojih in razporeja izvajanje virtualnih strojev na specifične NC enote. Ravno tako je zadolžen za upravljanje omrežja virtualnih instanc. • Nadzornik vozlišč (NC) – nadzira izvajanje, preverjanje in ustavljanje instanc virtualnih strojev na gostitelju, kjer se le-ta izvaja. • Nadzornik shrambe (SC) – ponuja podobne funkcionalnosti kot Amazon EBS in podpira številne datotečne sisteme (NFS, iSCSI, …). 48 24 Uvod v računalništvo v oblaku Eucalyptus Upravljanje: • • • • • • Upravljanje virtualnih strojev. Upravljanje ključev SSH. Upravljanje shrambe in slik. Upravljanje uporabnikov/skupin. Upravljanje omrežja. Upravljanje varnostnih skupin. • Orodja: – Euca2ools – administrativna konzola. – ElasticFox – samopostrežni spletni portal. Namestitveni modeli: P J H 49 OpenStack, Eucalyptus, OpenNebula Namestitev: Vsa ogrodja delujejo na podoben način: • Namestitev je možna na več različnih distribucijah Linuxa (Ubuntu / Debian sta zelo dobro podprta) • Namestitev vključuje veliko število opravil: – Namestitev programske opreme, konfiguracija hipervizorja, konfiguracija omrežja, namestitev podatkovne baze… – Namestitvi sledijo opcijske dodatne nastavitve: o Uporaba MySql namesto SQLite podatkovne baze o Inštalacija grafičnega uporabniške vmesnika za upravljanje z oblakom… • Sledi dodajanje uporabnikov oblaka, ustvarjanje skupin in uvoz slik virtualnih strojev (images). – slike virtualnih strojev morajo biti do neke mere prilagojene za uporabo v oblaku (npr. omogočati morajo takojšen SSH dostop ob zagonu / podpora za preverjanje ključev, itd.) • Ko uspešno opravimo vse te korake, lahko pričnemo z zaganjanjem instanc virtualnih strojev. 50 25 Uvod v računalništvo v oblaku OpenStack, Eucalyptus, OpenNebula Primerjava: OpenStack OpenNebula Eucalyptus Amazon AWS Komponenta identitete Keystone Interna Interna Amazon IAM Komponenta hrambe objektov (Object Store) Object Store (Swift) Interna Walrus Amazon S3 Omrežna komponenta Nova-network Virtual Network Manager Interna Interna Izvajalna komponenta (Compute) Nova-compute Oned Cloud Controller Amazon EC2 Komponenta nosilca (Volume) Nova-volume Interna Storage Controller Amazon EBS Komponenta razporejanja (Scheduler) Nova-scheduler Razporejevalnik (Scheduler) Cluster Controller ELB Nadzorna plošča (Dashboard) OpenStack Dashboard, Horizon SunStone, ElasticFox ElasticFox, Admin UI AWS Management Console 51 VMware vCloud Uvod: • Predstavlja infrastrukturo kot storitev (IaaS), ki lahko streže številnim infrastrukturnim in programskim potrebam, kot so eksperimentiranje, prototipiranje, testiranje in sam razvoj aplikacij. • Omogoča konsistentno in transparentno upravljanje privatnih in javnih vCloud instanc. • Predstavlja nabor storitev za računalništvo v oblaku, ki uporabljajo vCloud Director komponento kot razširitev zmožnosti vSphere virtualizacijske platforme. • Ključne komponente IaaS rešitve vCloud so: – vCloud Director, vSphere, vShield, vCenter Chargeback, vCenter Orchestrator ter vCloud Connector. 52 26 Uvod v računalništvo v oblaku VMware vCloud Arhitektura: vCloud API vCenter Operations vCloud Director vShield Manager vCenter Chargeback vCloud Connector vSphere Orchestrator vSphere API RabbitMQ VADP Fizična infrastruktura VMware Configuration Manager VMware Service Manager Skupni vmesnik Sklad oblaka Upravljanje in orkestracija 53 VMware vCloud Arhitektura: VMware vCloud Director • Storitev, ki omogoča izgradnjo ter izpostavljanje oblakov s pomočjo spletnega portala in programskih vmesnikov. 54 27 Uvod v računalništvo v oblaku VMware vCloud Arhitektura: VMware vCloud Director 55 VMware vCloud Arhitektura: VMware vSphere • Virtualizirana platforma, ki ponuja abstrakcijo nivoja fizične infrastrukture za vCloud. vStorage APIs for Data Protection 56 28 Uvod v računalništvo v oblaku VMware vCloud Arhitektura: VMware vShield • Ponuja omrežno varnost za virtualizirane podatkovne centre z uporabo VMware vShield Edge in vShield Manager tehnologije. 57 VMware vCloud Arhitektura: VMware vCenter Chargeback • Ponuja dinamično merjenje virov, cenovno modeliranje in izdelavo poročil. 58 29 Uvod v računalništvo v oblaku VMware vCloud Arhitektura: VMware vCenter Chargeback 59 VMware vCloud Arhitektura: Vmware vCloud Connector • Ponuja vtičnik s katerim se smejo uporabniki povezati z oblaki, ki temeljijo na vSphere in vCloud Director tehnologijah, ter upravljati te oblake preko enojnega vmesnika. 60 30 Uvod v računalništvo v oblaku VMware vCloud Arhitektura: VMware vCenter Orchestrator • Omogoča avtomatizacijo oskrbovanja in operativnih opravil med VMware in drugimi aplikacijami s pomočjo odprte in fleksibilne arhitekture. 61 VMware vCloud Arhitektura: VMware vCenter Orchestrator 62 31 Uvod v računalništvo v oblaku VMware vCloud Upravljanje: • • • • • Upravljanje z virtualnimi stroji. Upravljanje s slikami virtualnih strojev. Upravljanje z virtualiziranim omrežjem. Upravljanje z uporabniki/računi. Upravljanje s podatkovno shrambo... • Orodja: – VMware vCloud Director – grafični (spletni) administrativni vmesnik. Namestitveni modeli: P J H 63 Microsoft Hyper-V Cloud Uvod: • Omogoča izgradnjo privatnega oblaka s pomočjo Windows Server 2008 R2, Microsoft Hyper-V ter Microsoft System Center produkti. • Temelj produkta je postavljen na Windows Sever platformi skupaj z Windows Server Active Directory Identity Framework-om, Hyper-V virtualizacijsko zmožnostjo in System Center upravljavsko tehnologijo. • S pomočjo System Center Virtual Machine Self-Service portala lahko skrbimo za oskrbovanje, dodeljevanje in uporabo virov znotraj podatkovnega centra. 64 32 Uvod v računalništvo v oblaku Microsoft Hyper-V Cloud Arhitektura: Samopostrežba in oskrbovanje System Center VMM Self-Service Portal Integrirano upravljanje System Center Platforma Windows Server 2008 R2 Hyper-V Identiteta Windows Server 2008 Active Directory 65 Microsoft Hyper-V Cloud Arhitektura: Microsoft System Center • Družina produktov za upravljanje fizičnega in virtualiziranega IT okolja med več podatkovnimi centri, odjemalci in napravami: – – – – Upravitelj virtualnih strojev (Virtual Machine Manager) Upravitelj zaščite (Protection Manager) Upravitelj operacij (Operation Manager) Upravitelj konfiguracije (Configuration Manager) 66 33 Uvod v računalništvo v oblaku Microsoft Hyper-V Cloud Arhitektura: Microsoft System Center Self-Service Portal 67 Microsoft Hyper-V Cloud Arhitektura: Windows Server 2008 R2 Hyper-V • Ključen del Windows Server komponente in predstavlja temeljno virtualizacijsko platformo. Omogoča konsolidacijo strežnikov, izgradnjo dinamičnih podatkovnih centrov, itn. Windows Server 2008 R2 Active Directory • Omogoča upravljanje identitet ter ponuja funkcionalnosti za centralno konfiguracijo in administracijo sistema, uporabnikov in aplikacijskih nastavitev. 68 34 Uvod v računalništvo v oblaku Microsoft Hyper-V Cloud Upravljanje: • • • • • Upravljanje z virtualnimi stroji. Upravljanje zaščite podatkov. Upravljanje operacij. Upravljanje konfiguracij. Upravljanje storitev… • Orodja: – Družina produktov Microsoft System Center. Namestitveni modeli: P J H 69 Apache VCL Uvod: • Virtual Computing Lab (VCL) predstavlja idejo računalništva v oblaku, ki je bila zasnovana na ameriški univerzi North Carolina State University (NCSU) s tesno kolaboracijo IBM-ove iniciative za virtualno računalništvo (IBM Virtual Computing Initiative). • Predstavlja odprtokodni sistem za dinamično oskrbovanje in posredovanje dostopa do samostojnih strojev, kot so univerzitetni računalniki znotraj laboratorijev. • Eden izmed ključnih ciljev VCL sistema je za omejen čas dostaviti računalniško okolje uporabnikom preko spletnega vmesnika. • VCL se sestoji iz treh ključnih komponent: – Spletne komponente, – komponente podatkovne baze in – upravljavskega vozlišča. 70 35 Uvod v računalništvo v oblaku Apache VCL Arhitektura: Spletna komponenta (VCL razporejevalnik) • • • • rezervacije VCL kapacitet, nadzor dostopa, inventar strojev, zgodovino logov. Podatkovna baza Upravljavsko vozlišče Repozitorij slik Fizična postavitev Modul za novo postavitev Virtualna postavitev • • Vozlišče Vozlišče Vozlišče Bladi, VM-ji, stroji v LAB-ih… 80 – 120 blade-ov 71 Apache VCL Arhitektura: • Spletna komponenta – predstavlja jedro VCL oblaka in ponuja orodja za upravljanje, zahtevo in nadzor računalniških virov oblaka. • Komponenta podatkovne baze – hrani vse podatke povezane z rezervacijami VCL kapacitet, nadzorom dostopa, inventarjem strojev in okolja, zgodovino logov, itn. • Upravljavsko vozlišče – zadolženo za dodeljevanje primernega števila strežniških virov, avtomatično namestitev želenega operacijskega sistema, aplikacij in drugih slik programske opreme ter njihovo distribucijo. 72 36 Uvod v računalništvo v oblaku Apache VCL Upravljanje: • • • • Upravljanje s slikami virtualnih strojev. Upravljanje virtualnih omrežij. Upravljanje podatkovne shrambe. Upravljanje uporabnikov/skupin. • Orodja: – Samopostrežni spletni portal. Namestitveni modeli: P J H 73 Nimbus Uvod: • Nimbus je odprtokodno orodje, ki je osredotočeno na ponujanje infrastrukture kot storitve – IaaS za znanstvene namene. • Omogoča tri bistvene storitve: – Izgradnjo privatnih in javnih IaaS oblakov. – Uporabo IaaS oblaka. – Upravljanje IaaS oblaka. • Zasnovo Nimbusa sestavlja 7 komponent, ki temeljijo na spletnih tehnologijah. • Je kompatibilen z EC2 in S3 vmesniki. 74 37 Uvod v računalništvo v oblaku Nimbus Arhitektura: Razporejevalnik Cumulus Storage Service • Koordinacija samodejnega zagona VM-jev Workspace Pilot (integracija) Workspace Service (WSRF, EC2) Context Broker Context odjemalec Workspace resource manager Cloud odjemalec Ponudnik oblaka Workspace odjemalec Workspace Control • zagonu, zaustavitvi VM-jev. • upravljanju slik VM-jev. • varno povezovanju VM na omrežje. 75 Nimbus Arhitektura: Workspace Service: • Omogoča upravljanje in administriranje virtualnih strojev preko dveh vmesnikov. Prvi temelji na vmesniku Web Service Resource Framework (WSRF), drugi pa na EC2 WSDL . Ta storitev komunicira z Workspace Resource Manager ali Workspace Pilot komponento za upravljanje instanc. Workspace Resource Manager: • Implementira ustvarjanje instanc virtualnih strojev in njihovo upravljanje. Workspace Control: • Program nameščen na vsakem vozlišču in je namenjen zagonu, zaustavitvi in začasni zaustavitvi virtualnih strojev. Poleg tega je namenjen še rekonstrukciji in upravljanju slike virtualnega stroja, varnemu povezovanju virtualnega stroja na omrežje ter dostavi informacij za kontekstualizacijo. 76 38 Uvod v računalništvo v oblaku Nimbus Arhitektura: Workspace Pilot: • Omogoča integracijo virtualnih strojev z že konfiguriranimi viri za upravljanje opravil. Context Broker: • Storitev, ki odjemalcem omogoča koordinacijo samodejnega in ponavljajočega se zagona velikega števila virtualnih gruč. Workspace odjemalec: • Odjemalec, ki omogoča dostop do izbranih funkcionalnosti storitve Workspace Service. Cumulus Storage Service: • Omogoča akumulacijo in upravljanje podatkov, kar vključuje nalaganje podatkov v oblak, nadziranje statusa podatkov in prenos podatkov. • Omogoča shranjevanje slik za Nimbus izvajalne oblake. 77 Nimbus Upravljanje: • • • • Upravljanje virtualnih omrežij. Upravljanje z instancami virtualnih strojev. Upravljanje podatkovne shrambe. Upravljanje uporabnikov. • Orodja: – Cloud Client – administrativna konzola. Namestitveni modeli: P J H 78 39 Uvod v računalništvo v oblaku Xen Cloud Platform Uvod: • XPC je odprtokodna platforma za strežniško virtualizacijo in računalništvo v oblaku. • Podpira Xen hipervizorja ter različne operacijske sisteme (Windows in Linux). • Kombinira zmožnosti večnajemniškega modela in izolacije z naprednimi tehnologijami varnosti ter podatkovne in omrežne virtualizacije. • XCP je licenciran pod GNU General Public Licence (GPL2) in je brezplačen. • Sestavljen je iz petih ključnih komponent: – XAPI, XAPI Lib, nadzorniški vmesniki, Xen hipervizor, Dom0 domena ter operacijski sistemi. 79 Xen Cloud Platform Arhitektura: Nadzorniški vmesniki Dom0 XAPI XAPI Lib Ctrl IF Omrežje Shramba Gonilniki Operacijski sistem (Windows, Linux) Xen hipervizor Bazen virov Fizična strojna oprema 80 40 Uvod v računalništvo v oblaku Xen Cloud Platform Arhitektura: • XAPI – upravljavski sklad, ki nadzira gostitelje in bazene virov ter koordinira vire znotraj bazena. • XAPI Lib – nabor knjižnic in pripomočkov. • Nadzorniški vmesniki – XCP ponuja XE ukazno vrstico za nadzor Xen virtualnih strojev in bazenov. Obstajajo številna druga orodja. • Xen hipervizor – XCP podpira Xen hipervizorja. • Dom0 domena – vključuje podporo za omrežje, shrambo in gonilnike. • Operacijski sistem – podpira širok nabor Linux in Windows gostiteljev. 81 Xen Cloud Platform Upravljanje: • • • • Upravljanje virtualnih omrežij (Open vSwitch). Upravljanje slik virtualnih strojev. Upravljanje uporabnikov/skupin. Upravljanje spremljanja in poročanja. • Orodja: – XE – administrativna konzola. – Številni „third party“ vmesniki. Namestitveni modeli: P J H 82 41 Uvod v računalništvo v oblaku OpenQRM Uvod: • Odprtokodni produkt zgrajen na enoviti konzoli za upravljanje in številnimi vtičniki, ki skrbijo za ostale funkcionalnosti. • Podpira številne operacijske sisteme, hipervizorje (VMware, Xen, KVM in Citrix XenServer), podatkovne strežnike in omogoča razvoj lastnih vtičnikov. • Je licenciran pod GNU General Public Licence (GPL2). • Podpira P2V (physical to virtual), V2P (virtual to physical) in V2V (virtual to virtual) migracije. • Ponuja failover mehanizem, ki omogoča skupinam strežnikov uporabo enojnega „standby“ načina. • Podpira integracijo z Nagios monitoring sistemom. 83 OpenQRM Arhitektura: • Strežnik – temelj openQRM storitev je strežnik, ki je zadolžen za upravljanje virtualizirane vire oblaka. • Vtičnik oblaka – ponuja polno-avtomatiziran zahtevek in cikel za oskrbovanje in postavitev. Xen iSCSI-Target Abstrakci ja hrambe NetAPP OpenQRM strežnik Abstrakci ja virov VMware ESX KVM NFS-balde AoE-balde OpenQRM vtičnik oblaka 84 42 • • Dodelitev stežnikov, Postavitev slik… Uvod v računalništvo v oblaku OpenQRM Upravljanje: • • • • • • Upravljanje virtualnih omrežij. Upravljanje s slikami virtualnih strojev. Upravljanje z virtualnimi stroji. Upravljanje shrambe. Upravljanje spremljanja in poročanja. Upravljanje z uporabniškimi računi. • Orodja: – Enojna administrativna konzola. Namestitveni modeli: P J H 85 RedHat CloudForms Uvod: • Omogoča izgradnjo in upravljanje lastnega IaaS oblaka za interno uporabo. • Podpira integracijo z obstoječimi produkti in tehnologijami, kot so fizični strežniki ter virtualizacijske platforme drugih ponudnikov. • Zagotavlja upravljanje aplikacij skozi njihovo življenjsko dobo. • CloudForms ponuja IaaS infrastrukturo s pomočjo treh komponent: – Upravljanje življenjskega cikla aplikacij (sistemski in aplikacijski pogon). – Upravljanje izvajalnih virov (pogon oblaka). – Infrastrukturne storitve (storitve oblaka). 86 43 Uvod v računalništvo v oblaku RedHat CloudForms Arhitektura: Upravljanje izvajalnih virov Sistemski pogon • Izdelavo virov, • upravlja politike in delovne tokove • Vodi dostop in dovoljenja do teh virov. Aplikacijski pogon Upravljanje izvajalnih virov Pogon oblaka Infrastrukturne storitve Storitve oblaka Storitve oblaka Storitve oblaka Storitve oblaka Spremljanje, upravljanje, sporočanje, replikacija, visoka razpoložljivost (HA)… 87 RedHat CloudForms Arhitektura: CloudForms pogon oblaka: • Zadolžen za upravljanje vseh virov oblaka. Omogoča izdelavo virov, upravljanje politik in delovnih tokov ter voditi dostop in dovoljenja do teh virov. CloudForms aplikacijski pogon: • Ponuja upravljanje z aplikacijami, ki temelji na šablonah. Lahko dvigne, inicializira in ponuja definirane storitve. CloudForms sistemski pogon: • Upravlja izvajane sisteme med fizična in virtualna okolja ter okolja oblaka. CloudForms storitve oblaka: • Predstavljajo dodatke, ki zagotavljajo konsistentne funkcionalnosti med različnimi ponudniki oblaka. Primer: spremljanje, upravljanje, sporočanje, replikacija, visoka razpoložljivost (HA), itn. 88 44 Uvod v računalništvo v oblaku RedHat CloudForms Upravljanje: • • • • • Upravljanje s slikami virtualnih strojev. Upravljanje z življenjskim ciklom aplikacije. Upravljanje z oskrbovanjem. Upravljanje uporabnikov in računov. Upravljanje spremljanja in poročanja. • Orodja: – Grafični vmesnik za nadziranje in upravljanje. Namestitveni modeli: P J H 89 IBM SmartCloud Uvod: • IBM ponuja množico tehnologij za IaaS računalništvo v oblaku. • Produkte lahko združimo v štiri storitve: Upravljalne infrastrukturne storitve, sisteme za operacijsko podporo, optimizacijske storitve ter varnostno komponento. 90 45 Uvod v računalništvo v oblaku IBM SmartCloud Arhitektura: Upravljanje infrastrukturne storitve Sistemi za operacijsko podporo Optimizacijske storitve Varnostna komponenta 91 IBM SmartCloud Arhitektura: Upravljalne infrastrukturne storitve: • IBM SmartCloud Enterprise Sistemi za operacijsko podporo: • IBM Service management for cloud computing IBM Tivoli Monitoring for Virtual Servers • IBM Service Delivery Manager • Tivoli Monitoring for Virtual Servers • IBM Tivoli Storage Manager for Virtual Environments 92 46 Uvod v računalništvo v oblaku IBM SmartCloud Arhitektura: Optimizacijske storitve: • • • • • • • • IBM Service management for cloud computing IBM Service Delivery Manager IBM CloudBurst IBM BladeCenter Foundation for Cloud IBM Power Systems Cloud solutions IBM System z Solution Edition for Cloud Computing IBM System for Cloud Computing System Storage for Cloud Computing Varnostne komponente: • IBM Rational Cloud Application Security and Compliance solutions • Tivoli Cloud Security Management solutions 93 IBM SmartCloud Upravljanje: • • • • Upravljanje z gostitelji in gručami. Upravljanje s slikami virtualnih strojev. Upravljanje z instancami virtualnih strojev. Upravljanje z uporabniki in računi. • Orodja: – Nadzorna plošča za upravljanje in spremljanje. Namestitveni modeli: P J H 94 47 Uvod v računalništvo v oblaku Oracle IaaS Uvod: • Oracle sam ne dostavlja IaaS storitev vendar ponuja drugim IaaS ponudnikom strojno in programsko opremo za vzpostavitev privatnih in javnih oblakov. • V grobem ga sestavlja sedem ključnih komponent: – – – – – – – Shramba Strežniki Oracle Solaris vsebniki, Oracle VM za SPARC Oracle VM za x86 Oracle Solaris Oracle Linux Fizično in virtualno upravljanje sistema (Oracle Enterprise Manager Ops Center) 95 Oracle IaaS Arhitektura: Aplikacija 1 Aplikacija 2 Oracle Solaris Aplikacija 3 Oracle Linux Oracle Solaris vsebniki Oracle VM za SPARC Oracle VM za x86 Strežniki Shramba 96 48 Fizično in virtualno upravljanje sistema (Oracle Enterprise Manager Ops Center) Uvod v računalništvo v oblaku Oracle IaaS Arhitektura: Strežnik (Oracle VM Server): • Namestimo ga lahko neposredno na strežniško strojno opremo z x86 procesorji in ne zahtevajo operacijskega sistema gostitelja. Vključuje VM agenta, ki omogoča komunikacijski kanal z Oracle VM Manager komponento za upravljavske namene. Oracle VM Manager (Oracle Enterprise Manager Ops Center): • Upravljavski strežnik, ki temelji na Javanski tehnologiji in uporablja Oracle podatkovno bazo kot repozitorij za upravljanje. Zadolžen je za upravljanje virtualnih strojev, ki se izvajajo na Oracle VM Server komponenti (to počne s pomočjo Oracle VM Agent komponente). 97 Oracle IaaS Upravljanje: • • • • • Upravljanje z gostitelji in gručami. Upravljanje s slikami virtualnih strojev. Upravljanje z instancami virtualnih strojev. Upravljanje spremljanja in poročanja. Upravljanje z uporabniki in računi. • Orodja: – Oracle VM Manager – Oracle VM Management Pack Namestitveni modeli: P J H 98 49 Uvod v računalništvo v oblaku PLATFORMA KOT STORITEV Definicija Zmožnost postavitve različnih tipov aplikacij, ki si razvite z uporabo programskih jezikov in orodij ponujenih s strani ponudnika. Uporabnik pri tem ne upravlja in nadzira spodaj ležečo infrastrukturo (omrežje, shrambo, operacijski sistem ali strežnik) temveč ima nadzor nad postavljeno aplikacijo in pogosto tudi nastavitvami gostujočega okolja. NIST 100 50 Uvod v računalništvo v oblaku Ključne karakteristike Samopostrežba Avtomatizirano upravljanje in spremljanje Skalabilnost Večnajemniški model Centraliziran nadzor Varovana platforma ter dostop Merjenje in zaračunavanje porabe Visoka razpoložljivost aplikacij in podatkov Integracijski model storitev Celovito podprt življenjski cikel razvoja aplikacij Podprt skupinski razvoj 101 Programski modeli Odjemalec/Strežnik (Client/Server): • Ločuje sistem na aplikacije, kjer odjemalec pošilja zahteve strežniku. V večini primerov je strežnik podatkovna baza z aplikacijsko logiko, ki je predstavljena kot bazna procedura. Komponentna arhitektura (Component-Based Architecture): • Dekompozicija aplikacijske arhitekture v ponovno uporabljive funkcionalne in logične komponente, ki izpostavljajo dobro definirane komunikacijske vmesnike. Domensko gnano načrtovanje (Domain Driven Design): • Objektno orientiran arhitekturni stil osredotočen na modeliranje poslovnih domen in definiranju poslovnih objektov, ki temeljijo na entitetah znotraj poslovne domene. 102 51 Uvod v računalništvo v oblaku Programski modeli Nivojska arhitektura (Layered Architecture): • Osredotoča se na grupiranje sorodnih funkcionalnosti aplikacije v različne nivoje, katerih funkcionalnosti so povezani s skupno vlogo ali odgovornostjo. Sporočilno vodilo (Message Bus): • Arhitekturni stil, ki predpisuje uporabo programske opreme za pošiljanje in sprejem sporočil z uporabo enega ali več komunikacijskih kanalov. Na tak način so lahko različne aplikacije v interakciji, ne da bi se zavedale podrobnosti drugih. Večslojna/3-slojna arhitektura (N-Tier/3-Tier): • Združuje funkcionalnosti v ločene segmente na podoben način kot nivojski arhitekturni stil. V tem primeru vsak segment predstavlja logičen nivo, ki je lociran na drugem fizičnem računalniku. 103 Programski modeli Storitveno usmerjena arhitektura (SOA): • Arhitektura aplikacij, ki izpostavljajo in koristijo funkcionalnosti v obliki storitev z uporabo pogodb in sporočil. Model računalništva v oblaku: • Računalništvo v oblaku prinaša številne prednosti, kot so elastičnost, visoka stopnja razpoložljivosti in zanesljivosti ter agilnost. Ravno tako vpeljuje nov način dostave storitev, kot so relacijska podatkovna baza v oblaku, NoSQL baza, avtomatično skaliranje, varnostne skupine, itn. Da bi uspešno koristili vse te prednosti, morajo aplikacije za oblak biti načrtovane tako, da sledijo specifičnemu aplikacijskemu modelu. • Različni ponudniki storitev oblaka imajo različne zahteve in s tem drugačne modele aplikacij. 104 52 Uvod v računalništvo v oblaku Programski modeli Model računalništva v oblaku: • Amazon AWS: Odjemalec Zunanji sistem Vnaprej nastavljen AMI Aplikacija AWS Elastic Beanstalk Amazon EC2 RDS EC2+EBS SimpleDB SQS S3 105 Programski modeli Model računalništva v oblaku: • Google App Engine: Odjemalec Zunanji sistem URLFetch Service Aplikacija App Engine izvajalno okolje Blobstore Datastore Memcache 106 53 Uvod v računalništvo v oblaku Programski modeli Model računalništva v oblaku: • Windows Azure: Odjemalec Odjemalec Zunanji sistem AppFabric Service Bus Aplik Aplikacija Web role Web role Worker role Azure Storage AppFabric Caching SQL Azure 107 Programski modeli Model računalništva v oblaku: • Force.com: Odjemalec Worke VM role Zunanji sistem Force.com Web Services Aplikacija Apex izvajalno okolje Force.com Database 108 54 SQL Azure AppFa Cach Uvod v računalništvo v oblaku Življenjski cikel razvoja aplikacij na PaaS SDLC na PaaS: Lokalno V oblaku Razvoj aplikacije Postavitev in izdaja Gradnja in testiranje Postavi - Orodja za razvoj - Orodja za Unit testiranje - Spletni portal - CLI orodja - SDK-ji in vtičniki za razvojna orodja Sistemsko testiranje Izdaja verzije Izdaja v produkcijo Integracijski test UAT Smoke test Prenos v produkcijo Nastavitve Upravljanje Spremljanje Odpravljanje hroščev Upravljanje verzij in nadzor kode Upravljanje in spremljanje storitev 109 Življenjski cikel razvoja aplikacij na PaaS Testiranje aplikacije v oblaku je smiselno opraviti v treh fazah: • Lokalno testiranje aplikacije znotraj emulatorjev. • Uporaba lokalne podatkovne shrambe. Lokalno Hibridno • Lokalno testiranje aplikacije znotraj emulatorjev. • Uporaba podatkovne shrambe v oblaku. 110 55 • Testiranje aplikacije v oblaku. • Uporaba podatkovne shrambe v oblaku. V oblaku Uvod v računalništvo v oblaku Java EE 7 in oblak – JSR 342 Podpora za delovanje aplikacij v PaaS okoljih Zasebnih in javnih oblakov Podpora večnajemniškemu modelu Podpora elastičnosti Bolj natančne zahteve za vire in upravljanje stanja Boljša izolacija med aplikacijami Standardni APIji na ne-RDBMS, medpomnjenje, itd. Enotni vmesniki za upravljanje in nadzor Boljše pakiranje aplikacije / modularnost 111 Java v oblaku Aplikacija UPRAVLJANO OKOLJE Aplikacija Aplikacija Aplikacija PaaS Java storitve Trajnost podatkov Storitveno vodilo, sporočilni sistem, … IaaS Virtualizacija Upravljanje stanj, elastičnost, … 112 56 Uvod v računalništvo v oblaku Modularnost v Java EE 7 Bo temeljila na modularnosti Java SE 8 Aplikacije sestavljene iz modulov SCA Odvisnosti so eksplicitne Vgrajeno verzioniranje Izboljšani nalagalniki razredov 113 Ostale novosti v Java EE 7 Java Persistence API 2.1 – JSR 338 JAX-RS 2.0 – JSR 339 Servlets 3.1 – JSR 340 Expression Language 3.0 – JSR 341 Java EE 7 – JSR 342 Java Message Service 2.0 – JSR 343 Java Server Faces 2.2 – JSR 344 EJB 3.2 – JSR 345 CDI 1.1 – JSR 346 JCache – JSR 107 Bean Validation 1.1 – JSR 349 ... 114 57 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku Uvod: • Pod podatkovno shrambo v oblaku je smiselno obravnavati štiri možnosti: – – – – Objektna shramba statičnih podatkov (BLOBs) Relacijska podatkovna baza Distribuirano predpomnjenje NoSQL podatkovna baza 115 Podatkovna shramba v oblaku Distribuiran datotečni sistem (Objektna shramba): • Predstavlja datotečni sistem, ki omogoča dostop do datotek v distribuiranem, večnajemniškem (multi-tenant) okolju preko omrežja. • Primeri: – – – – – – – – – Windows Azure Storage blobs Amazon Simple Storage Service (S3) Google File System Hadoop Distributed File System (HDFS) XtreemFS GlusterFS Eucalyptus Walrus OpenStack Object Storage (Swift) Nimbus - Cumulus Storage Service 116 58 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku Relacijska baza v oblaku: • Gre za relacijsko bazo, ki je dostavljena kot storitev v oblaku. • Primeri: – – – – – – Amazon RDS SQL Azure Google Cloud SQL Oracle Database Cloud Service IBM DB2 for Private Cloud Drizzle 117 Podatkovna shramba v oblaku Distribuirano predpomnjenje: • Ponuja predpomnjenje podatkov, da bi pospešili performanco visoko-skalabilnih sistemov. • Primeri: – – – – – – – – – – Gemstone Gemfire IBM Webpshere eXtreme Scale Gigaspaces IBM Webpshere eXtreme Scale Infinispan Memcached Ncache Oracle Coherence Terracotta for Web Sessions Hazelcast 118 59 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku NoSQL podatkovne baze: • Definicija NoSQL še zmeraj ni popolnoma razjasnjena. V literaturi sicer zasledimo dve možni interpretaciji: – Not Only SQL – Not Relational • Ključne karakteristike NoSQL: – Zmožnost horizontalnega skaliranja operacij (read/write) med več strežniki. – Zmožnost replikacije in distribucije podatkov med več strežniki. – Preprost vmesnik ali protokol (kot nasprotje SQL binding-a). – Šibak model sočasnega izvajanja (kot nasprotje ACID transakcijam večine SUPB). – Učinkovita uporaba distribuiranih indeksov in RAM-a za podatkovno hrambo. – Zmožnost dinamičnega dodajanja novih atributov k zapisom podatkov. – ACID (Atomic, Consistent, Isolated, Durable) -> BASE (Basic Availability, Soft state, Eventual consistency) 119 Podatkovna shramba v oblaku NoSQL podatkovne baze: • V kontekstu NoSQL baz običajno velja t.i. CAP teorem in pravi, da sta lahko v distribuiranem okolju zagotovljena zgolj 2 izmed 3 atributov: • Consistency – vsi vozlišča vidijo iste podatke ob istem času. • Availibility – vsak odjemalec lahko zmeraj piše/bere. • Partition-tolerance – sistem ne preneha delovati v primeru izgub sporočil med dvema ali več vozlišči (npr. napaka omrežja). • Večina NoSQL sistemov ovrže ravno konsistenco. • NoSQL baze lahko klasificiramo glede na naslednje podatkovne modele: • „Key-value“ baze – sistem hrani indeksirane podatke, ki jih pridobimo glede na njihov ključ. • Dokumentno usmerjene – hranijo in organizirajo podatke kot zbirke dokumentov (JSON, XML), raje kot strukturirane tabele z enotno velikostjo polj za vsak zapis. • Stolpično usmerjene – namesto shranjevanja podatkov v strukturirane tabele stolpcev in vrstic z fiksno dolžino atributov, stolpčno usmerjene baze vsebujejo razširljive stolpce. • Baze, ki temeljijo na grafih – baze, kjer podatke hranimo v obliki grafov. 120 60 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku NoSQL podatkovne baze: A Consistency, Availability: • • Availability, Partition-tolerance: • • • RDBMS (MySQL, Postgres, DB2, …) Vertica (stolpično usmerjena) C Consistency, Partition-tolerance: • • • MongoDB Terrastore Redis • • • BigTable Hypertable HBase • • • Scalaris MemcacheDB Berkeley DB 121 Podatkovna shramba v oblaku NoSQL podatkovne baze: • Primeri „Key-value“ baz: – – – – – – – – – – – Dynamo Voldemort Cassandra Windows Azure Table Storage Oracle NoSQL Database Voldemort (temelji na Dynamo) Amazon Dynamo Riak (temelji na Dynamo) Membase Redis Berkeley DB MemcacheDB Scalaris Tokyo Cabinet / Tyrant 122 61 P • • • SimpleDB CouchDB Riak Uvod v računalništvo v oblaku Podatkovna shramba v oblaku NoSQL podatkovne baze: • Primeri dokumentno usmerjenih baz: – – – – – – – – SimpleDB (uporablja Amazon S3) CouchDB MongoDB Terrastore ThruDB OrientDB RavenDB IBM Lotus Domino 123 Podatkovna shramba v oblaku NoSQL podatkovne baze: • Primeri stolpično usmerjenih baz: – – – – – – Cassandra (Bigtable + Dynamo) Hbase (temelji na BigTable) PNUTs (ni komercialno na voljo - Yahoo) BigTable (ni komercialno na voljo - Google) Hypertable (temelji na BigTable) HBase (uporablja Hadoop) 124 62 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku NoSQL podatkovne baze: • Primeri baz, ki temeljijo na grafih: – – – – – – – – – – – Neo4J Infinite Graph Sones InfoGrid HyperGraphDB Trinity AllegroGraph Bigdata DEX AllegroGraph FlockDB 125 Podatkovna shramba v oblaku NoSQL podatkovne baze: • Apache Cassandra: – Gre za odprtokodni projekt, ki ga leta 2008 navzven odprl Facebook. – Visoko-skalabilna in distribuirana podatkovna baza, ki predstavlja kombinacijo Amazon Dynamo (distribuirana arhitektura) in Google Bigtable (stolpično usmerjena baza). – Lastnosti: o Simetrična baza: × Ni enojne točne za napako (Single Point Of Failure) × Linearno skalabilna × Enostavna administracija o Fleksibilno particioniranje in menjava replik o Automatizirano oskrbovanje o Visoka stopnja razpoložljivosti (Morebitna konsistenca) – Osnovno enoto hrambe prestavlja stolpec. – CAP teorem: AP (razpoložljiva in odporna na particije). 126 63 Uvod v računalništvo v oblaku Podatkovna shramba v oblaku NoSQL podatkovne baze: • Apache CouchDB: – Gre za odprto-kodno bazo nad katero lahko izvajamo poizvedbe in indeksiranje z uporabo JavaScripta (MapReduce). – Nima sheme in je dokumentno usmerjena. – Ponuja inkrementalno replikacijo z dvosmerno detekcijo konfliktov. – Ponuja RESTful JSON API. – Napisa je v programskem jeziku Erlang (funkcijski jezik, idealen za izdelavo sočasnih distribuiranih sistemov). – Operacije branja uporabljajo MVCC (Multi-Version Concurrency Control) model, pri čemer vsak odjemalec vidi konsistenten posnetek celotne operacije branja. – Dokument v kontekstu CouchDB predstavlja objekt, ki se sestoji iz poimenovanih polij (Stringi, števila, datumu, urejeni seznami, …). – Podpira vse ACID (Atomic Consistent Isolated Durable) lastnosti. – CAP teorem: AP (razpoložljiva in odporna na particije). 127 Podatkovna shramba v oblaku NoSQL podatkovne baze: • Azure Table Storage (Key-value): – Za razliko od prejšnjih dveh je ta komercialna. – Gre za „Key-value“ podatkovno bazo, pri čemer pare (ključ-vrednost) imenujemo lastnosti. – Je brez sheme, kar omogoča, da so lastnosti vsake entitete v tabeli med seboj različne. – Predstavlja eno izmed Windows Azure Storage komponent (Blobi, Tabele in Vrste). – Podatke, ki hrani posamezna tabela so shranjeni v skupini entitet, ki vsebujejo lastnosti. – Namesto klasičnih SQL poizvedb, tukaj uporabljamo poizvedbe z uporabo konvencij, definiranih s strani OData. – Takšna struktura omogoča hitro skaliranje med več virtualnih strojev. – Dostopen preko REST API-ja. – CAP teorem: AP (razpoložljiva in odporna na particije). 128 64 Uvod v računalništvo v oblaku AWS Elastic Beanstalk Uvod: • Omogoča hitro postavitev in upravljanje aplikacij ne da bi morali skrbeti za spodaj-ležečo infrastrukturo. AWS Elastic Beanstalk skrbi za postavitvene podrobnosti, oskrbovanje kapacitet, izenačevanje obremenitev, avtomatično skaliranje in spremljanje zdravja aplikacij. • AWS Elastic Beanstalk je sestavljen in številnih komponent, ki delujejo skupaj, da bi omogočili enostavno postavitev in upravljanje aplikacij v oblaku: – – – – – Aplikacijska komponenta. Komponenta verzij. Komponenta okolja. Komponenta konfiguracije okolja. Komponenta konfiguracijske predloge. 129 AWS Elastic Beanstalk Arhitektura: http://moja-aplikacija.elasticbeanstalk.com/ Elastic Load Balancer Okolje Verzija S3 vedro Auto Scaling EC2 instance EC2 instance EC2 instance Apache Elastic Beanstalk Host Manager Elastic Beanstalk aplikacija Tomcat Izvajana aplikacija Amazon Linux AMI 130 65 Uvod v računalništvo v oblaku AWS Elastic Beanstalk Arhitektura: Aplikacijska komponenta: • Predstavlja logično kolekcijo komponent, kot so okolja, verzije ter konfiguracije. Komponenta verzij: • Predstavlja specifično, označeno iteracijo postavljene kode. Verzija kaže na Amazon S3 objekt, ki vsebuje postavljeno kodo (npr. Javansko WAS datoteko). Aplikacija lahko ima več verzij. Komponenta okolja: • Predstavlja verzijo, ki je postavljena na virih AWS. Okolje lahko ima le eno verzijo istočasno, vendar je lahko prisotnih več simultanih okolij, ki izvajajo isto ali različne verzije. • AWS viri znotraj okolja vključujejo izenačevalca obremenitev, Auto Scaling skupino ter eno ali več EC2 instanc. 131 AWS Elastic Beanstalk Arhitektura: Komponenta konfiguracije okolja: • Zadolžena za identifikacijo kolekcije parametrov in nastavitev, ki definirajo obnašanje okolja in asociiranih virov. Ob posodobitvi nastavitev okolja, AWS Elastic Beanstalk avtomatično aplicira spremembe k obstoječim virom ali izbriše in postavi nove vire. Komponenta konfiguracijske predloge: • Konfiguracijska predloga omogoča izdelavo unikatne konfiguracije okolja. Lahko jih izdelamo oziroma modificiramo s pomočjo komandne vrstice ali API-jev. 132 66 Uvod v računalništvo v oblaku AWS Elastic Beanstalk Upravljanje: • • • • • Spremljanje porabe in izvajanja. Upravljanje opozoril. Upravljanje z avtomatičnim skaliranjem. Upravljanje verzij in logiranja. Spremljanje virov (EC2, ELB, S3, CloudWatch) • Orodja: – Eclipse razširitve – AWS upravljavska konzola. Namestitveni modeli: P J H 133 RedHat OpenShift Uvod: • Storitev, ki omogoča razvoj, izvajanje in postavitev aplikacij med več oblaki in z uporabo različnih ogrodij in programskih jezikov. • Trenutno je sestavljen iz dveh storitev: Flex in Express. 134 67 Uvod v računalništvo v oblaku RedHat OpenShift Arhitektura: RedHat OpenShift Express Flex Amazon EC2 infrastruktura 135 RedHat OpenShift Arhitektura: OpenShift Express • Brezplačna aplikacijska platforma za Ruby, Perl, PHP in Python aplikacije. • Uporablja Git sistem za dodajanje in postavitev aplikacij na OpenShift Express (takšen sistem omogoča nadzor verzij). • Uporablja CLI (Command Line Interface) orodja za postavitev in upravljanje aplikacij v oblaku. OpenShift Flex • Brezplačna aplikacijska platforma za Java EE in PHP aplikacije. • Ponuja grafični uporabniški vmesnik za izdelavo, postavitev, upravljanje in spremljanje oblaka in aplikacije. • Na voljo so orodja za spremljanje performance, izvedbo analize logov ter zagotavljanje avtomatične skalabilnosti. • Postavljen na Amazon EC2 infrastrukturi. 136 68 Uvod v računalništvo v oblaku RedHat OpenShift Upravljanje: • • • • • Upravljanje z nastavitvami virtualnih strojev. Upravljanje z aplikacijami in podatki. Spremljanje porabe in izvajanja. Upravljanje skaliranja. Upravljanje verzij (Git sistem). • Orodja: – CLI orodja – postavitev in upravljanje aplikacij v oblaku. – GUI za izdelavo, postavitev, upravljanje in spremljanje oblaka in aplikacije. Namestitveni modeli: P J H 137 Windows Azure platforma Uvod: Windows Azure platforma je sestavljena iz štirih tehnologij: • • • • Windows Azure, SQL Azure, Windows Azure AppFabric, Windows Azure Marketplace. Komponente lahko uporabljamo skupaj ali posamično. 138 69 Uvod v računalništvo v oblaku Windows Azure platforma Arhitektura: Aplikacije in podatki Windows Azure AppFabric SQL Azure Windows Azure Marketplace Windows Azure 139 Windows Azure platforma Arhitektura: Windows Azure: • Okolja za izvajanje aplikacij in shrambo podatkov na strežnikih znotraj Microsoftovih podatkovnih centrih. Storitev je sestavljena iz petih komponent: – Compute – skrbi za izvajanje aplikacij na Windows Server strežnikih. – Storage – omogoča shrambo treh tipov podatkov (blob-ov, tabel in vrst). – Fabric controller – programska oprema, ki upravlja in spremlja izvajane aplikacije ter računalniške vire. – Content Delivery Network (CDN) – predpomnjenje najpogosteje uporabljenih podatkov blizu končnega uporabnika. – Connect – omogoča obravnavo aplikacij, kot da bi bile znotraj požarnega zidu organizacij, ki do njih dostopajo. SQL Azure: • Omogoča delo z relacijsko podatkovno bazo v oblaku. Storitev sestavljajo tri komponente: – SQL Azure Database – predstavlja sistem za upravljanje s podatkovno bazo (SUPB) v oblaku. – SQL Azure Reporting – omogoča izdelavo standardnih SSRS poročil. – SQL Azure Data Sync – omogoča sinhronizacijo podatkov med SQL Azure podatkovnimi bazami in lokalnimi SQL Server bazami. 140 70 Uvod v računalništvo v oblaku Windows Azure platforma Arhitektura: Windows Azure AppFabric: • Omogoča izdelavo infrastrukturnih storitev v oblaku. Storitev je sestavljena iz treh komponent: – Service Bus – omogoča izpostavljanje končnih točk do katerih lahko dostopajo druge aplikacije. – Access Control – ponuja vgrajeno podporo za delo z identitetami. – Caching – omogoča distribuirano predpomnjenje najpogosteje uporabljenih podatkov. Windows Azure Marketplace: • Repozitorij aplikacij in nabora podatkov (datasets). Sestavljata ga dve komponenti: – DataMarket – omogoča ponudnikom, da izpostavljajo dataset-e, do katerih lahko dostopajo končni uporabniki. – AppMarket – razvijalci lahko izpostavljajo svoje aplikacije potencialnim končnim uporabnikom. 141 Windows Azure platforma Upravljanje: • Upravljanje z virtualnimi stroji (spletne, delovne in VM vloge). • Upravljanje s podatkovno shrambo (relacijska baza, NoSQL baza, blobi, sporočilne vrste). • Spremljanje porabe in izvajanja. • Upravljanje verzij. • Orodja: – Windows Azure portal – grafični administrativni vmesnik. Namestitveni modeli: P J H 142 71 Uvod v računalništvo v oblaku Google App Engine Uvod: • Gre za platformo kot storitev (PaaS) in omogoča izgradnjo in gostovanje spletnih aplikacij na Google-ovih podatkovnih centrih. • Podpira aplikacije razvite v številnih programskih jezikih. Podprta so tri izvajalna okolja: Javansko izvajalno okolje, Python izvajalno okolje ter Go izvajalno okolje. • Ključne arhitekturne komponente lahko razdelimo na tri dele: Izvajalno okolje, shrambo in ostale storitve. 143 Google App Engine Arhitektura: Datastore Blobstore Memcache Aplikacijski strežniki zehteva URL Fetch Mail Images XMPP Task Queues Accounts „Frontend“ Datotečni strežniki 144 72 Uvod v računalništvo v oblaku Google App Engine Arhitektura: Izvajalno okolje: • Omogoča dejansko izvajanje aplikacij. Trenutno podpira izvajalna okolja za Python, Javo in Go. Shramba: • Datastore – App Engine ne ponuja tradicionalne relacijske podatkovne baze temveč vpeljuje distribuirano in skalabilno Datastore bazo, ki temelji na BigTable. • Blobstore – omogoča shranjevanje binarnih objektov, ki so veliko večji od podatkov dovoljenih znotraj Datastore baze. • Memcache – omogoča predpomnjenje pogosto uporabljenih podatkov in je skladen z JCache specifikacijo (JSR 107). 145 Google App Engine Arhitektura: Storitve: • URL Fetch – aplikacijam omogoča dostop do spletnih storitev (s pomočjo URL Fetch service storitvijo) in drugih podatkov na spletu. • Mail – poštna storitev, ki omogoča pošiljanje in prejemanje e-poštnih sporočil. • XMPP – analogno Mail storitvi, vendar gre za sistem za takojšnje sporočanje (Instant Messaging). • Images – integrirana storitev za manipulacijo s slikami (povečanje, združevanje, pretvarjanje formatov, rotiranje, …). • Task queues – vgrajena funkcionalnost za procesiranje iz ozadja (background processing). • Accounts – omogoča integracijo z aplikacijami za uporabo avtentikacije uporabnikov. 146 73 Uvod v računalništvo v oblaku Google App Engine Upravljanje: • • • • Upravljanje z virtualnimi stroji. Upravljanje s podatkovno shrambo (Datastore, Blobstore). Spremljanje porabe in izvajanja. Upravljanje verzij in logov. • Orodja: – Administrativna konzola – omogoča pregled nad realnočasovnimi podatki, logi, prometom, itn. Omogoča vpogled nad ternutno performanco postavljene aplikacije. Ponuja možnost postavitve nove verzije izvorne kode. – Eclipse razširitve Namestitveni modeli: P J H 147 IBM PaaS Uvod: • IBM-ova PaaS rešitev obsega številne tehnologije, ki jih lahko razdelimo v štiri področja: Aplikacijske storitve, življenjski cikel aplikacij, integracijske storitve in „Workload“ storitve. 148 74 Uvod v računalništvo v oblaku IBM PaaS Arhitektura: Aplikacijske storitve Življenjski cikel aplikacij Integracijske storitve „Workload“ storitve 149 IBM PaaS Arhitektura: Aplikacijske storitve: • Storitve za kolaboracijo, analitiko in upravljanje poslovnih procesov. Produkti, ki so na voljo: – IBM Smart Analytics Cloud for System z – IBM Systems Director – IBM Blueworks Live Življenjski cikel aplikacije: • Tehnologije, ki omogočajo kolaboracijo in avtomatizacijo razvoja aplikacij skozi celoten življenjski cikel: – IBM Rational Collaborative Software Delivery Life Cycle Management Solutions on the Cloud – IBM Rational Solutions for Cloud Development and Test 150 75 Uvod v računalništvo v oblaku IBM PaaS Arhitektura: Integracijske storitve: • Omogoča integracijo podatkov, aplikacij in storitev z različnimi okolji oblaka: – IBM WebSphere Cast Iron Cloud Integration Workload storitve: • Gre za storitve optimizacije zmogljivosti od aplikacijskih vzorcev, do vzorcev obremenitve, ki zagotavljajo QoS in razpoložljivost. Produkti, ki so na voljo: – – – – – IBM Workload Deployer WebSphere Virtual Enterprise WebSphere Application Server IBM DB2 for Private Cloud IBM Informix Flexible Grid for Private Cloud 151 IBM PaaS Upravljanje: • • • • • • Upravljanje z postavitvijo in izvajanjem aplikacij. Upravljanje s podatkovno shrambo. Upravljanje z repozitorijem slik. Spremljanje porabe in izvajanja. Upravljanje z življenjskim ciklom razvoja aplikacij. Upravljanje verzij. • Orodja: – Tivoli Service Automation Manager. Namestitveni modeli: P J H 152 76 Uvod v računalništvo v oblaku Oracle PaaS Uvod: • Oracle ponuja celovit nabor produktov za izgradnjo aplikacijske platforme PaaS, ki je na voljo kot storitev javnega ali privatnega modela računalništva v oblaku. • Osnovan je na Oracle Grid tehnologijah za postavitev modela mrežnega računalništva. • Produkte, ki omogočajo postavitev privatnega PaaS oblaka lahko razdelimo med 8 komponent: Podatkovna komponenta, aplikacijska komponenta, integracijska komponenta, komponenta upravljanja s procesi, varnostna komponenta, komponenta uporabniške interakcije ter deljene storitve. 153 Oracle PaaS Arhitektura: Aplikacija 1 Aplikacija 2 Aplikacija 3 Deljene storitve Integracijska komponenta Komponenta upravljanja s procesi Komponenta uporabniške interakcije Varnostna komponenta Aplikacijska komponenta Podatkovna komponenta 154 77 Upravljavska komponenta Uvod v računalništvo v oblaku Oracle PaaS Arhitektura: Podatkovna komponenta: • Oracle Database, RAC, ASM, Partitioning, IMDB Cache, Active Data Guard, Database Security. Aplikacijska komponenta: • WebLogic Server, Coherence, Tuxedo, JRockit. Integracijska komponenta: • Oracle SOA Suite – omogoča izdelavo ponovno uporabljivih komponent znotraj privatnega oblaka PaaS. Komponenta upravljanja s procesi: • Oracle BPM Suite – orodje za upravljanje s poslovnimi procesi. 155 Oracle PaaS Arhitektura: Varnostna komponenta: • Identity Management – družina produktov, ki omogoča upravljanje z različnimi ponudniki identitet. Komponenta uporabniške interakcije: • WebCenter Suite – platforma za izdelavo spletnih aplikacij, portalov ter omrežij za socialno kolaboracijo. Deljene storitve: • Vključuje samopostrežni vmesnik in deljene komponente. Upravljavska komponenta: • Oracle Enterprise Manager – omogoča celovito upravljanje z življenjskim ciklom razvoja aplikacij. 156 78 Uvod v računalništvo v oblaku Oracle PaaS Upravljanje: • • • • Upravljanje z postavitvijo in izvajanjem aplikacij. Upravljanje s podatkovno shrambo. Spremljanje porabe in izvajanja. Upravljanje z življenjskim ciklom razvoja aplikacij (Oracle Enterprise Manager). • Upravljanje verzij. • Orodja: – Oracle Enterprise Manager – grafični administrativni vmesnik. Namestitveni modeli: P J H 157 VMware vFabric Uvod: • Platforma kot storitev (PaaS), ki je optimizirana za izvajanje Java Spring aplikacij. • Podpira integracijo s Springsource Tool Suite (STS). • Sestavljena je iz petih komponent: – – – – – Strežniška komponenta. Podatkovna komponenta. Sporočilna komponenta. Komponenta za razporejanje bremena. Komponenta za upravljanje in spremljanje. 158 79 Uvod v računalništvo v oblaku VMware vFabric Arhitektura: Komponenta za razporejanje bremena (ERS) Komponenta za upravljanje in spremljanje (Hyperic) Strežniška komponenta (tc Server) Sporočilna komponenta (RabbitMQ) Podatkovna komponenta (GemFire) 159 VMware vFabric Arhitektura: Strežniška komponenta: • VMware vFabric tc Server je osrednja komponenta VMware vFabric aplikacijske platforme PaaS. Tc Server v osnovi izhaja iz Apache Tomcat strežnika in mu dodaja značilnosti za prilagoditev poslovnega okolju, kot so dodane razvojne, operacijske in postavitvene zmogljivosti. Podatkovna komponenta: • VMware vFabric GemFire zagotavlja zavarovan, zanesljiv in skalabilen podatkovni nivo za gradnjo poslovnih aplikacij za oblak. Komponenta omogoča paralelno izvajanje podatkovno usmerjenih funkcionalnosti aplikacije nad porazdeljenim podatkovnim nivojem. 160 80 Uvod v računalništvo v oblaku VMware vFabric Arhitektura: Sporočilna komponenta: • RabbitMQ je odprtokodna rešitev, ki omogoča delovanje sporočilnih sistemov v vFabric platformi. Zgrajena je z namenom zagotavljanja zanesljivega in robustnega sporočilnega sistema v porazdeljenem okolju. RabbitMQ je implementacija AMQP protokola (Advance Messaging and Queuing Protocol). Komponenta za razporejanje bremena: • Enterprise Ready Server (ERS) je komponenta, ki zajema spletni strežnik in komponento za razporejanje bremena. Zagotavlja celovito in centralizirano upravljanje Apache HTTP strežnika in Apache Tomcat okolja. 161 VMware vFabric Arhitektura: Komponenta za upravljanje in spremljanje: • VMware vFabric Hyperic je nadzorna komponenta VMware vFabric aplikacijske platforme. Omogoča spremljanje razpoložljivosti in zmogljivostnih metrik postavljenih spletnih aplikacij. Omogoča avtomatizirano odkrivanje, dodajanje v repozitorij in pregled strežniških komponent, ne glede na tip in lokacijo. • Arhitekturo upravljalnega sistema sestavljajo tri komponente: – HQ Agent – komponenta, katero poganjamo na vseh strežniških instancah in je zadolžena za zbirajo metrik o razpoložljivosti, utilizaciji, performanci in metrik prepustnosti. – HQ Server strežnik – prejema zajete metrike in druge podatke, ter jih shranjuje v HQ Database repozitorij v obliki podatkovne baze. – HQ Database – omogoča mehanizem za izdelavo varnostnih kopij, obnove po incidentu, spremljanje delovanje baze, shrambo metrik, itn. 162 81 Uvod v računalništvo v oblaku VMware vFabric Upravljanje: • • • • • Upravljanje z izvajanjem in postavitvijo aplikacij. Upravljanje s podatkovno shrambo (relacijska baza, sporočilne vrste). Spremljanje porabe, razpoložljivosti in izvajanja. Upravljanje z repozitorijem slik. Upravljanje z opozorili. • Orodja: – VMware vFabric Hyperic – grafični administrativni vmesnik. – HQ Dashboard – nadzorna plošča, kjer so zbrani podatki o spremembah inventarja komponent, informacije o težavah, zadnjih opozorilih in metričnih pregledih pomembnih virov. Namestitveni modeli: P J H 163 WMware Cloud Foundry Uvod: • Zastonjska in odprtokodna platforma kot storitev, ki ponuja različna ogrodja, podpira več ponudnikov oblaka in številne aplikacijske storitve. • Cloud Foundry je ponujen uporabnikom v treh oblikah: – CloudFoundry.com – popoln, večnajemniško PaaS okolje, ki je gostovano in upravljano s strani VMware. Izvaja se na vSphere platformi in podpira razvoj Spring za javanske aplikacije, Rails in Sinatra za Ruby aplikacije, Node.js ter Grails aplikacije. – CloudFoundry.org – odprtokodni projekt, ki ga vzdržuje in razvija skupnost pod Apache License 2.0. Je IaaS agnostična platforma (vSphere, OpenStack, AWS in Eucalyptus). – Cloud Foundry mikro oblak – enojna razvijalska instanca, ki omogoča osebni PaaS na lastnih namizjih. Ponujen je kot prenosljiva slika • Arhitektura Cloud Foundry platforme se sestoji iz šestih komponent. 164 82 Uvod v računalništvo v oblaku WMware Cloud Foundry Arhitektura: Upravljavec zdravja Razvijalec Nadzornik oblaka (CC) DEA DEA … DEA Sporočilno vodilo Storitve Storitve Storitve Storitve Usmerjevalniki 165 WMware Cloud Foundry Arhitektura: Droplet izvajalni agent (DEA): • Zadolžen za izvajanje dropletov. Vsebuje vse objekte, ki sestavljajo aplikacijo in so organizirani kot tar datoteke ter ovite z parom start/stop skripte. DEA se izvaja na vsakem izmed vozlišč in je zadolžena za izvajanje aplikacije na tem vozlišču. Nadzornik oblaka (CC): • Vmesnik namenjen razvijalcem za dostop do Cloud Foundry platforme. CC je zadolžen za pakiranje aplikacije v Droplet in obvesti sporočilno vodilo, da je na voljo aplikacija za izvajanje. Usmerjevalniki: • Platforma ima bazen identičnih usmerjevalnikov. Le-ti prejmejo aplikacijske zahteve od zunanjih entitet in jih usmerjajo do naslovljenih aplikacij. Zahteve uporabnikov so usmerjene k enemu izmed usmerjevalnikov s strani izenačevalca obremenitev. Usmerjevalni nato preusmeri zahtevo k ustrezni aplikaciji. 166 83 Uvod v računalništvo v oblaku WMware Cloud Foundry Arhitektura: Upravljavec zdravja: • Zadolžen za zanesljive operacije platforme. Periodično skenira podatkovno bazo CC komponente, da bi ugotovil kakšno je stanje oblaka. Storitve: • Gre za nabor storitev, kot so sporočanje, predpomnjenje in storitve podatkovne baze (MySQL). Sporočilno vodilo: • Ponuja mehanizem preko katerega komunicirajo komponente Cloud Foundry platforme. 167 WMware Cloud Foundry Upravljanje: • • • • Upravljanje z oskrbovanjem instanc. Upravljanje z opozorili. Spremljanje stanja aplikacij. Upravljanje z življenjskim ciklom razvoja aplikacij. • Orodja: – Spletni portal za upravljanje in nadzor. Namestitveni modeli: P J H 168 84 Uvod v računalništvo v oblaku Force.com Uvod: • Ponuja platformo kot storitev za izdelavo in postavitev poslovnih aplikacij. • Ponuja vgrajene mobilne in socialne funkcionalnosti, poslovne procese, poročanje, iskanje, itn. • Ponudnik platforme skrbi za varnost, skalabilnost ter izdelavo varnostnih kopij. • Platforma je sestavljena iz sedmih komponent: – – – – – – – Infrastrukture. Podatkovne baze. Integracije. Logike. Uporabniškega vmesnika. Razvojnih orodij. AppExchange komponente. 169 Force.com Arhitektura: AppExchange Razvojna orodja Uporabniški vmesnik Logika Integracija Podatkovna baza Infrastruktura 170 85 Uvod v računalništvo v oblaku Force.com Arhitektura: Infrastruktura: • Predstavlja okolje za postavitev in izvajanje aplikacij. Sestavlja jo napreden in upravljan podatkovni center, ki uporablja sodobne tehnologije varnosti. Podatkovna baza: • Zgrajena na temeljih Force.com infrastrukture. Omogoča izdelavo metapodatkov, ki opisujejo objekte podatkovne baze, kot so tabele in polja. Integracija: • Platforma ponuja storitev za integracijo aplikacij z viri in aplikacijami, ki se nahajajo v lokalnih podatkovnih centrih in podatkovnih centrih drugih ponudnikov. Za te namene platforma ponuja Force.com Web Services API (podpira integracijo z Amazon Web Services, Facebook, in Google Apps). 171 Force.com Arhitektura: Logika: • Platforma omogoča avtomatizacijo poslovnih procesov. Workflow Engine omogoča ponovno uporabljive procese, kot so izdelava opravil, dodelitev opravil, časovne akcije ter dogodkovno gnano integracijo sistema. Naštete komponente je možno uporabiti pri poslovni logiki aplikacije. Uporabniški vmesnik: • Platforma ponuja dve možnosti za izdelavo GUI-ja: – Force.com builder – preprost vmesnik za izgradnjo in modificiranje uporabniškega vmesnika. – Visualforce – popolno ogrodje za izdelavo poljubnega grafičnega vmesnika za katerokoli napravo in aplikacijo. 172 86 Uvod v računalništvo v oblaku Force.com Arhitektura: Razvojna orodja: • Ponuja številna orodja in API-je za razvoj, postavitev in integracijo informacijskih sistemov (Force.com Metadata API, Force.com Integrated Development Environment (IDE), Force.com Sandbox ter Force.com Code Share). AppExchange: • Predstavlja portal, ki povezuje razvijalce aplikacij in potencialne kupce in uporabnike. Omogoča objavo certificiranih aplikacij s strani razvijalcev in na drugi strani najem aplikacij s strani končnih uporabnikov. 173 Force.com Upravljanje: • • • • • Upravljanje s podatkovno shrambo (relacijska baza). Spremljanje porabe in izvajanja aplikacij. Upravljanje življenjskega cikla razvoja aplikacij. Upravljanje s poslovnimi procesi. Upravljanje verzij. • Orodja: – Nadzorna plošča za upravljanje. Namestitveni modeli: P J H 174 87 Uvod v računalništvo v oblaku CloudBees Uvod: • Ponuja platformo kot storitev (PaaS) in omogoča razvoj, testiranje, postavitev in izvajanje javanskih spletnih aplikacij v oblaku. • Sestavljata jo dve temeljni komponenti RUN@cloud ter DEV@cloud. • Gre za IaaS agnostično platformo, saj lahko izbiramo med številnimi ponudniki infrastrukture kot storitve. • Ponuja „failover“ in HA podporo. • Za razvoj, postavitev in testiranje uporablja platforma Jenkins Continuous Integration strežnik. 175 CloudBees Arhitektura: DEV@cloud RUN@cloud Testiraj Izgradi Jenkins strežnik Testiraj PaaS, ki temelji na JVM Kontinuirana postavitev Shrani Git SVN Storitve MySQL Maven HA CloudBees Ekosistem - razširitve HTTP API-ji, CLI, grafični UI, vtičnik za Eclipse, Vtičnik za Maven, Ant 176 88 … Uvod v računalništvo v oblaku CloudBees Arhitektura: DEV@Cloud: • Ponuja nabor storitev za podporo celotnega življenjskega cikla razvoja aplikacij v oblaku. • Ponuja naročniško storitev za Jenkins strežnike, ki se izvajajo v oblaku. • Podpira privatne in varovane Maven repozitorije. • Ponuja upravljavske funkcije za varno administracijo privilegijev in pravil dostopa razvojne ekipe. • Omogoča uporabo SVN in Git repozitorijev. 177 CloudBees Arhitektura: RUN@Cloud: • Omogoča postavitev Javanskih aplikacij v oblak. • Ponuja izenačevanje obremenitev, avtomatično skalabilnost ter visoko razpoložljivost (HA) za spletne aplikacije, Java EE ter Spring aplikacije. • Ponuja storitve za zagotavljanje failover mehanizma, merjenja in zaračunavanja. • Ponuja RUN@cloud SDK kot kolekcijo orodij za razvoj in postavitev aplikacij na lokalnih računalnikih. • Za upravljanje RUN@cloud storitev ponuja RUN@cloud API. • Postavitev aplikacij je možna iz različnih okolij (UI, Eclipse, CLI, REST, Maven, Ant). 178 89 Uvod v računalništvo v oblaku CloudBees Upravljanje: • • • • • • Upravljanje z virtualnimi stroji. Upravljanje s podatkovno shrambo (relacijska MySQL baza). Spremljanje porabe in izvajanja. Upravljanje z failover mehanizmom in visoko razpoložljivostjo. Upravljanje avtomatične skalabilnosti. Upravljanje verzij. • Orodja: – Nadzorna plošča za upravljanje in nadzor v obliki spletnega portala. Namestitveni modeli: P J H 179 CumuLogic Uvod: • Predstavlja platformo kot storitev za razvoj Javanskih in Spring aplikacij za oblak. • Je IaaS agnostična platforma, saj ponuja možnost izbire med številnimi infrastrukturnimi produkti (Amazon EC2, VMware, Eucalyptus, OpenStack, itn.). • Platforma se sestoji iz desetih ključnih komponent. 180 90 Uvod v računalništvo v oblaku CumuLogic Arhitektura: Katalog storitev v oblaku Ogrodje vtičnik Komponenta za avtomatično skaliranje Komponenta za spremljanje zmogljivosti in analitiko Komponenta za upravljanje z viri Komponenta za upravljanje z uporabniki Strežnik podatkovne baze (SQL ali NoSQL) Aplikacijski strežnik Spletni strežnik Izenačevalec obremenitev RESTful API Integracija Sporočilne vrste Ogrodje za avtomatizacijo storitev Eclipse IDE, Dev Tools vtičniki CLI Administrativna konzola API za integracijo z IaaS nivojem 181 CumuLogic Arhitektura: API za integracijo z IaaS nivojem: • Omogoča integracijo z različnimi IaaS ponudniki, kot so VMware, Cloud.com, Eucalyptus, OpenStack in Amazon EC2. Ogrodje za avtomatizacijo storitev: • Vključuje izenačevalca obremenitve, spletni strežnik, aplikacijski strežnik, sporočilne vrste, relacijsko in NoSQL bazo. Komponenta za avtomatično skaliranje: • Vgrajen mehanizem za avtomatično skaliranje omogoča aplikacijam, da skalirajo in vzdržujejo želeno stopnjo performance. CumuLogic mehanizem za avtomatično skaliranje prejme metrike iz nivoja operacijskega sistema, infrastrukturnega nivoja, JVM nivoja in aplikacijskega nivoja, da bi zadovoljil potrebe po skaliranju. Komponenta za spremljanje zmogljivosti in analitiko: • Platforma podpira vgrajen mehanizem za spremljanje celotnega sklada platforme in aplikacije. 182 91 Uvod v računalništvo v oblaku CumuLogic Arhitektura: Komponenta za upravljanje z viri: • Omogoča administratorjem, da definirajo minimalno in maksimalno število vozlišč v vsaki gruči z razlogom, da bi aplikacija ustregla SLA zahtevam in skladno z njimi skalirala. Komponenta za upravljanje z uporabniki: • Omogoča nadzor nad pravicami uporabnikov glede na funkcionalne vloge PaaS okolja. Ogrodje vtičnik: • S pomočjo ogrodja vtičnik smejo razvijalci dodajati v katalog poljubne strežnike in jih deliti z ostalimi razvojnimi ekipami. Katalog storitev v oblaku: • Ponuja testirane infrastrukturne komponente za privatni in javni oblak. Razvijalci lahko dodajajo v katalog nove strežniške slike ali programsko opremo. 183 CumuLogic Arhitektura: RESTful API: • Razvijalcem daje nadzor nad postavitvijo aplikacij in omogoča integracijo z razvojnimi orodji. Razvojna orodja: • S pomočjo CumuLogic vtičnika za Eclipse lahko Java razvijalci postavijo in upravljajo aplikacijo neposredno iz razvojnega okolja. 184 92 Uvod v računalništvo v oblaku CumuLogic Upravljanje: • • • • • • • Upravljanje z oskrbovanjem instanc. Upravljanje konfiguracij. Upravljanje s podatkovno bazo (MySQL gruča). Spremljanje porabe in izvajanja aplikacij ter platforme. Upravljanje z življenjskim ciklom razvoja aplikacij. Upravljanje avtomatične skalabilnosti in SLA-jev. Upravljanje uporabnikov/vlog in politike. • Orodja: – Samopostrežni spletni portal – CLI orodja. Namestitveni modeli: P J H 185 AppScale Uvod: • Predstavlja odprtokodno platformo kot storitev, ki implementira številne API-je, kot so Google App Engine, MapReduce (preko Hadoop), MPI in druge. • AppScale se izvaja kot gostovan virtualni stroj (guestVM) na vseh slojih virtualizacije, ki lahko gostiijo Ubuntu Karmic sliko. • Trenutno sta podprta dva hipervizorja: Xen in KVM. • AppScale avtomatično postavlja aplikacije na Amazon EC2 javni oblak ter Eucalyptus privatni oblak. • Platformo sestavlja pet ključnih komponent: AppController (AC), AppLoadBalancer (ALB), AppServer (AS), komponenta upravljanja podatkov ter AppScale orodja. 186 93 Uvod v računalništvo v oblaku AppScale Arhitektura: Razvijalec GAE aplikacij (AppScale admin) Uporabnik GAE aplikacij DBM ALB AS AS AS DBS DBS DBS AppScale orodja AppController (AC) HTTPS 187 AppScale Arhitektura: AppController (AC) • Izvaja se na vsakem vozlišču in se zažene ob vsakem dvigu virtualnega stroja. AC v čelnem vozlišču je zadolžen za spremljanje postavitve in avtomatično skaliranje. AppLoadBalancer (ALB) • Zadolžen za distribucijo zahtevkov s strani uporabnika do posamezne AS komponente GAE aplikacije. Uporabniki običajno vzpostavijo stik z ALB ob prijavi in avtentikaciji. AppServer (AS) • Omogoča izvajanje GAE aplikacij na Xen gručah znotraj izbranega javnega oblaka (Amazon EC2 ali Eucalyptus). 188 94 Uvod v računalništvo v oblaku AppScale Arhitektura: Komponenta upravljanja podatkov • Za upravljanje s podatki je zadolžen PBServer in skrbi za komunikacijo z podprtimi podatkovnimi bazami. Deluje nad DBM (Database Master) in DBS (Database Slave) komponentami. • AppScale trenutno podpira številne podatkovne baze: Cassandra, HBase, Hypertable, MongoDB, MemcacheDB, Scalaris, SimpleDB, MySQL Cluster in Voldemort. AppScale orodja • Omogočajo izdelavo AppScale instance in postavitev GAE aplikacij na odprtokodno platformo. – Amazon’s EC2 tools for AWS. 189 AppScale Upravljanje: • Upravljanje z virtualnimi stroji. • Upravljanje s podatkovno shrambo (relacijska baza, NoSQL baza, blobi). • Spremljanje porabe in izvajanja aplikacij. • Upravljanje življenjskega cikla razvoja aplikacij. • Upravljanje z varnostnimi kopijami. • Orodja: – CLI orodja. Namestitveni modeli: P J H 190 95 Uvod v računalništvo v oblaku PROGRAMSKA OPREMA KOT STORITEV Definicija Zmožnost izvajanja aplikacije v infrastrukturi oblaka pri čemer je le-ta dostopna več odjemalcem (spletni brskalnik, mobilne in tablične naprave, …). Uporabnik pri tem ne rabi skrbeti za upravljanje ali nadzor nad spodaj-ležečo infrastrukturo oblaka, omrežjem, strežniki, operacijskim sistemom ter individualnimi aplikacijskimi zmožnostmi. Primeri: • • • • • Google Gmail, Yahoo! Mail, Hotmail, … Facebook, Twitter, LinkedIn, … Salesforce CRM, Oracle CRM On Demand Oracle Fusion Application Services … 192 96 Uvod v računalništvo v oblaku Osnovne karakteristike SaaS Dostop do programske opreme preko različnih odjemalcev: • Spletni brskalnik, mobilne in tablične naprave, namizje … Upravljanje aplikacije iz centralne lokacije. Aplikacija je dostavljena na dva različna načina: • Pay As You Go model • Naročnina (mesečna, celoletna, …) Uporabniki ne rabijo skrbeti za nadgradnje programske opreme in popravke. API-ji omogočajo integracijo med različnimi deli aplikacije. Elastično obnašanje aplikacije - samodejna skalabilnost. 193 Arhitektura Večina SaaS rešitev temelji na večnajemniški (Multi-tenant) arhitekturi. • Ena različica aplikacije z enojno konfiguracijo (strojna oprema, omrežje, operacijski sistem) je uporabljena za vse stranke. Za podporo skalabilnosti je SaaS aplikacija nameščena na več strojih znotraj podatkovnega centra (lahko tudi med različnimi PC). 194 97 Uvod v računalništvo v oblaku Poslovni model Zaračunavanje tradicionalne programske opreme: • Stalne licence, ki jih plačamo vnaprej Zaračunavanje SaaS aplikacij: • Običajno uporabljajo naročniški poslovni model (npr. mesečna ali celoletna naročnina) • Običajno so zaračunane preko parametrov uporabe (npr. število uporabnikov aplikacije) – Pay As You Go model. • Ker so podatki aplikacije v številnih primerih ravno tako hranjeni pri SaaS ponudniku, lahko le-ti zaračunavajo glede na parametre, kot so transakcije, količina shranjenih podatkov ter ostale enote. • Zaradi večnajemniške (Multi-tenant) arhitekture lahko ponudniki ponujajo aplikacije po zelo nizki cenah – včasih tudi brezplačno. – Gmail je brezplačen, saj je poslovni model osredotočen v oglaševanje. 195 Tržni delež namestitvenih modelov 196 98 Uvod v računalništvo v oblaku NAMESTITVENI MODELI Namestitveni modeli Javni oblak: • • • • • V lasti tretje organizacije, ki ga tudi upravlja. Na voljo širši javnosti, organizacijam, podjetjem… Ponuja nizko-cenovni “pay-as-you-go” model. Večji od RC znotraj podjetij -> skalabilnost na zahtevo. Primer: Amazon AWS, IBM SmartCloud, Windows Azure… 198 99 Uvod v računalništvo v oblaku Namestitveni modeli Privatni oblak: • Postavljeni izključno za posamezno organizacijo. • Večji nadzor nad podatki, za varnost skrbijo organizacije. • Dve možnosti: – “On-premise” privatni oblak (notranji) o o o o Znotraj podatkovnega centra organizacije. Omejen na velikost in skalabilnost. Visoki kapitalni ter operativni stroški. Primerni za aplikacije, ki zahtevajo popolni nadzor nad nastavitvijo infrastrukture ter varnostjo. – Zunanji privatni oblak o Postavljen zunaj organizacije, pri enem izmed ponudnikov računalništva v oblaku. o Ponudnik mora zagotoviti popolno zaupnost. o Primerna za organizacije, ki ne želijo uporabljati javnega oblaka zaradi deljenja fizičnih resursov. • Primer: OpenStack, Eucalyptus, Microsoft Hyper-V Cloud… 199 Namestitveni modeli Hibridni oblak: • Kompozicija dveh ali več oblakov (privatnega ali javnega), ki ohranjajo unikatne entitete. Vežejo jih standardizirane tehnologije, ki omogočajo portabilnost podatkov in aplikacij (npr. cloudbursting za izenačevanje obremenitev med oblaki). • Običajno gre za razširitev privatnega oblaka z viri, ki jih ponuja javni oblak (v primeru da pride do nepričakovanega povečanja bremena). 200 100 Uvod v računalništvo v oblaku Namestitveni modeli Pregled ponudnikov: Ponudniki Privatni oblak Javni oblak Hibridni oblak IBM x x x Oracle x x x Microsoft x x x VMware x x x HP x x x EMC x x x Cisco x Amazon x x Google x x RightScale x x TerraMark x x 201 UPORABA JAVNIH OBLAKOV 101 Uvod v računalništvo v oblaku Javni oblak Zagotavljanje dinamičnih virov preko interneta na samopostrežen način in plačevanje virov po porabi. Hibridni Privatni Javni 203 Javni oblak - IaaS Javni ponudniki na nivoju IaaS • • • • • • • • • • Amazon AWS (EC2, S3, SimpeDB, …) Rakspace Cloud IBM SmartCloud Joyent GoGrid Terremark FlexiScale ElasticHosts Enomaly OpSource 204 102 Uvod v računalništvo v oblaku Javni oblak - PaaS Javni ponudniki na nivoju PaaS • • • • • • Google App Engine Windows Azure AWS Elastic Beanstalk Oracle Public Cloud Force.com IBM SmartCloud 205 Dostopnost - Primer EC2 AWS Upravljana konzola Elasticfox razširitev za Firefox 206 103 Uvod v računalništvo v oblaku Dostopnost - Primer EC2 Razširitev za Razvojna okolja (Eclipse) Amazon EC2 AMI Tools EC2 QUERY, EC2 SOAP API 207 Tveganja Varnost • Nevarnost vdora (tako s strani ponudnika kot nekih tretjih organizacij). • Glede na raziskavo IDC je vidik varnosti prvi pomislek, ki ga organizacije imajo glede oblaka. Šele nato sledi dostopnost in zmogljivost. • Za manjša podjetja je z omejenimi finančnimi viri je lahko hramba podatkov v oblaku varnejša. Zasebnost in privatnost • Uporabniki nimajo nadzora nad podatki, ki jih ponudniki o njih zbirajo (Gmail - Oglaševanje). Priklepanje ponudnika (Vendor Lock-In) • Niso vsi viri enostavno prenosljivi med ponudniki. • Uporaba specifičnih sistemov za podatkovno shrambo (npr. BigTable). • Uporaba drugih specifičnih storitev (npr. Google Login service). • Uporaba specifične platforme PaaS (npr. Windows Azure). 208 104 Uvod v računalništvo v oblaku Tveganja Dostopnost • Za poslovne aplikacije je dostopnost kritičnega pomena. • V zadnjem letu je bilo precej odmevnih izpadov: – Azure (November 2011) – Amazon (April 2011) • Dostopnost je določena z SLA, kjer pa je potrebno biti pazljiv. Q: What does your Amazon EC2 Service Level Agreement guarantee? A: The Amazon EC2 SLA guarantees 99.95% availability of the service within a Region over a trailing 365 day period. • Ob izpadu Aprila 2011, so bile 4 dni težave z delovanjem EBS in RDS storitev (bločna shramba in relacijska podatkovna baza), ki so pogosto pogoj za delovanje aplikacij v EC2 instancah. • SLA ni bil prekršen, ker zajema samo EC2, ki pa je deloval normalno! 209 Tveganja Stabilnost zmogljivosti • Raziskave so pokazale da ponudniki še ne dosegajo ustreznega skaliranja. Test Amazona, Googla in Microsofta je pokazal, da je pri nenadnemu povečanju uporabnikov na 2000, odzivni čas variiral tudi za faktor 20! Omejitve omrežja • Delovanje storitev je odvisno od delovanja omrežja. • Zaradi nepredvidljivega odzivnega časa oblak ni primeren za določene aplikacije (npr. trgovanje z delnicami in valutami). • Prenos ogromnih količin podatkov je lahko dražji in traja dlje časa kot če klasične diske pošljemo s kurirsko službo. 210 105 Uvod v računalništvo v oblaku Prednosti Samopostrežba virov (Self Service) • Uporabnik si sam postreže z viri. • Spletni portal, ukazna vrstica, razširitve za razvijalce (Eclipse). Plačilo po porabi (Pay-as-you-Go) • Na podlagi različnih metrik se meri poraba. • Zmerjena poraba se zaračuna. Skalabilnost • Viri so elastični, navidezno neskončni • Dobili bomo toliko virov kot ji bomo potrebovali. Odpornost na napake in okrevanje ob izpadu • • • • Ni potrebno da sami zagotovimo te vidike. Samo-odpravljanje napak. Samodejna izdelava varnostnih kopij podatkov. Večkratna redundanca podatkov in aplikacije. 211 Prednosti Neodvisnost od lokacije uporabnika • Enostavna uporaba virov od doma, z mobilnih telefonov, tablic, … (Gmail). Specifičen kader za vzdrževanje storitev ni potreben Samodejno posodabljanje • Amazon RDS, SaaS Storitve, … Nižji stroški • Ni kapitalnih stroškov (CAPEX), samo operativni (OPEX). Poslovna agilnost • Nakup opreme je hiter. • Pohitri se čas na tržišče (Time to Market). • Pohitri se čas do ustvarjanja dobička (Time to Revenue). 212 106 Uvod v računalništvo v oblaku Prednosti - primeri Zahtevne simulacije • Izvedemo hitreje in ne kupujemo nepotrebne opreme. Razvoj aplikacij, testiranje in zagotavljanje kakovosti • Nakup specifičnih produktov potrebnih v času razvoja ni potreben. • Nakup fizične programske in strojne ni potreben za namene testiranja in zagotavljana kakovosti. – – – – Operacijski sistemi Različne strojne konfiguracije Različne verzije izvajalnih okolij Testiranje skaliranja Nepredvidljive potrebe po virih • Obisk spletnih trgovin pred prazniki, prodaja nogometnih vstopnic. 213 MIGRACIJA V OBLAK, PORTABILNOST IN IZHODNA STRATEGIJA 107 Uvod v računalništvo v oblaku Migracija obstoječih rešitev v oblak Gartner identificira pet načinov, kako migrirati aplikacije v oblak: • Ponovno gostovanje (Rehost): – Postavimo aplikacijo v drugo okolje strojne opreme in spremenimo infrastrukturne konfiguracije. – Prednost: Ponovno gostovanje aplikacije brez arhitekturnih sprememb in „refactoringa“ je hitra rešitev migracije v oblak (na nivoju IaaS). – Slabost: Ker arhitekture aplikacije ni potrebno spreminjati pa ne moremo polno koristiti karakteristik infrastrukture oblaka, kot je na primer skalabilnost. • Preurejanje (Refactoring): – Izvajanje aplikacije na infrastrukturi ponudnika oblaka. – Prednost: Razvijalci lahko ponovno uporabijo programske jezike, ogrodja in vsebnika v katere so investirali (na nivoju PaaS). – Slabost: Pomanjkanje zmožnosti, tranzitivno tveganje in zaklepanje v ogrodje (framework lock-in). 215 Migracija obstoječih rešitev v oblak Gartner identificira pet načinov, kako migrirati aplikacije v oblak: • Revizija (Revise): – Modificiramo ali razširimo obstoječo programsko kodo, da bi modernizirali „legacy“ sisteme. Nato uporabimo ponovno gostovanje (1) ali preurejanje (2) in tako postavimo aplikacijo v oblak. – Prednost: Omogoča organizacijam optimizirati aplikacijo, ki bo koristila karakteristike oblaka ponudnika. – Slabost: Takšen projekt bi zahteval veliko truda in stroškov, da bi mobilizirali razvojno ekipo. • Ponovna gradnja (Rebuild): – Ponovno zgradi aplikacijo na PaaS, odstrani kodo iz obstoječe aplikacije in ponovno načrtuj aplikacijo za oblak. – Prednost: Čeprav ponovna gradnja zahteva izgubo podobnosti z obstoječo kodo in ogrodji je njena prednost v inovativnih funkcionalnostih ponudnikove platforme. – Slabost: Na drugi strani pa je zaklepanje pri ponudniku največja slabost- V primeri, da ponudnik naredi tehnične ali cenovne spremembe, ki jih uporabnik ne more sprejeti, ali prekrši SLA, je uporabnik prisiljen zamenjati oziroma zapustiti nekatera ali vsa sredstva aplikacije. 216 108 Uvod v računalništvo v oblaku Migracija obstoječih rešitev v oblak Gartner identificira pet načinov, kako migrirati aplikacije v oblak: • Zamenjava (Replace): – Zavrži obstoječo aplikacijo ali nabor aplikacij in uporabi komercialno programsko opremo dostavljeno kot storitev (SaaS). – Prednost: Ta možnost se izogne investicijam potrebnih za mobiliziranje razvojne ekipe v primerih, ko se zahteve po poslovnih funkcionalnostih hitro zamenjajo. – Slabost: Nekonsistentna podatkovna semantika, težave pri dostopu do podatkov in zaklepanje pri ponudniku. 217 Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: 1 Faza evalvacije: • Finančna evalvacija (kalkulacija TCO in ROI). • Evalvacija varnosti in predpisov. • Tehnična evalvacija. • Identifikacija ponovno uporabljivih orodij. • Migracija licenčnih produktov. Faza evalvacije • Ustvari drevo odvisnosti • Ocena stroškov • Ocena arhitekture • Ocena varnosti 218 109 Uvod v računalništvo v oblaku Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: 2 Proof of Concept faza: • Preučitev AWS tehnologije. • Izdelava pilotne aplikacije in validacija tehnologije. • Testiranje obstoječe programske opreme v oblaku. Proof of Concept faza • Študija AWS • Izdelava pilota • Vzpostavitev podpore znotraj organizacije 219 Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: 3 Faza migracije podatkov: • Razumevanje različnih možnosti shrambe podatkov. • Migracija datotečnih strežnikov na Amazon S3. • Migracija komercialnih SUPB na EC2 + EBS. • Migracija MySQL na Amazon RDS. Faza migracije podatkov • Preizkus različnih možnosti shrambe • Migracija podatkov 220 110 Uvod v računalništvo v oblaku Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: 4 Faza migracije aplikacije: • Celostna migracijska strategija. • Hibridna migracijska strategija. • Izdelava AMI-jev za vsako komponento. Faza migracije aplikacije • Celostna migracija • Hibridna migracija 221 Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: 5 Faza uporabe oblaka: • Preizkus ostalih AWS storitev. • Avtomatizirana elastičnost in SDLC. • Izboljšana varnost. • Izdelava nadzorne plošče za upravljanje virov AWS. • Uporaba več dostopnih območij. Faza uporabe oblaka • Avtomatično skaliranje • Avtomatizacija • Elastičnost • Visoka stopnja dostopnosti 222 111 Uvod v računalništvo v oblaku Migracija obstoječih rešitev v oblak Amazon AWS predlaga šestfazni migracijski pristop: Faza optimizacije: 6 • Optimizacija uporabe na zahtevo. • Izboljšava učinkovitosti. • Implementacija naprednega spremljanja. • Re-inženiring aplikacije. Faza optimizacije • • • • • Utilizacija Spremljanje Učinkovitost Zmogljivost Ponovni inženiring 223 Migracija med IaaS platformami Migracija med Amazon EC2 in OpenStack: • Uporaba multi-cloud ogrodja jclouds zagotavlja enostavno migracijo Javanske aplikacije med Amazon EC2 in OpenStack instancami, brez potrebe po spreminjanju izvorne kode. Aplikacija jclouds OpenStack EC2 … 224 112 Uvod v računalništvo v oblaku Migracija med IaaS platformami Migracija med Amazon EC2 in OpenStack: • jclouds trenutno ponuja dve API abstrakciji: – Blobstore o Poenostavlja delo z key-value ponudniki, kot sta na primer Amazon S3 in Azure Storage Blobs. – Computeservice o Poenostavlja delo z upravljanjem virtualnih strojev v oblaku. Podprti produkti so Amazon EC2, Rackspace Cloud Servers, OpenStack, VMware vCloud API in RimuHosting VPS. 225 Migracija obstoječih rešitev na PaaS Primer migracije na Azure: Analiza Strategija Načrtovanje Izvedba migracije komponent Analiza: • Analiziramo trenutno stanje svoje tehnološke infrastrukture in aplikacij ter ocenimo na čem smo in hkrati, kje bi želeli biti v prihodnje. 226 113 Uvod v računalništvo v oblaku Migracija obstoječih rešitev na PaaS Primer migracije na Azure: Analiza Strategija Načrtovanje Izvedba migracije komponent Strategija: • Ko enkrat uspemo identificirati, katere oblačne prednosti razširljivost, elastičnost, rapidna postavitev itn. – nam bo najbolje ustrezala, želimo izbrati ocenjevalno ter migracijsko strategijo, ki bo najbolje ustrezala poslovnim potreba. 227 Migracija obstoječih rešitev na PaaS Primer migracije na Azure: Analiza Strategija Načrtovanje Izvedba migracije komponent Načrtovanje: • Ko so aplikacije enkrat identificirane kot del celotne strategije, je potrebno začeti razmišljati o njihovi arhitekturi in načrtovanju. 228 114 Uvod v računalništvo v oblaku Migracija obstoječih rešitev na PaaS Primer migracije na Azure: Analiza Strategija Načrtovanje Izvedba migracije komponent Izvedba migracije posameznih komponent: • Microsoft SQL Server migracija: – Premik velikih tabel v Azure Storage tabele. – Segmentacija podatkov preko več instanc SQL Azure Database. • NFS migracija: – Omrežni datotečni sistem migriramo v visoko razširljive Azure Storage blobe. • Migracija spletne aplikacije: – Aplikacija se preslika v spletne, delovne ali VM role. • Migracija sporočilne vrste – MSMQ: – Sporočilne vrste se preslikajo v Windows Azure Storage vrste. 229 Portabilnost med PaaS platformami Migracija aplikacij iz Windows Azure na Microsoft Private Cloud: Portabilnost aplikacije Portabilnost aplikacije Tradicionalni podatkovni center Privatni oblak Javni oblak • PaaS: Windows Azure Platform Appliance • IaaS: Hyper-V Cloud Identiteta Windows Server Active Directory Upravljanje System Center Razvoj Visual Studio, .NET 230 115 • PaaS: Windows Azure Platform Uvod v računalništvo v oblaku Portabilnost med PaaS platformami Migracija Javanskih aplikacij na GAE. URLFetch Service Aplikacija App Engine izvajalno okolje Obstoječa javanska aplikacija ? Blobstore Datastore Memcache 231 Portabilnost med PaaS platformami Migracija Javanskih aplikacij na GAE. • Migracija obstoječe (Java) aplikacije na Google App Engine ni nemogoča, je pa v številnih primerih potrebno narediti „refactoring“ programske kode. • Google App Engine v celoti ne podpira Java EE specifikacije in nima podpora za delo z relacijskimi podatkovnimi bazami. • Trenutna podpira: – – – – – – – – – Java Data Objects (JDO) Java Persistence API (JPA) Java Server Faces (JSF) 1.1 - 2.0 Java Server Pages (JSP) + JSTL Java Servlet API 2.4 JavaBeans™ Activation Framework (JAF) Java Architecture for XML Binding (JAXB) JavaMail XML API-ji za procesiranje (DOM, SAX in XSLT) 232 116 Uvod v računalništvo v oblaku Portabilnost med PaaS platformami Migracija Javanskih aplikacij na GAE. • Ne podpira naslednjih tehnologij: – – – – – – – – – Enterprise Java Beans (EJB) JAX-RPC JAX-WS Java Database Connectivity (JDBC) Java EE™ Connector Architecture (JCA) Java Management Extensions (JMX) Java Message Service (JMS) Java Naming and Directory Interface (JNDI) Remote Method Invocation (RMI) 233 Portabilnost med PaaS platformami Platforme, ki podpirajo razvoj Javanskih aplikacij: • • • • • • • • • • • • Google App Engine OpenShift FLEX (beta) IBM PaaS VMware vFabric Cloud Application Platform Oracle PaaS VMware Cloud Foundry AWS Elastic Beanstalk CloudBees Windows Azure CumuLogic Jelastic … 234 117 Uvod v računalništvo v oblaku Izhodna strategija Večina IaaS in PaaS ponudnikov uporablja unikatne in lastniške uporabniške vmesnike, API-je in podatkovne baze. Uporaba takšnih storitev v polni meri zahteva od uporabnikov, da programirajo v skladu s predpisanimi specifikacijami ponudnika. V primeru, da uporabniki storitev želijo zamenjati ponudnika iz kakršnegakoli razloga (nezadovoljstvo, ponudnik preneha poslovati) znajo naleteti na številne težave, predvsem zaradi nestandardiziranih formatov, na primer: • Prenos statičnih podatkov iz Amazon S3 na Azure Storage Blobs. Rešitev: • Uporaba multi-cloud ogrodij, ki zagotavljajo neodvisnost od ponudnika storitev oblaka: – jclouds (http://www.jclouds.org/) – Dasein Cloud API (http://dasein-cloud.sourceforge.net/) – Deltacloud (http://incubator.apache.org/deltacloud/)... • Standardizacija storitev oblaka. 235 SKLEP e-naslov: http://www.cloud.si e-naslov: http://www.soa.si e-pošta: [email protected] 236 118