Используйте nginx для проксирования MySQL
Используйте nginx для проксирования MySQL

1. Зачем вам нужен агент

1. Экранирование порта

Обычно, когда вы видите 3306, вы знаете, что это выделенный порт для MySQL. При экранировании клиент может видеть только порт, который прослушивает nginx, и не может видеть, какую программу и протокол он представляет. Конечно, это также поверхностная защита. метод.

2. Защита

Доступ к интрасети осуществляется через IP-адрес и порт интрасети, а доступ к общедоступной сети — через прокси-сервер nginx. Если доступ к общедоступной сети рискован, его можно настроить для ограничения текущих и ограничения клиентских подключений. А в крайнем случае агент можно закрыть и отключить доступ к общедоступной сети, чтобы это не повлияло на работу экземпляра MySQL и доступ к интрасети.

3. Динамическая нагрузка

Экземпляр прокси-сервера MySQL может быть динамически заменен без ведома клиента, а загрузка запросов и распределение маршрутов также могут быть реализованы в кластере, тем самым улучшая доступность сервиса.

4. Заблокируйте настоящий сервер MySQL

С помощью Nginx реальный IP-адрес сервера MySQL может быть защищен, чтобы злоумышленники не могли использовать грубый взлом и другие методы для атаки на сервер MySQL.

2. Как реализовать прокси-сервер nginx в MySQL

nginx по умолчанию проксирует семиуровневые протоколы, а mysql — четырехуровневый протокол, поэтому обратный прокси не может быть реализован с использованием модуля http и требует поддержки четырехуровневого модуля протокола tcp.

1. Установите поддержку четырехуровневого протокола nginx.
Язык кода:javascript
копировать
yum -y install nginx
yum -y install nginx-all-modules.noarch
2. Настройте прокси MySQL.
Язык кода:javascript
копировать
server {
    listen 3388;
    proxy_pass host:3306;
}

nginx прослушивает и предоставляет порт 3388. Порт экземпляра mysql не открыт для интрасети. nginx преобразует порт 3388 в порт 3306 через протокол TCP.

Добавьте конфигурацию потока в основной файл конфигурации nginx nginx.conf:

