The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]

Тестирование операций на чтение-запись в SQL на FreeBSD

05.08.2007 16:52

Kris Kennaway опубликовал результаты тестов PostgreSQL и MySQL, проведённых с целью выявления узких мест в операциях чтения-записи на FreeBSD.

Из-за медленной дисковой подсистемы на тестовом сервере, Kris дополнительно провёл тестирование с использованием TMPFS. При росте количества параллельных запросов производительность MySQL резко падает, причём система в это время практически не загружена. В то же время, PostgreSQL ведёт себя более устойчиво, хотя и показывает меньшую производительность при малом числе параллельных запросов.

Крис заметил, что в Google SoC'07 ведётся работа над улучшением lockmgr, которая должна положительно сказаться на производительности PostgreSQL. В то время, как MySQL имеет проблемы во внутреннем дизайне и разработчики ОС никак не могут улучшить ситуацию с ним.



  1. Главная ссылка к новости (http://lists.freebsd.org/piper...)
  2. Результаты тестирования
Автор новости: butcher
Лицензия: CC BY 3.0
Источник: lists.freebsd.org
Короткая ссылка: https://opennet.ru/11661-FreeBSD
Ключевые слова: FreeBSD, PgSQL, MySQL, bench
При перепечатке указание ссылки на opennet.ru обязательно


Обсуждение (30) Ajax | 1 уровень | Линейный | +/- | Раскрыть всё | RSS
  • 1.1, Exe (?), 20:56, 05/08/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    кто на linux потестит? :).
    PS конец мифу что на bsd быстро работают базы? :)
     
     
  • 2.9, Andrew Kolchoogin (?), 08:53, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Смотря на какой платформе. На *BSD базы действительно работают быстрее, чем на Линуксе. Примерно на 30%. Но это не из за баз, это из-за Линукса.
    Замечание 1. База должна быть _большой_. Настолько большой, чтобы ОЗУ понадобилось больше 4 гигабайт. Тогда Линукс с трёхуровневым VM'ом будет нервно покуривать в уголку. :) А пока нет выигрыша по скорости работы виртуальной памяти -- все сравнения дают данные в пределах погрешности одинаковые.
    Замечание 2. Да, я знаю, какой ценой даётся это быстродействие. Оборудование надо подбирать правильное, умеющее 64'х-битный DMA. :)
     
     
  • 3.15, sauron (??), 12:10, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Вы что при объемах памяти больше 4 гиг до сих пор используете 32-битные системы?
     
  • 3.22, _Nick_ (??), 14:02, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Смотря на какой платформе. На *BSD базы действительно работают быстрее, чем на
    >Линуксе. Примерно на 30%.

    а это скока в попугаях? %)))
    А может не 30? Или не быстрее? ;)


    >Но это не из за баз, это из-за Линукса.
    >Замечание 1. База должна быть _большой_. Настолько большой, чтобы ОЗУ понадобилось больше
    >4 гигабайт. Тогда Линукс с трёхуровневым VM'ом будет нервно покуривать в
    >уголку. :)

    Хэх... а бздуны все голой ж..й на саблю...
    Это оно в исходниках в 3 уровнях и при компиляции вырождаеться в использование всего-лишь 2 уровней: на 32 бит платформе нижний и средний, на 64 - нижний и высокий.

    Угу, а если она будет ОЧЕНЬ большой? ;) гиг 20...
    бздя не помрет под линейными лупами?
    И это >4гиг нужно как? Одному процессу или где? Дык это тогда amd64...


    Так может ты не о том линуксе говоришь?


    >А пока нет выигрыша по скорости работы виртуальной памяти
    >-- все сравнения дают данные в пределах погрешности одинаковые.

    лирика...

    >Замечание 2. Да, я знаю, какой ценой даётся это быстродействие. Оборудование надо
    >подбирать правильное, умеющее 64'х-битный DMA. :)

    фантазер...
    Тебе мало 4гига чтоб разминуться в буферах с винтом? ГЫ :)
    Ты это либо придумал либо линух с чем иным путаешь...

     
     
  • 4.34, Andrew Kolchoogin (?), 15:46, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Хэх... а бздуны все голой ж..й на саблю...

    Я бы попросил следить за речью.

    >Это оно в исходниках в 3 уровнях и при компиляции вырождаеться в
    >использование всего-лишь 2 уровней: на 32 бит платформе нижний и средний,
    >на 64 - нижний и высокий.

    И как же после компиляции так происходит вырождение VM'а, что 32'х-битный драйвер начинает резко узнавать про то, что памяти больше 4 гигабайт?

    >Угу, а если она будет ОЧЕНЬ большой? ;) гиг 20...
    >бздя не помрет под линейными лупами?
    >И это >4гиг нужно как? Одному процессу или где? Дык это тогда amd64...

    :) *BSD не нужно мапить всю память в адресное пространство. Тут вам не Линукс. :)

    >Так может ты не о том линуксе говоришь?

    О том, о том.

    >>Замечание 2. Да, я знаю, какой ценой даётся это быстродействие. Оборудование надо
    >>подбирать правильное, умеющее 64'х-битный DMA. :)
    >
    >фантазер...
    >Тебе мало 4гига чтоб разминуться в буферах с винтом? ГЫ :)

    Моя не понимать, каким образом драйвер SCSI-контроллера, не знающий про 64-bit DMA, сможет мне положить данные с винчестера в пятый гигабайт ОЗУ.

    Или кое-кто наивно полагает, что у него собственный MMU родиццо?-)

     
     
  • 5.38, _Nick_ (??), 16:10, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Я бы попросил следить за речью.

    да, чуток загнул...

    >>Это оно в исходниках в 3 уровнях и при компиляции вырождаеться в
    >>использование всего-лишь 2 уровней: на 32 бит платформе нижний и средний,
    >>на 64 - нижний и высокий.
    >
    >И как же после компиляции так происходит вырождение VM'а, что 32'х-битный драйвер
    >начинает резко узнавать про то, что памяти больше 4 гигабайт?

    когда врублена поддержка >4G памяти - юзаеться верхний уровень таблиц.
    Как в 64бит архитектурах.
    Одна запись в верхнем уровне адресует 4M.
    4M*2^32 = выше крыши


    >:) *BSD не нужно мапить всю память в адресное пространство.

    Даже если было бы нужно - то _чье_ адрессное пространство? ;)
    ядра или какого-либо процесса? занумером 1? или 2?
    Аддр. пространство оно виртуальное и его много ;)
    Так какого адресного пространства? :)


    >Тут вам не Линукс. :)

    о... уже инересно...
    А Линукс, значит, всю память мапит куда-то? ;)
    Где ты дурь (не слишком загнул?) берешь?


    >Моя не понимать, каким образом драйвер SCSI-контроллера, не знающий про 64-bit DMA,
    >сможет мне положить данные с винчестера в пятый гигабайт ОЗУ.

    Через bounce буфер. Т.е. реально тока конечно в нижние адреса, а потом уже ядро переложит.
    Конечно это нельзя считать чесным "положением".
    С другой стороны, если это не умеет железо - то пофиг о чем знает драйвер (а драйвер,
    все-таки знать может под amd64. Или мы тока о 32 битах?)

    >Или кое-кто наивно полагает, что у него собственный MMU родиццо?-)

    как тока на заводе поставят - так и появицо :)
    А если не поставили - то, как я тока шо сказал, пофиг что знает или нет драйвер.

     
     
  • 6.41, _Arti (??), 17:04, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/

    >Даже если было бы нужно - то _чье_ адрессное пространство? ;)
    >ядра или какого-либо процесса? занумером 1? или 2?
    >Аддр. пространство оно виртуальное и его много ;)
    >Так какого адресного пространства? :)
    >

    Чтобы ответить на это вопрос нужно вспомнить с чем работает DMA (правильного варианта Вы не назвали ;) ).

     
     
  • 7.42, sauron (??), 19:44, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Чтобы ответить на это вопрос нужно вспомнить с чем работает DMA (правильного
    >варианта Вы не назвали ;) ).

    Ну 64 битное DMA в linux kernel есть если на то пошло.

     
  • 7.46, _Nick_ (??), 03:12, 07/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >
    >>Даже если было бы нужно - то _чье_ адрессное пространство? ;)
    >>ядра или какого-либо процесса? занумером 1? или 2?
    >>Аддр. пространство оно виртуальное и его много ;)
    >>Так какого адресного пространства? :)
    >>
    >
    >Чтобы ответить на это вопрос нужно вспомнить с чем работает DMA (правильного
    >варианта Вы не назвали ;) ).

    а должен был? ;)
    кто мне тут затирает про "маппинг в адресное пространство"?
    Я что-ли? Вот я и спрашил. Мои варианты никак не обязаны содержать правильный вариант.
    Это ж не тест на IQ :)

    а по сути
    "*BSD не нужно мапить всю память в адресное пространство."
    Линуху тоже этого делать не надо, но человек почему-то уверен, что надо...
    Кто тут неправ - вроде бы очевидно

     

  • 1.2, creativ (??), 21:06, 05/08/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Такого мифа как раз и небыло.
     
  • 1.3, Answer (?), 22:57, 05/08/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Хороший тест: ни структуры таблиц, ни конфигурации, ни типов запросов. Брехня - на более слабом железе БДшки под фрибздей показывали более сильные резулбтаты, на нетривиальных запросах.

    ПС. Зачем такой бред помещать в новость? Или все что содержит картинки будет вешаться на главную страницу?

     
     
  • 2.5, _Nick_ (??), 04:08, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    да...
    какая-то странная новость.
    никаких деталей, чтоб можно было перепроверить.

    негросовт-style

     
  • 2.7, butcher (ok), 07:58, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Тесты проводились стандартным набором тестов http://sysbench.sourceforge.net/.
    О чём в тексте письма написано.
     

  • 1.4, adil_18 (??), 23:07, 05/08/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    Esli pravelno pod tyunit BSD, to bistree :)
     
     
     
    Часть нити удалена модератором

  • 3.8, Онанимус (?), 08:36, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    А теперь внимание, господа знатоки, вопрос: кто в жопе вот на этом графике: http://people.freebsd.org/~jeff/mysqlwrite.png
     
     
  • 4.17, _Nick_ (??), 12:47, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >А теперь внимание, господа знатоки, вопрос: кто в жопе вот на этом
    >графике: http://people.freebsd.org/~jeff/mysqlwrite.png

    Слышал о программе негросовта в свое сремя GetTheFUCKs?
    Так вот они сравнивали RH7.3 с XP...

    Ты тоже страдаешь таким легким "скрытым" "незнанием" реалий?

    Где ты взял эту 7-ку? В CVSе. Еще и пачку патчей прикрутил.
    А Линух какой ты взял? Древний. Пойди посмотри на kernel.org - какое щас последнее?
    А если взять не .22, а .23 с CFQ шедулером? Нет охоты такой график показать людям?

     
     
  • 5.21, nuclight (?), 13:29, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Не, вот такие красноглазые линуксоиды меня всегда умиляют, разница на 1 в последней цифре номера версии ядра - всё, уже древнее, передернем-ка сравнением в несколько лет разницы, ага. А то, что тесты были сделаны почти полгода назад на свежих в то время версиях того и другого - это поинтересоваться не в состоянии, да. Впрочем, чему удивляться, если даже про sysbench не в курсе, зато следуют понты насчет методологии тестов, ага-ага.
     
     
  • 6.23, _Nick_ (??), 14:07, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Не, вот такие красноглазые линуксоиды меня всегда умиляют, разница на 1 в
    >последней цифре номера версии ядра - всё, уже древнее, передернем-ка сравнением
    >в несколько лет разницы, ага. А то, что тесты были сделаны
    >почти полгода назад на свежих в то время версиях того и
    >другого - это поинтересоваться не в состоянии, да. Впрочем, чему удивляться,
    >если даже про sysbench не в курсе, зато следуют понты насчет
    >методологии тестов, ага-ага.

    Легкое напоминание из моей цитыты: "...Еще и пачку патчей прикрутил..."
    Линух то ванильный...

    Так чта либо с ванилью бзд давай тягацо, либо давай правильных патчей положим на пингвина...

     
  • 6.24, Аноним (-), 14:08, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Не, вот такие красноглазые линуксоиды меня всегда умиляют, разница на 1 в
    >последней цифре номера версии ядра - всё, уже древнее, передернем-ка сравнением
    >в несколько лет разницы, ага.

    А вот тут ты не прав, в 2.6.23(с _rc1) новый шедулер. Он есть и для .22 но в виде стороннего патча от Ingo Molnar. Ну и glibc был допилен в 2.6. Так что же тебя смущает?

     
     
  • 7.39, nuclight (?), 16:40, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    То, что некто _Nick_, в лучших традициях ЛОРа, любит нагло пиздеть. Багфиксы и влитие патчей - это не то же самое, что древность, и уж тем более сравнение RH7.3 с XP.
     
     
  • 8.40, _Nick_ (??), 16:43, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Любит - этого не отнять Но чуть больше он любит выдать правду-матку Чем чаще... текст свёрнут, показать
     
     
  • 9.51, Sem (??), 15:20, 09/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    Это не правда матка Это просто постоянный флейм Причем с постоянной демонстрац... текст свёрнут, показать
     
  • 4.18, Аццкая Сотона (?), 13:15, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >http://people.freebsd.org/~jeff/mysqlwrite.png

    патч от Nick Piggin вошёл в каком-то из 2.6.22-rc.
    Ну и ессно ещё и фикс в glibc.
    Так что стоит сравнивать 2.6.22+glibc-2.6

     
  • 3.11, Andrew Kolchoogin (?), 09:03, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    А потом включить и там, и там PAE и выкинуть Пингвиникс в помойку. :)
     
     
  • 4.16, sauron (??), 12:13, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >А потом включить и там, и там PAE и выкинуть Пингвиникс в
    >помойку. :)

    Знаете когда на рынке свободно доступны 64 битные системы, гордиться тем что в FreeBSD лучше реализован PAE, довольно таки смешно. Особенно учитывая, что если приложение оптимизировано под 64 бита, то прирост может быть до 30 процентов.

     
     
  • 5.32, Andrew Kolchoogin (?), 15:41, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    > Знаете когда на рынке свободно доступны 64 битные системы, гордиться тем что в FreeBSD лучше реализован PAE, довольно таки смешно.

    На рынке свободно доступен AMD64 (ну, или EM64T, один болт).
    А ему нужно то же, что и PAE - 64'х-битный DMA.
    Или куча костылей, которые в Линуксе называются трёхуровневым VM'ом, что для FreeBSD неприемлемо, так как приводит к деградации производительности, а в мозгах корпорации nVidia называются контролем за линейным адресным пространством областей, выделяемых функцией mmap().
    zander из nVidia писал, что их GPU -- 32'х разрядные (в смысле внешней шины), и поэтому, чтобы появился драйвер для nVidia'вских карточек под FreeBSD/amd64, им нужно, чтобы...
    [за необходимым -- на nvforum :)]

     
     
  • 6.36, _Nick_ (??), 15:54, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >На рынке свободно доступен AMD64 (ну, или EM64T, один болт).
    >А ему нужно то же, что и PAE - 64'х-битный DMA.

    не наезда ради, но правды для...
    64бит DMA нужно лишь для того, чтоб девайсы сами могли адресовать >4г, чтоб выложить в них
    приехавшее из девайса.
    К софтовому подходу это дела никакого не имеет (по крайней мере я не вижу проблем в нижних 4 гигах держать пару десят метров для DMA).
    Поправь, если я неправ...

    >Или куча костылей, которые в Линуксе называются трёхуровневым VM'ом, что для FreeBSD
    >неприемлемо, так как приводит к деградации производительности,

    да не приводит. Оно вырождаеться в 2 уровня при сборке еще.
    (http://www.ibm.com/developerworks/ru/library/l-memmod/)

    >а в мозгах корпорации
    >nVidia называются контролем за линейным адресным пространством областей, выделяемых >функцией mmap().

    ну, с Линухом то эта корпорация ужилась :)
    И весьма неплохо ;)

    >zander из nVidia писал, что их GPU -- 32'х разрядные (в смысле
    >внешней шины), и поэтому, чтобы появился драйвер для nVidia'вских карточек под
    >FreeBSD/amd64, им нужно, чтобы...
    >[за необходимым -- на nvforum :)]

    да... было такое :)
    вот и иди тут расказывай о высоком... о BSD-style...

     
  • 6.43, sauron (??), 19:49, 06/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >На рынке свободно доступен AMD64 (ну, или EM64T, один болт).
    >А ему нужно то же, что и PAE - 64'х-битный DMA.

    Который есть в 64 битном ядре. Не забываем что для AMD64 ядро собирается соответвующее и работает в соответвующем режиме. И DMA там тоже работает в необходимом режиме.

    >Или куча костылей, которые в Линуксе называются трёхуровневым VM'ом, что для FreeBSD
    >неприемлемо, так как приводит к деградации производительности

    Как уже говорили выше это есть только на уровне исходных кодов при сборке не нужный уровень отсекается. И?

    >zander из nVidia писал, что их GPU -- 32'х разрядные (в смысле
    >внешней шины), и поэтому, чтобы появился драйвер для nVidia'вских карточек под
    >FreeBSD/amd64, им нужно, чтобы...

    Или переделали шину или правильно написали драйвер чтобы он не клал ничего выше 4Gb лимита.

     

  • 1.48, ad3000 (?), 08:58, 07/08/2007 [ответить] [﹢﹢﹢] [ · · · ]  
  • +/
    >Вот интересно, зачем в комментах обсуждают линукс, если новость
    >была исключительно внутриBSDшная?..

    Совершенно согласен.

    Лучше бы дали ссылки на тесты непосредственно mySQL и PostgreSQL как в линуксе так и во фряхе (иль другое бсд)... Свежие и из хороших источников, а не от "Вася Пупкинс Групп"...

     
     
  • 2.50, Аноним (-), 12:04, 07/08/2007 [^] [^^] [^^^] [ответить]  
  • +/
    >Лучше бы дали ссылки на тесты непосредственно mySQL и PostgreSQL как в
    >линуксе так и во фряхе (иль другое бсд)... Свежие и из
    >хороших источников, а не от "Вася Пупкинс Групп"...

    А чем производительность mysql мерять-то? Есть скрипт чтоб запустил и он все сам сделал? А то я-то могу тестов напридумать, но они вам вряд ли понравятся :)

     

     Добавить комментарий
    Имя:
    E-Mail:
    Текст:



    Партнёры:
    PostgresPro
    Inferno Solutions
    Hosting by Hoster.ru
    Хостинг:

    Закладки на сайте
    Проследить за страницей
    Created 1996-2024 by Maxim Chirkov
    Добавить, Поддержать, Вебмастеру