Научная статья на тему 'Разработка модуля оптимального размещения информационных ресурсов на узлах вычислительной сети: описание реализуемых методов и структур данных'

Разработка модуля оптимального размещения информационных ресурсов на узлах вычислительной сети: описание реализуемых методов и структур данных Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
84
13
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ВЫЧИСЛИТЕЛЬНАЯ СЕТЬ / ИНФОРМАЦИОННЫЙ РЕСУРС / СЛУЧАЙНОЕ РАЗМЕЩЕНИЕ РЕСУРСОВ / СИМПЛЕКС-МЕТОД / МЕТОД ВЕТВЕЙ И ГРАНИЦ / ГЕНЕТИЧЕСКИЙ АЛГОРИТМ / ПРОЕКТИРОВАНИЕ / МОДЕЛИРОВАНИЕ / COMPUTER NETWORK / INFORMATION RESOURCE / RANDOM ALLOCATION OF RESOURCES / SIMPLEX METHOD / BRANCH AND BOUND METHOD / GENETIC ALGORITHM / DESIGN / MODELING

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Евсин В. А., Тихонов Н. А., Воробьев С. П.

В данной статье рассматривается проблематика оптимального размещения информационных ресурсов на узлах вычислительной сети. Представлены основные методы, используемые в ходе решения данной проблемы. В частности, рассмотрен метод случайного размещения ресурсов, оптимизация размещения ресурсов с использованием метода ветвей и границ, а также оптимизация размещения ресурсов с использованием генетического алгоритма. Для данных методов определена структура входных и выходных данных, кроме того для представленных методов продемонстрирована внутренняя структура размещения ресурсов. Ключевым аспектом рассмотрения в данной статье является постановка задачи и моделирование процесса ее решения с использованием представленных алгоритмов. Как итог, представлено тестирование разработанного модуля на входных данных и анализ перспектив использования модуля.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Евсин В. А., Тихонов Н. А., Воробьев С. П.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Development of the module for optimal placement of information resources at the nodes of the computer network: a description of the methods and data structures implemented

This article discusses the problems of optimal placement of information resources on the nodes of a computer network. The main methods used in solving this problem are presented. In particular, the method of random allocation of resources, optimization of allocation of resources using the branch and bound method, and optimization of allocation of resources using a genetic algorithm are considered. For these methods, the structure of the input and output data has been determined, in addition, the internal structure of resource allocation has been demonstrated for the presented methods. A key aspect of the consideration in this article is the formulation of the problem and the modeling of its solution using the algorithms presented. As a result, testing of the developed module on the input data and analysis of the prospects for using the module are presented.

Текст научной работы на тему «Разработка модуля оптимального размещения информационных ресурсов на узлах вычислительной сети: описание реализуемых методов и структур данных»

Разработка модуля оптимального размещения информационных ресурсов на узлах вычислительной сети: описание реализуемых методов

и структур данных

В.А. Евсин, Н.А. Тихонов, С.П. Воробьев

Южно-Российский государственный политехнический университет (НПИ)

имени М.И. Платова

Аннотация: В данной статье рассматривается проблематика оптимального размещения информационных ресурсов на узлах вычислительной сети. Представлены основные методы, используемые в ходе решения данной проблемы. В частности, рассмотрен метод случайного размещения ресурсов, оптимизация размещения ресурсов с использованием метода ветвей и границ, а также оптимизация размещения ресурсов с использованием генетического алгоритма. Для данных методов определена структура входных и выходных данных, кроме того для представленных методов продемонстрирована внутренняя структура размещения ресурсов. Ключевым аспектом рассмотрения в данной статье является постановка задачи и моделирование процесса ее решения с использованием представленных алгоритмов. Как итог, представлено тестирование разработанного модуля на входных данных и анализ перспектив использования модуля. Ключевые слова: вычислительная сеть, информационный ресурс, случайное размещение ресурсов, симплекс-метод, метод ветвей и границ, генетический алгоритм, проектирование, моделирование.

В ходе увеличения сложности и комплексности вычислительных сетей стала возникать необходимость в оптимальном размещении информационных ресурсов на узлах вычислительной сети, подробнее о которых можно прочесть в [1,2]. Одним из наиболее значимых показателей оптимального размещения ресурсов является стоимость размещения ресурса на сервере, другим важным аспектом оптимального размещения ресурсов является средняя стоимость доставки информационного ресурса до сервера, следовательно, задача оптимизации в общем виде может быть сформулирована следующим образом:

