Multiprocessing ( Multiprocessing , Multiprocessing , English Multiprocessing ) - parin tai useamman fyysisen prosessorin käyttö yhdessä tietokonejärjestelmässä .
Laitetta kutsutaan moniprosessoriksi , jos siinä on kaksi tai useampi fyysinen prosessori .
Käyttöjärjestelmää tai ohjelmaa kutsutaan moniprosessoriksi, jos se pystyy jakamaan tehtäviä prosessorien välillä (katso monisäikeisyys ).
Tästä konseptista on monia muunnelmia, ja moniprosessoinnin määritelmä voi vaihdella kontekstin mukaan, pääasiassa riippuen siitä, miten prosessorit on määritelty ( monta ydintä yhdessä sirussa , monta sirua yhdessä paketissa, monta pakettia yhdessä järjestelmämoduulissa ja niin edelleen ).
Moniprosessointia kutsutaan joskus useiden rinnakkaisten ohjelmistoprosessien suorittamiseksi järjestelmässä, toisin kuin yksittäisen prosessin suorittamiseksi milloin tahansa. Termit moniajo tai moniohjelmointi sopivat kuitenkin paremmin kuvaamaan tätä enimmäkseen ohjelmistossa toteutettua käsitettä, kun taas moniprosessointi sopii paremmin kuvaamaan useiden laitteistoprosessorien käyttöä. Järjestelmä ei voi olla sekä moniprosessorinen että moniohjelmoitu, vain toinen näistä kahdesta tai ei kumpaakaan.
Moniprosessorijärjestelmässä kaikki prosessorit voivat olla samanarvoisia tai osa niistä voi olla varattu erityistarkoituksiin. Laitteiston ja käyttöjärjestelmän ohjelmistosuunnittelunäkökohtien yhdistelmä määrittää symmetrian (tai sen puutteen) tietyssä järjestelmässä. Esimerkiksi laitteisto- tai ohjelmistonäkökohdat voivat edellyttää, että vain yksi keskusprosessori vastaa kaikkiin laitteiston keskeytyksiin, kun taas kaikki muu järjestelmässä tehtävä työ voidaan jakaa tasaisesti prosessorien kesken; tai etuoikeutetun tilan koodin suorittaminen voidaan rajoittaa vain yhteen prosessoriin (tai tiettyyn prosessoriin tai vain yhteen prosessoriin kerrallaan), kun taas etuoikeutetun tilan koodi voidaan suorittaa missä tahansa prosessorien yhdistelmässä. Usein moniprosessorijärjestelmiä on helpompi suunnitella, jos tällaisia rajoituksia asetetaan , mutta ne ovat yleensä vähemmän tehokkaita kuin järjestelmät, jotka käyttävät kaikkia suorittimia.
Järjestelmiä, jotka käsittelevät kaikkia suorittimia samalla tavalla, kutsutaan symmetrisiksi monikäsittelyjärjestelmiksi (SMP). Järjestelmissä, joissa kaikki prosessorit eivät ole samanarvoisia, järjestelmäresurssit voidaan jakaa monilla tavoilla, mukaan lukien epäsymmetrinen moniprosessointi ( ASMP ), epäyhtenäinen muistin käyttömonikäsittely (NUMA) ja klusteroitu moniprosessointi (qq.v.).
Monikäsittelyssä prosessoreita voidaan käyttää suorittamaan yksi käskysarja useissa yhteyksissä (yksi konekäsky , useita tietoja tai SIMD , usein käytetty vektorikäsittelyssä), useita käskysarjoja yhdessä kontekstissa ("useita käskyvirtaa, yksi tietovirta" " tai MISD-arkkitehtuuri , jota käytetään vikasietoisissa järjestelmissä redundanssiin ja joskus kuvaamaan liukuhihnaprosessoreja tai hypersäikeistystä ), tai useita käskysekvenssejä useissa yhteyksissä ("useita käskyvirtaa, useita tietovirtaa" tai MIMD ).
Tiiviisti kytketyt moniprosessorijärjestelmät sisältävät useita prosessoreita, jotka on kytketty väylätasolla . Näillä prosessoreilla voi olla pääsy keskusmuistiin (SMP tai UMA), tai ne voivat osallistua muistihierarkiaan sekä paikallisen että jaetun muistin (NUMA) kanssa. IBM p690 Regatta on esimerkki tehokkaasta SMP-järjestelmästä. Intel Xeon -prosessori hallitsi yritystietokoneiden moniprosessorimarkkinoita ja oli ainoa x86 - vaihtoehto, kunnes AMD:n Opteron-prosessorilinja julkaistiin vuonna 2004. Molemmilla prosessorisarjoilla oli oma siruvälimuisti , mutta ne tarjoavat pääsyn jaettuun muistiin eri tavoin: Xeon-prosessorit yhteisen kanavan kautta ja Opteron-prosessorit itsenäisten väyläjen kautta järjestelmän RAM-muistiin.
Moniprosessorisirut (moniytiminen) sisältävät useamman kuin yhden prosessorin yhdelle sirulle, ja niitä voidaan pitää tiukasti kytketyn moniprosessoinnin äärimmäisimpänä muotona. Mainframe- järjestelmät, joissa on useita prosessoreita, ovat usein erittäin kytkettyjä järjestelmiä.
Löyhästi kytketyt moniprosessorijärjestelmät , joita usein kutsutaan klustereiksi , perustuvat useisiin erillisiin yksittäisiin tai kahteen tietokoneeseen, jotka on yhdistetty nopean tietoliikennejärjestelmän (kuten Gigabit Ethernet ) kautta . Linuxia käyttävä Beowulf -klusteri on esimerkki joustavasti yhdistetystä järjestelmästä.
Tiiviisti kytketyt järjestelmät toimivat paremmin ja ovat fyysisesti pienempiä kuin joustavasti kytketyt järjestelmät, mutta ne ovat historiallisesti vaatineet suuria alkuinvestointeja ja voivat heiketä nopeasti . joustavasti yhdistetyn järjestelmän solmut ovat yleensä halpoja tietokoneita ja niitä voidaan käyttää itsenäisinä koneina, kun ne poistetaan klusterista.
Tiiviisti kytketyt järjestelmät ovat yleensä paljon energiatehokkaampia kuin klusterit. Huomattava energiatehokkuus saavutetaan, kun tällaisten järjestelmien komponentit on valmiiksi suunniteltu toimimaan tietyssä järjestelmässä, kun taas joustavasti kytketyissä järjestelmissä käytetään usein komponentteja, jotka on suunniteltu toimimaan laajemmassa järjestelmäluokassa.
Tietokoneessa, jossa on yksi käskyvirta ja yksi tietovirta, yksi prosessori käsittelee käskyt peräkkäin; jokainen konekäsky käsittelee yhden tietoelementin. Esimerkkinä on von Neumann - arkkitehtuuri .
Tietokoneessa, jossa on yksi käskyvirta ja useita tietovirtoja, yksi prosessori käsittelee käskyvirran, joista jokainen voi suorittaa rinnakkaisia laskelmia datajoukolle.
SIMD-monikäsittely soveltuu hyvin rinnakkais- tai vektorikäsittelyyn, jossa suuri joukko dataa voidaan jakaa osiin, jotka käsitellään identtisillä mutta itsenäisillä operaatioilla. Yksi käskyvirta ohjaa moniohjelmointimoduulien toiminnan suorittamaan samanlaisia käsittelyjä samanaikaisesti mahdollisesti suurelle datamäärälle.
Tietyntyyppisissä laskentasovelluksissa tämän tyyppinen arkkitehtuuri voi parantaa huomattavasti suorituskykyä käytetyn ajan suhteen. Tämän arkkitehtuurin haittana on kuitenkin se, että suurin osa järjestelmästä jää käyttämättömäksi suorittaessaan ohjelmia tai järjestelmätehtäviä, joita ei voida jakaa rinnakkain prosessoitaviin moduuleihin (alitehtäviin).
Lisäksi ohjelmien tulee olla huolellisesti ja täsmällisesti kirjoitettuja, jotta ne voivat hyödyntää arkkitehtuurin ominaisuuksia täysimääräisesti. Usein on olemassa erityisiä optimoivia kääntäjiä, jotka on suunniteltu tuottamaan koodia erityisesti käytettäväksi tässä ympäristössä. Jotkut tämän luokan kääntäjät tarjoavat erikoisrakenteita tai laajennuksia, joiden avulla ohjelmoijat voivat suoraan määritellä rinnakkain suoritettavat toiminnot (esimerkiksi Fortranin DO FOR ALL -käskyt, joita käytettiin ILLIAC IV :ssä , joka oli SIMD-arkkitehtuurin moniprosessorinen supertietokone).
SIMD-monikäsittelyllä on laaja sovellus joillakin alueilla, kuten tietokonesimulaatioissa , mutta siitä ei ole juurikaan hyötyä yleiskäyttöisissä työpöytä- ja yrityssovelluksissa.
Moniprosessointi usealla käskyvirralla ja yksittäisellä tietovirralla tarjoaa pääasiassa redundanssin etuna, koska moniohjelmointimoduulit suorittavat samat tehtävät samoilla tiedoilla, mikä vähentää virheellisten tulosten mahdollisuutta, jos jokin moduuleista epäonnistuu. MISD-arkkitehtuurin avulla voit verrata laskelmien tuloksia vikojen havaitsemiseksi. Redundanssin ja vikasietoisuuden lisäksi tämäntyyppisellä moniprosessoinnilla on vain vähän etuja. Lisäksi se on erittäin kallista. Se ei lisää suorituskykyä.
MIMD-moniprosessointiarkkitehtuuri soveltuu monenlaisiin tehtäviin, jotka toteuttavat eri tietojoukkoja koskevien käskyjen täysin itsenäisen ja rinnakkaisen suorituksen. Tästä syystä ja koska se on yksinkertainen toteuttaa, MIMD hallitsee moniprosessointia.
Prosessointi on jaettu useisiin säikeisiin, joista jokaisella on oma prosessorin laitteistotila, yhden ohjelmiston määrittämän prosessin sisällä tai useiden prosessien kesken. Koska järjestelmässä on useita suorittamista odottavia säikeitä (järjestelmä- tai käyttäjäsäikeitä), tämä arkkitehtuuri käyttää tehokkaasti laitteistoresursseja.
MIMD:ssä voi syntyä umpikuja- ja resurssikilpaongelmia, koska resursseihin pääsyä yrittävät säikeet voivat törmätä arvaamattomilla tavoilla. MIMD vaatii erityistä koodausta tietokoneen käyttöjärjestelmässä, mutta ei vaadi muutoksia sovellusohjelmiin, elleivät ohjelmat itse käytä useita säikeitä (MIMD on läpinäkyvä yksisäikeisille ohjelmille useimmissa käyttöjärjestelmissä, jos ohjelmat eivät itse kiellä ohjausta OS). Sekä järjestelmä- että käyttäjäohjelmistojen on ehkä käytettävä ohjelmointirakenteita, kuten semaforeja , jotta yksi säie ei häiritse toista, jos niillä on viittaus samaan dataan. Tämä lisää koodin monimutkaisuutta, heikentää suorituskykyä ja lisää huomattavasti vaadittavan testauksen määrää, vaikkakaan se ei yleensä riitä poistamaan moniprosessoinnin etuja.
Tällaisia ristiriitoja voi syntyä prosessorien välillä laitteistotasolla, ja ne tulisi yleensä ratkaista laitteistossa tai ohjelmiston ja laitteiston yhdistelmällä.