WedX - журнал о программировании и компьютерных науках

Nodejs лучший способ реализовать соединение с базой данных (mysql)

Я работаю на сервере nodejs.

Я вижу, что есть много способов реализовать соединение mysql, например:

  • 1 соединение, и оно никогда не заканчивается (обработайте ошибку и снова подключитесь)

  • Пул соединений (как я могу узнать, сколько соединений за раз разрешает мой сервер mysql)

  • Инициируйте новое соединение, когда оно нам понадобится (http-запрос...), а затем завершите его, когда закончите.

Мой вопрос: как лучше всего реализовать mysql на моем сервере. Или у каждого из них есть минусы или плюсы -> покажите.

12.11.2013

Ответы:


1

Я вмешивался как в неиспользование пулов, так и в использование пулов, и после этого я бы рекомендовал вам настроить пулы. Постоянные соединения приведут к проблемам, если вы имеете дело с асинхронным кодом, для которого Node отлично подходит. Если вы в конечном итоге попытаетесь выполнить 2 вызова одного и того же постоянного обработчика MySQL одновременно, ему это не понравится. Перейти на пул.

Не уверен, почему вы когда-либо хотели подключаться к SQL через HTTP для Node.

Как я могу узнать, что мой сервер mysql позволяет сколько подключений одновременно

Проверьте параметр max_connections в конфигурации MySQL (my.cnf).

12.11.2013
  • Вы также можете запустить этот запрос (например, из оболочки MySQL): show variables like "max_connections"; 12.11.2013

  • 2

    Вот связанный ответ, который поможет вам понять преимущества объединения соединений.

    Вы также можете взять пример Sequelize, ORM для Node, который поддерживает MySQL. Как видно из документации, вы можете использовать либо одно соединение для каждого запроса, либо пул соединений с тайм-аутом простоя (т. е. вы закрываете соединение после того, как оно какое-то время бездействовало).

    12.11.2013
    Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

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

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

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]