n m

* K + CSt * VR, * K2)* B, ^ min, (1)

i=1 j=1

где t - индекс сервера в кластере, n - количество серверов в кластере, t = 1, n, j - индекс информационного ресурса в массиве, m - количество

J

информационных ресурсов, 1 = 1, т, ТБу - средняя стоимость доставки 7-го информационного ресурса на ¡-й сервер, К\ - коэффициент значимости стоимости доставки ресурса, С8г - стоимость размещения единицы объема информационного ресурса на ¡-м сервере, УЯ- - объем 7-го информационного ресурса, К2 - коэффициент значимости стоимости размещения ресурсов, В- -бинарное значение размещения информационного ресурса на сервере. Данная целевая функция должна выполняться при следующих ограничениях:

' ТУЯ, *В, <У£г,г = 1й

¿—1 1 ¡1 г' '

11, если й информационный ресурс отправляется на 1 - й сервер' (2)

ь [ 0, иначе

где VSi - объем i-го сервера, остальные параметры представлены выше. Подробнее о математических моделях в кластерных вычислительных системах в [3,4]. Для решения поставленной задачи могут быть использованы следующие методы:

- метод случайного размещения: данный метод предполагает отсутствие оптимизации при размещении ресурса на случайном сервере с условием ограничения по объему сервера;

- метод ветвей и границ: данный метод предполагает использование симплекс метода для оптимизации размещения ресурсов, а также использование метода ветвей и границ для отсечения нецелочисленных параметров решения;

- генетические алгоритмы: данный метод предполагает поиск решений путем кроссовера, а также мутации хромосом, содержащих параметры решения. Структура данных входного параметра для методов размещения ресурсов данной системы имеет следующую форму:

DTD =< LS, LIR, KCPS, KCSS >,

где LS = {SERVi, i = 1...n} - массив серверов вычислительной сети, LIR = {LIR}, j = 1...m} - массив информационных ресурсов, KCPS - коэффициент

значимости стоимости размещения на сервере, KCSS - коэффициент значимости стоимости отправления данных на сервер.

Структура данных i-го сервера имеет следующую форму: LSt =< ЫСЛРг, COST, USCAp, LIRt >, где MCAPi - максимальный объем i-го сервера, COSTi - стоимость размещения на i-м сервере, USCAPi - используемый объем i-го сервера, LIRi -список информационных ресурсов, которые размещены на i-м сервере. Структура данных j-го информационного ресурса имеет следующую форму:

LIR} =< RIDj, VOLj, HTCOSTj > ,

где RIDj- идентификатор j-го ресурса, VOLj - объем j-го ресурса, HTCOSTj- таблица стоимостей отправки j-го ресурса до серверов. Структура результирующих данных после размещения ресурсов имеет следующую форму:

PLSERV =< CODE,MES, LS, LIR >, где CODE - код возвращаемого значения, MES - сообщение об ошибке, LS -массив серверов, LIR - массив информационных ресурсов. Диаграмма классов рассмотренных структур представлена на рис.1.

В ходе решения методом случайного размещения необходимо провести сортировку стека серверов по их объему, после чего необходимо заполнять сервера случайным образом, итерации прекращаются, когда будут заполнены все сервера или распределены все ресурсы.

В ходе решения задачи методом ветвей и границ, о котором в [5,6], необходимо определить минимум функции (1) при заданных ограничениях (2), для решения необходимо использовать симплекс метод, в ходе которого

J

определяется оптимальное решение без учета ограничения по целочисленности, подробнее о данном методе в [7,8].

Server

maxCapacity: int cost:double

usedCapacity:usedCapacity infRes ource s : infRes ource s

+ Server(maxCapacity, cost) + getFree): int

+addResource(infResource): void +calculatePrice(): int

1

ru

1

ResourcePopulation

chromosomeList:

List<ResourceChromosome>

populationLimit:int

OnePointCrossover:OnePointCrossover binaryMutation:BinaryMutation geneticAlgoritmConstraints:List<Genetic AlgoritmConstraint>

ResourcePopulation(chromosomeList, geneticAlgoritmConstraints) initialResourceChromosome(populationSi ze, goalFunction,

serverSize,resourceSize):List<ResourceC hromosome>

getRandomChromosome(serverSize, resourceSize):List<Integer> nextGeneration():popul ati on checkConstraint(chromosome):boolean addChromosome(chromosome):void

CustomRandom

