MagmaFS - MagmaFS

Магмалық желі жүйесі
Magma logo.png
ӘзірлеушілерTx0
ЖазылғанC
Операциялық жүйеLinux және BSD ядролары
Қол жетімдіАғылшын
ТүріТаратылған файлдық жүйе
ЛицензияGNU GPL
Веб-сайтwww.magmafs.желі

Магма Бұл таратылған файлдық жүйе негізделген таратылған хэш-кесте, жазылған C, үйлесімді Linux және BSD ядроларды қолдану ТЫҚТЫРУ.

Терминология және негізгі принциптер

Магма а-мен байланысты бірнеше хосттарды байланыстырады TCP / IP а деп аталатын жалпы сақтау кеңістігін құру үшін желі лава сақинасы. Әр хост (немесе түйін) а деп аталады вулкан. Әрбір вулкан екіге бөлінген жалпы кілт кеңістігінің бөлігін орналастырады SHA1 кілттер. Әрбір вулкан қамтамасыз ету үшін алдыңғы түйіннің негізгі кеңістігін шағылыстыруға жауапты деректердің артық болуы. Әр перне сақтау кеңістігінде бір немесе бірнеше нысанды көрсете алады. Бұл нысандар деп аталады алау.

Магма объектілердің басқа диапазонын сақтай алады: файлдар, каталогтар, символдық сілтемелер, блокталған және электродталған құрылғылар, ФИФО құбырлары. Әрбір объект алауға байланысты және керісінше. Жоғарыда аталған алтылықтағы кез-келген типтегі алау барлық алауда кездесетін негізгі қасиеттерімен сипатталады, мысалы, жол және хэш кілті. Бірақ алты түрдің әрқайсысының өзіндік ерекше қасиеттері де бар. Мысалы, каталогтағы алауда символдық сілтемелерге қолданылмайтын белгілі бір ақпарат болады. Жалпылама ақпараты бар алау деп аталады жинақталмаған толық алау деп аталады актерлік құрам.

Тұтанбаған алауда деректермен жұмыс істеуге жеткілікті ақпарат жоқ, бірақ вулкан түйіндері арасында мөлдір емес контейнер ретінде жылжытылатын жеткілікті ақпарат бар. Жылдам қозғалу үшін, алаудың әр түрі, оның ішінде каталогтар, екі файлдар жиынтығы ретінде толықтырылды, біріншісінде алау туралы ақпарат (метадеректер), ал екіншісінде алау мазмұны бар. Алаулардың лава сақинасы бойынша қозғалуы деп аталады жүктемені теңдестіру және ең жақсы өнімділікті қамтамасыз ету үшін түйіндер арасындағы жүктеме теңсіздігін көтеру үшін жасалады.

Алаулар жүйесі

Магманың ішкі қозғалтқышы деп аталады алау жүйесі және қабатты стек ретінде жүзеге асырылады.

Алаулар жүйесінің қабаттары
1.Жалпыға ортақ API: flare_system_init (), magma_open (), magma_mknod (), magma_lstat (), ...
2.Лавалық желі: magma_new_node (), route_key (), join_network ()
3.Алау объектілері: magma_new_flare (), magma_search_or_create (), magma_add_to_cache (), ...

magma_mkdir () қабаттарын өту мысалы ретінде қолдануға болады. Осы абзацта каталог деп аталатын болады / мысал жасалады. magma_mkdir () бөлігі болып табылады Жалпыға ортақ API қабат. Ол стандарт бойынша жасалынған жаңа каталог құру үшін қолданылады Libc әріптесі mkdir ().

magma_mkdir () бірінші кезекте сұранысты жергілікті басқаруға болатындығын немесе желілік әрекеттерді қажет ететіндігін шешеді. Маршруттауды, жолды орындау үшін / мысал сәйкес SHA1 хэш-кілтінде аударылады 81f762fd59d88768b06b8e9de56aef8a95962045. Егер маршруттау басқа вулкан түйінімен байланысу қажеттілігін анықтаса, сұраныс бұл қабатты қалдырмайды. Лаваның желілік деңгейі сұранысты қашықтағы түйіндегі операциялар ағымын жалғастыра отырып, кілтке ие түйінге жібереді. Маршруттау рөлінің жартысын құрайды Лава желісі қабаты, оған желілік бақылау және вулкан түйіндерін құру, жаңарту және жою кіреді.

