Jaettu muisti

Jaettu muisti on nopein  tapa vaihtaa tietoja prosessien välillä [1] .

Muissa prosessienvälisissä viestintätyökaluissa ( IPC ) prosessien välinen viestintä kulkee ytimen kautta , mikä johtaa kontekstin vaihtoon prosessin ja ytimen välillä, ts. suorituskyvyn menetyksiin [2] .

Jaettu muistitekniikka mahdollistaa tietojen vaihdon jaetun muistisegmentin kautta prosesseja varten ilman ytimen järjestelmäkutsuja. Jaettu muistisegmentti on kytketty prosessin virtuaalisen osoiteavaruuden vapaaseen osaan [3] . Näin ollen kahdella eri prosessilla voi olla eri osoitteet samasta jaetun muistin sijainnista.

Lyhyt kuvaus työstä

Jaetun muistisegmentin luomisen jälkeen mikä tahansa käyttäjäprosessi voi liittää sen omaan virtuaalitilaansa ja työskennellä sen kanssa kuten tavallisen muistisegmentin kanssa. Tällaisen tiedonvaihdon haittapuolena on synkronointikeinojen puuttuminen, mutta tämän haitan voittamiseksi voidaan käyttää semaforitekniikkaa .

Asiakas-palvelin-teknologian käyttöönotto

Kahden prosessin ( asiakas ja palvelin ) välisessä tiedonvaihdossa jaetun muistin avulla kahden semaforin ryhmän on toimittava. Ensimmäistä semaforia käytetään estämään pääsy jaettuun muistiin, sen aktivointisignaali on 1 ja sen estosignaali on 0. Toista semaforia käytetään ilmoittamaan palvelimelle, että asiakas on aloittanut työn, kun taas pääsy jaettuun muistiin on estetty, ja asiakas lukee tietoja muistista. Nyt kun palvelin kutsuu toiminnon, sen työ keskeytyy, kunnes asiakas vapauttaa muistin.

Jaetun muistin skenaario

  1. Palvelin käyttää jaettua muistia semaforin avulla.
  2. Palvelin kirjoittaa tiedot jaettuun muistiin.
  3. Kun tietojen kirjoitus on valmis, palvelin vapauttaa pääsyn jaettuun muistiin semaforin avulla.
  4. Asiakas käyttää jaettua muistia lukitsemalla pääsyn tähän muistiin muille prosesseille semaforin avulla.
  5. Asiakas lukee tietoja jaetusta muistista ja vapauttaa sitten muistin semaforin avulla.

Ohjelmiston toteutus

Ohjelmistossa jaettua muistia kutsutaan nimellä:

Koska molemmat prosessit voivat käyttää jaettua muistialuetta normaalina muistina, se on erittäin nopea tapa kommunikoida (toisin kuin muut IPC-mekanismit, kuten nimetyt putket , UNIX-pistokkeet tai CORBA ). Toisaalta tämä menetelmä on vähemmän joustava, esimerkiksi viestintäprosessien on oltava käynnissä samassa koneessa (luetelluista IPC-menetelmistä vain verkkopistokkeet, joita ei pidä sekoittaa UNIX-verkkoalueen pistokkeisiin, voivat kommunikoida verkon yli) , ja on huolehdittava ongelmien välttämisestä käytettäessä jaettua muistia eri prosessoriytimissä ja laitteistoarkkitehtuurissa ilman yhtenäistä välimuistia .

Jaetun muistin tiedonsiirtoa käytetään esimerkiksi kuvien siirtämiseen sovelluksen ja X-palvelimen välillä Unix-järjestelmissä tai CoMarshalInterThreadInterfaceInStreamin palauttaman IStream-objektin sisällä Windowsin COM-kirjastossa.

Jaetut kirjastot ladataan tavallisesti muistiin kerran ja kartoitetaan useiden prosessien kesken, ja vain yhdelle prosessille ominaiset sivut (koska jotkin tunnukset eroavat toisistaan) monistetaan, yleensä mekanismilla, joka tunnetaan nimellä copy-on-write . jaettuun muistiin, hiljaa kirjoitusta kutsuvaan prosessiin, kopioi muistin sivut ja kirjoittaa sitten tiedot kyseiseen kopioon.

UNIX-tyyppisissä käyttöjärjestelmissä

POSIX tarjoaa standardoidun sovellusliittymän jaetun muistin kanssa työskentelemiseen, POSIX Shared Memory . Yksi UNIX -käyttöjärjestelmien avainominaisuuksista on prosessin kopiointimekanismi (järjestelmäkutsu fork()), jonka avulla voit luoda jaetun muistin nimettömiä alueita ennen prosessin kopioimista ja periä ne jälkeläisille prosesseille. Kun prosessi on kopioitu, jaettu muisti on sekä vanhemman että lapsiprosessin käytettävissä. [3] [4]

Jaetun muistin yhdistämiseen ja käyttämiseen on kaksi erilaista tapaa:

UNIX System V -tyylinen jaettu muisti

UNIX System V sisältää joukon C-kielen toimintoja, joiden avulla voit työskennellä jaetun muistin kanssa [7] :

  • shmget — kokonaislukutunnisteeseen sidotun jaetun muistisegmentin tai anonyymin jaetun muistisegmentin luominen (jos IPC_PRIVATE-arvo määritetään tunnisteen sijaan) [8] ;
  • shmctl - muistisegmentin parametrien asettaminen [9] ;
  • shmat - segmentin liittäminen prosessin osoiteavaruuteen [4] ;
  • shmdt - segmentin irrottaminen prosessin osoiteavaruudesta [10] .