idServers: forms.List<Integer> countServer:int

CustomRandom(countServer) addIdServer(id):void clearList():void generateRandom( ):int

PlaceServer

code: int

message:String

servers:List<Server>

infResources:Stack<infResources>

+PlaceServer()

+PlaceSeiver(code,message, servers) +PlaceServer(code, message, servers, infResources)

+PlaceServer(code, message, servers): void

DistributeGeneticAlgorithMethod

CROSSOVER_RATE:double

MUTATION_RATE:double

TOURNAMENT_ARITY:int

+PlaceServer(dataToDistribute):PlaceSer ver

createConstraints(dataToDistribute):

List<GeneticAlgoritmConstraint>

stoppingCondition():StoppingCondition

1

GeneticAlgoritmCons traint

constraintParams:double[] enumTypeEqual:EnumTypeEqual value:double

+Genetic AlgoritmC rams,enumTypeEqu +checkConstraint(re onstraint(constraintPa al,value) presentation):boolean

HelperMethods

createParameterGoalFunction(resourceDa ta):double[]

createZeroDoubleArray(ans, length):double[]

DataToDistribute

servers:List<Server> infResources :List<InfResource> koefCostPlaceOnServer: double koefCostSendToServer: double

+DataToDistribute(servers,infResources, koefCostPlaceOnServer,koefCostSendTo Server)

ResourceChromosome

functionParameters:List<Double> representation :List<Integer>

ResourceChromosome(representation, functionParameters)

checkValidity(chromosomeRepresentatio n):void

newFixedLengthChromosome(chromoso

meRepresentation):AbstractListChromoso

me<Integer>

fitness():double

RandomDistributionMethod

+ randomDistribute(servers, infResources)

+getCostSendToServer(): PlaceServer

InfResource

resourceId: int volume:int

costSendToServer:Hashtable

+ InfResource(resourceId, volume) +getCostSendToServer(): Hashtable

BranchAndBoundsMethod

distributeResources(resourceData):PlaceS erver

Рис. 1 - Диаграмма классов модуля оптимального размещения информационных ресурсов по узлам вычислительной сети

1

1

*

*

1

*

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

1

1

1

1

1

Для определения целочисленного решения необходимо для каждого нецелочисленного параметра разделить решение на 2 ветви:

- для первой ветви определить х = 0;

- для второй ветви определить х >= 1, после чего необходимо произвести пересчет нижней границы решения и произвести выбор решения с наименьшей границей. В ходе итерационного пересчета параметров будет определено целочисленное решение.

Для решения генетическим алгоритмом, о котором можно прочесть в [9-11], необходимо определить начальную популяцию хромосом, которая бы удовлетворяла ограничениям (2). Хромосомы данной модели имеют следующую форму:

дЕРд | ^ | ^ |1, если ] - й ресурс отправляется на 1- й сервер 11,1 у 0, иначе

Фитнес-функция данной модели имеет следующую форму:

Р = 2 РР} * ЯЕРЯ] ,

1

где ГР1 - 1-й параметр целевой функции, ЯЕРД - значение генов 1-й хромосомы. В качестве модели селекции используется модель элитарного отбора по критерию минимальной фитнес-функции хромосом. Для определения генов новых потомков используется модель точечного кроссовера. С вероятностью 30% у хромосом возникает мутация гена у рассматриваемой хромосомы. Каждая новая хромосома должна быть допустимой. Допустимость достигается путем выполнения критериев (2), в противном случае хромосома отбрасывается из общего набора. Каждая новая популяция имеет максимальный размер, равный 1.5 размера предыдущей популяции. Условие выхода из процесса селекции имеет следующую форму:

Е =

1, если—21Р - Р | < 8 или сер >= тер

ту 1 ,

0, иначе

где ¥1 - наиболее приспособленная особь ^-й эпохи, ¥ - усредненный

показатель наиболее приспособленных особей за последние т-эпох, а - максимальная ошибка модели, сер - номер текущей эпохи, тер - максимальное количество эпох.

Тестирование данных на 6 серверах и 12 информационных ресурсах генетическим алгоритмом показало результат, представленный на рис.2.

го 30 40 50 60 70 80 90 100 Эпоха

Рис. 2 - Динамика абсолютной стоимости

Дальнейшая разработка приложения будет направлена на разработку модуля моделирования среднего времени доступа к информационным ресурсам. Разработанное приложение может быть использовано предприятиями различных отраслей в целях оптимизации размещения ресурсов на узлах вычислительной сети.