Жергілікті немесе қашықтағы сұраныс бола отырып, соңғы қадам орындалады Алау қабаты. Кілтке сәйкес келетін алау 81f762fd59d88768b06b8e9de56aef8a95962045 кэш ішінде ізделетін болады. Егер табылмаса, ол жасалады және бар болса, дискіден жүктеледі. Алынған алау объектісінде алдымен рұқсатты тексеру сынақтары қолданылады. Егер жұмыс істеуге рұқсат берілсе, алғашқы сұраныс орындалады: бұл мысалда алау каталогқа жіберіліп, егер ол болмаса және дискіге сақталса.

Маршруттау

Әрбір вулкан түйінінде толық желілік топология бар болғандықтан, маршруттау алау пернелерін түйіндер кеңістігімен сәйкестендіріп, алауды ұстап тұрған түйінді табуға қатысты. Желілік топология таратылған каталогта да сақталады /.dht/ магма файлдық жүйесінде. Вулкан түйіндері мезгіл-мезгіл өз ақпараттарын мазмұнымен салыстырып тексере алады /.dht/ бірдеңе өзгергенін білу үшін каталог. Түйіндер сонымен қатар ішіндегі өз ақпараттарын мезгіл-мезгіл сақтайды /.dht/ анықтамалық.

Жүктемелерді теңдестіру

Әрбір вулкан түйінінде өткізу қабілеті мен сақтау орны сияқты жүктеу кезінде жарияланған кейбір параметрлер бар. Бөлек жіп деп аталады теңдестіруші түйіндердің шамадан тыс жүктелуіне немесе жүктелуіне жол бермеу үшін кілттерді таратуға арналған. Әр түйіннің мына формуламен есептелетін динамикалық жүктеме мәні бар:

қайда логарифмдік шкала бойынша есептелген түйін кілтінің жүктемесі; түйіннің өткізу қабілеттілігі және орташа өткізу қабілеттілігі; түйінді сақтау және орташа сақтау болып табылады

Магмалық бағдарламалық қамтамасыз етуді тарату

Магма деп аталатын сервер түрінде таратылады магмад және клиент қоңырау шалды магма.

Магма-сервер

Магма-сервер магмад DHT түйіндері мен магма клиенттерінің арасындағы байланысты басқарады. Алаулар жүйесі кіріс қосылымдарын қабылдайтын желілік оқиғалар циклін ұсынады. Қосылудың үш түрі қабылданады.

  • Алаулар хаттамасының қосылымы алауда жұмыс істеу үшін қолданылады: файлдар мен каталогты ашу, оқу және жазу, теңгерімдеу операциялары кезінде ақпарат алу және алмасу. Алаулар хаттамасы - екілік хаттама.
  • Интернод протоколының қосылымы DHT ақпаратымен алмасу және жаңа түйіндерге қосылу үшін қолданылады. Интерноде хаттамасы - екілік хаттама.
  • Консольдық протокол қосылымы лаваларға сұраныс жіберуге, каталогтардың мазмұнын тізімдеу сияқты қарапайым әрекеттерді орындауға және файл мазмұнын көрсетуге және түйіндерге кейбір әкімшілік командаларды беруге мүмкіндік беру үшін қолданылады (әкімшілік команданың мысалы: өшіру). Консольдық протокол - бұл мәтіндік протокол арқылы қол жетімді Телнет.

Магма клиенті

Магма клиенті магма негізделген ТЫҚТЫРУ, Linux және BSD ядроларымен үйлесімді. Магма клиенті жақын магма серверімен байланысып, жұмыс істеу үшін алау хаттамасының қосылымын пайдаланады. Желілік топология және алаудың орналасуы клиенттер үшін мүлдем ашық. Клиент бір серверден нақты түрде сұрайды, өйткені барлық ақпарат тек сол хостта орналасқан.

Магма клиенті үшін шифрлауға мүмкіндік беретін криптографиялық деңгей жоспарланған. Клиенттік жағында криптографияны енгізу масштабталуға байланысты (есептеу қуаты есептеу сұранысының жылдамдығында жоғарылайды) және криптографиялық кілттердің құпиялылығымен (кілттер немесе құпия фразалар ешқашан серверге жетпейді).

Балама NFS интерфейсі

Magma клиентіне балама ретінде, оны тек Linux және BSD ядролары қолдайды, Magma сервері NFS басқа Unices үшін интерфейс. NFS белгіленген стандарт болғандықтан, ешқандай жаңа мүмкіндіктер қосуға болмайды. Мысалы, NFS арқылы клиенттерге орнатылатын магма акцияларына криптографиялық қабат қол жетімді болмайды.

Сыртқы сілтемелер

  • [1] - MagmaFS үй сайты.