Nimetty jaettu muisti tarkoittaa, että jokaiseen muistipaikkaan liittyy käyttöjärjestelmässä ainutlaatuinen numeroavain, jota voidaan myöhemmin käyttää jaetun muistin yhdistämiseen toisessa prosessissa. [kahdeksan]

POSIX jaettu muisti

POSIX antaa sinun liittää tiedostokuvaajan jaettuun muistiobjektiin , joka on yhtenäisempi mekanismi kuin UNIX System V. Seuraavia C-kielen toimintoja voidaan käyttää muistin käsittelyyn:

  • shm_open— POSIX -jaetun muistiobjektin  luominen tai yhdistäminen sen nimellä [6] ;
  • shm_unlink — jaetun muistiobjektin poistaminen sen nimellä (tässä tapauksessa jaettu muistisegmentti on olemassa, kunnes se katkaistaan ​​kaikista prosesseista) [11] ;
  • ftruncate - asettaa tai muuttaa jaetun muistin (tai muistiin yhdistetyn tiedoston) kokoa [12] ;
  • mmap — liittää olemassa olevan tai luo nimettömän jaetun muistisegmentin prosessin osoiteavaruuteen [3] .
Windows -perheen käyttöjärjestelmissä

Windows- käyttöjärjestelmässä MSDNCreateFileMapping :n toimintoja ja MapViewOfFile[13] : a käytetään jaetun muistin luomiseen .

Ohjelmointikielien tuki

Jotkut C++-kirjastot tarjoavat käyttöympäristöjen välisen pääsyn jaettuun muistiin . Esimerkiksi Boost -kirjasto tarjoaa luokan boost::interprocess::shared_memory_object[14] POSIX-yhteensopiville käyttöjärjestelmille , ja Qt -kirjasto tarjoaa luokan QSharedMemory, joka yhdistää pääsyn jaettuun muistiin eri käyttöjärjestelmissä tietyin rajoituksin [15] .

Java 7 : ssä GNU/Linux - käyttöjärjestelmässä jaettu muisti voidaan toteuttaa yhdistämällä tiedosto hakemistosta /dev/shm/(tai /run/shm/jakelusta riippuen) muistiin [16] käyttämällä mapluokkamenetelmää java.nio.MappedByteBuffer[17] .

Jaetun muistin tuki on otettu käyttöön monissa muissa ohjelmointikielissä . Siten PHP tarjoaa API :n [18] jaetun muistin luomiseen, jonka toiminnot ovat samanlaisia ​​kuin POSIX .

Katso myös

Muistiinpanot

  1. Kolisnichenko Denis Nikolaevich. Linux - sovellusten kehittäminen . - BHV-Petersburg, 1.1.2012. - 430 s. — ISBN 9785977507479 . Arkistoitu 23. heinäkuuta 2016 Wayback Machineen
  2. Hyok-Sung Choi, Hee-Chul Yun. Kontekstin vaihtaminen ja IPC:n suorituskyvyn vertailu uClinuxin ja Linuxin välillä ARM9-pohjaisessa prosessorissa  //  Samsung Electronics: Technical Report. - 2004. Arkistoitu 6. maaliskuuta 2016.
  3. ↑ 1 2 3 mm kartta . pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 6. joulukuuta 2015.
  4. ↑ 12 shmat . _ pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 30. joulukuuta 2015.
  5. Järjestelmäliitännät Luku 2 . pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 8. tammikuuta 2016.
  6. ↑ 12 shm_open . _ pubs.opengroup.org. Käyttöpäivä: 3. tammikuuta 2016. Arkistoitu alkuperäisestä 21. marraskuuta 2015.
  7. Kay A. Robbins. UNIX-järjestelmien ohjelmointi: viestintä, samanaikaisuus ja säikeet . - Prentice Hall PTR, 2003. - s. 512. Arkistoitu 22. syyskuuta 2014 Wayback Machinessa
  8. ↑ 12 shmget . _ pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 5. maaliskuuta 2016.
  9. shmctl . pubs.opengroup.org. Käyttöpäivä: 3. tammikuuta 2016. Arkistoitu alkuperäisestä 7. joulukuuta 2015.
  10. shmdt . pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 12. joulukuuta 2015.
  11. shm_unlink . pubs.opengroup.org. Haettu 3. tammikuuta 2016. Arkistoitu alkuperäisestä 9. marraskuuta 2015.
  12. lyhennä . pubs.opengroup.org. Käyttöpäivä: 3. tammikuuta 2016. Arkistoitu alkuperäisestä 1. helmikuuta 2016.
  13. Nimetyn jaetun muistin luominen . Haettu 26. kesäkuuta 2014. Arkistoitu alkuperäisestä 5. kesäkuuta 2014.
  14. Muistin jakaminen prosessien välillä - 1.60.0 . www.boost.org. Käyttöpäivä: 4. tammikuuta 2016. Arkistoitu alkuperäisestä 29. joulukuuta 2015.
  15. QSharedMemory Class | Qt Core 5.5 . doc.qt.io. Käyttöpäivä: 4. tammikuuta 2016. Arkistoitu alkuperäisestä 7. joulukuuta 2015.
  16. shm_overview(7) - Linux-käyttöopassivu . man7.org. Käyttöpäivä: 4. tammikuuta 2016. Arkistoitu alkuperäisestä 4. tammikuuta 2016.
  17. MappedByteBuffer (Java Platform SE 7) . docs.oracle.com. Käyttöpäivä: 4. tammikuuta 2016. Arkistoitu alkuperäisestä 15. tammikuuta 2016.
  18. Jaetut muistitoiminnot PHP-API:ssa . Haettu 26. kesäkuuta 2014. Arkistoitu alkuperäisestä 25. kesäkuuta 2014.