Литература

1. Степанов А.Н. Архитектура вычислительных систем и компьютерных сетей. - СПб.: Питер, 2007. - 509 с.

2. Богданов А.В, Корхов В.В., Мареев В.В., Станкова Е.Н. Архитектуры и топологии многопроцессорных вычислительных систем. - М.: ИНТУИТ.РУ "Интернет-Университет Информационных технологий", 2004. -172 с.

3. Евсин В. А., Литвяк Р.К. Математическая модель информационной системы высокой готовности на базе кластерной

архитектуры // Моделирование. Теория, методы и средства. - Новочеркасск: Лик, 2016. - С. 176-179.

4. Евсин В.А., Широбокова С.Н., Евсина В.А., Продан Е.А. Математическое моделирование распределеного реестра в сфере аренды недвижимости как сети массового обслуживания // Инженерный вестник Дона, 2018, №3 URL: ivdon.ru/ru/magazine/archive/n3y2018/5078

5. Черноморов Г. А. Теория принятия решений. - 3 изд. -Новочеркасск: Ред. журн. «Изв. вузов. Электромеханика», 2005. - 448 с.

6. Parmigiani G., Inoue L., Lopes, H. Decision Theory. Principles and Approaches. - New Jersey: John Wiley & Sons, 2009. - 405 p.

7. Банди Б. Основы линейного программирования. - М.: Радио и связь, 1989. - 176 с.

8. Васильев Ф.П. Методы оптимизации. - М.: МЦНМО, 2011. - 620с.

9. Haupt R.L., Haupt S.E. Practical Henetic Algoritms. - 2 edition. - New Jersey: John Wiley & Sons, 2004. - 272 p.

10. Рутковская Д., Пилиньский М., Рутковский Л. Нейронные сети, генетические алгоритмы и нечеткие системы. - М.: Горячая линия - Телеком, 2006. - 383 с.

11. Орловский Н.М. Решение задачи однокритериальной оптимизации процесса планирования действий экипажа Российского сегмента Международной космической станции на основе генетического алгоритма // Инженерный вестник Дона. 2013. №3. URL: ivdon.ru/ru/magazine/archive/n3y2013/1776

References

1. Stepanov A.N. Arkhitektura vychislitel'nykh sistem i komp'yuternykh setey [Architecture of computer systems and computer networks] SPb. Piter, 2007. 509 p.

2. Bogdanov A.V., Korhov V.V., Mareev V.V., Stankova E.N. Arhitektury i topologii mnogoprocessornyh vychislitel'nyh sistem [Architecture and topology of multiprocessor computing systems]. M.: INTUIT.RU "Internet-Universitet Informacionnyh tehnologij", 2004. 172 p.

3. Evsin V.A., Litvjak R.K. Modelirovanie. Teorija, metody i sredstva. Novocherkassk: Lik, 2016. pp. 176-179.

4. Evsin V.A., Shirobokova S.N., Evsina V.A., Prodan E.A. Inzenernyj vestnik Dona (Rus), 2018, №3 URL: ivdon.ru/ru/magazine/archive/n3y2018/5078.

5. Chernomorov G.A. Teorija prinjatija reshenij [Decision theory]. 3 izd. Novocherkassk: Red. zhurn. «Izv. vuzov. Jelektromehanika», 2005. 448 p.

6. Parmigiani G., Inoue L., Lopes, H. Decision Theory. Principles and Approaches. New Jersey: John Wiley & Sons, 2009. 405 p.

7. Bandi B. Osnovy linejnogo programmirovanija [Basics of linear programming]. M.: Radio i svjaz', 1989. 176 p.

8. Vasil'ev F.P. Metody optimizacii. [Optimization methods]. M.: MCNMO, 2011. 620 p.

9. Haupt R.L., Haupt S.E. Practical Henetic Algoritms. 2 edition. New Jersey: John Wiley & Sons, 2004. 272 p.

10. Rutkovskaja D., Pilin'skij M., Rutkovskij L. Nejronnye seti, geneticheskie algoritmy i nechetkie sistemy. [Neural networks, genetic algorithms and fuzzy systems] M.: Gorjachaja linija. Telekom, 2006. 383 p.

11. Orlovskij N.M. Inzenernyj vestnik Dona (Rus), 2013, №3. URL: ivdon.ru/ru/magazine/archive/n3y2013/1776

i Надоели баннеры? Вы всегда можете отключить рекламу.