Язык кода:javascript
копировать
stream {
        include /etc/nginx/tcp.protocol/*.conf;
}
3. Начните тестирование
Язык кода:javascript
копировать
nginx -t
nginx

Теперь мы можем только доказать, что сеть и порт соединены, но это может быть не так, что с протоколом mysql агента nginx все в порядке. Для проверки необходимо использовать команды или клиентские инструменты:

3. Расширение

1. Больше, чем MySQL

Поскольку nginx может поддерживать прокси-сервер протокола TCP, помимо проксирования MySQL, он также может проксировать Redis, Nacos и другие часто используемые четырехуровневые протоколы. redis:

Язык кода:javascript
копировать
server {
        listen 6388;
        proxy_pass host:6379;
}

nacos:

Язык кода:javascript
копировать
server {
        listen 8188;
        proxy_pass host:8848;
}
2. Другие подобные четырехслойные прокси

Амазон НЛБ

Фактически, проще говоря, для некоторых простых сценариев возможности прокси-сервера, предоставляемые NLB, аналогичны nginx, за исключением того, что NLB — это зрелое решение продукта, поддерживаемое многими возможностями периферийных продуктов, такими как WAF и Shield.

Алибаба Облако НЛБ

Подобно NLB AWS, кластер продуктов Alibaba Cloud SLB также предоставляет балансировщик нагрузки NLB для поддержки переадресации прокси-сервера протокола четвертого уровня.

boy illustration
RasaGpt — платформа чат-ботов на основе Rasa и LLM.
boy illustration
Nomic Embed: воспроизводимая модель внедрения SOTA с открытым исходным кодом.
boy illustration
Улучшение YOLOv8: EMA основана на эффективном многомасштабном внимании, основанном на межпространственном обучении, и эффект лучше, чем у ECA, CBAM и CA. Малые цели имеют очевидные преимущества | ICASSP2023
boy illustration
Урок 1 серии Libtorch: Тензорная библиотека Silky C++
boy illustration
Руководство по локальному развертыванию Stable Diffusion: подробные шаги и анализ распространенных проблем
boy illustration
Полностью автоматический инструмент для работы с видео в один клик: VideoLingo
boy illustration
Улучшения оптимизации RT-DETR: облегченные улучшения магистрали | Support Paddle облегченный rtdetr-r18, rtdetr-r34, rtdetr-r50, rtdet
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | Деформируемое внимание с большим ядром (D-LKA Attention), большое ядро ​​​​свертки улучшает механизм внимания восприимчивых полей с различными функциями
boy illustration
Создано Datawhale: выпущено «Руководство по тонкой настройке развертывания большой модели GLM-4»!
boy illustration
7B превышает десятки миллиардов, aiXcoder-7B с открытым исходным кодом Пекинского университета — это самая мощная модель большого кода, лучший выбор для корпоративного развертывания.
boy illustration
Используйте модель Huggingface, чтобы заменить интерфейс внедрения OpenAI в китайской среде.
boy illustration
Оригинальные улучшения YOLOv8: несколько новых улучшений | Сохранение исходной информации — алгоритм отделяемой по глубине свертки (MDSConv) |
boy illustration
Второй пилот облачной разработки | Быстро поиграйте со средствами разработки на базе искусственного интеллекта
boy illustration
Бесшовная интеграция, мгновенный интеллект [1]: платформа больших моделей Dify-LLM, интеграция с нулевым кодированием и встраивание в сторонние системы, более 42 тысяч звезд, чтобы стать свидетелями эксклюзивных интеллектуальных решений.
boy illustration
Решенная Ошибка | Загрузка PyTorch медленная: TimeoutError: [Errno 110] При загрузке факела истекло время ожидания — Cat Head Tiger
boy illustration
Brother OCR, библиотека с открытым исходным кодом для Python, которая распознает коды проверки.
boy illustration
Новейшее подробное руководство по загрузке и использованию последней демонстрационной версии набора данных COCO.
boy illustration
Выпущен отчет о крупной модели финансовой отрасли за 2023 год | Полный текст включен в загрузку |
boy illustration
Обычные компьютеры также могут работать с большими моделями, и вы можете получить личного помощника с искусственным интеллектом за три шага | Руководство для начинающих по локальному развертыванию LLaMA-3
boy illustration
Одной статьи достаточно для анализа фактора транскрипции SCENIC на Python (4)
boy illustration
Бросая вызов ограничениям производительности небольших видеокарт, он научит вас запускать большие модели глубокого обучения с ограниченными ресурсами, а также предоставит полное руководство по оценке и эффективному использованию памяти графического процессора!
boy illustration
Команда Fudan NLP опубликовала 80-страничный обзор крупномасштабных модельных агентов, в котором в одной статье представлен обзор текущего состояния и будущего агентов ИИ.
boy illustration
[Эксклюзив] Вы должны знать о новой функции JetBrains 2024.1 «Полнострочное завершение кода», чтобы решить вашу путаницу!
boy illustration
Краткое изложение базовых знаний о регистрации изображений 1.0
boy illustration
Новейшее подробное руководство по установке и использованию библиотеки cv2 (OpenCV, opencv-python) в Python.
boy illustration
Легко создайте локальную базу знаний для крупных моделей на основе Ollama+AnythingLLM.
boy illustration
[Решено] ошибка установки conda. Среда решения: не удалось выполнить первоначальное зависание решения. Повторная попытка с помощью файла (графическое руководство).
boy illustration
Одна статья поможет вам понять RAG (Retrival Enhanced Generation) | Введение в концепцию и теорию + практику работы с кодом (включая исходный код).
boy illustration
Эволюция архитектуры шлюза облачной разработки
boy illustration
Docker и Kubernetes [Разработка контейнерных приложений с помощью Python]