docker php nginx mysql phpmyadmin

Docker Nginx + PHP + MySQL

Docker Nginx + PHP + MySQL

Теперь создадим связку Nginx + PHP ( пока без MySQL )

Создадим конфиг для nginx:

Создадим файлы для логов nginx:
touch /data/web/logs/nginx-error.log
touch /data/web/logs/nginx-access.log

Создадим тестовый файл php:
» > /data/web/public/index.php» />

Создадим compose файл для объединения образов nginx и php:

Образ nginx использует образы с именами tutum/nginx и линковку на образ php-fpm:
tutum/nginx
php-fpm

Пробрасываем файлы, инча после каждого перезапуска контейнера все будет очищаться

Т.е. из каталога на машине с докером мы пробрасываем папку веб-проекта в контейнер

Проверяем:
docker ps
CONTAINER ID IMAGE COMMAND STATUS PORTS NAMES
97d8b54f1145 tutum/nginx «/usr/sbin/nginx» Up 2 minutes 0.0.0.0:80->80/tcp web_nginx_1
401891b69b07 php:fpm «docker-php-entrypoi…» Up 2 minutes 0.0.0.0:9000->9000/tcp, 9000/tcp web_php-fpm_1

Если какой-либо из контейнеров не запускается, смотрим логи:
docker logs 97d8b54f1145

Столкнулся с проблемой, которую так и не понял, как решить толком, как сделал

Если столкнетесь с ошибкой:
nginx: [emerg] invalid number of arguments in «fastcgi_param» directive in /etc/nginx/sites-enabled/default:11

Управление проектом compose:
docker-compose stop
docker-compose start

Теперь добавим MySQL

Дополним compose файл:

Еще нам нужно установить драйверы для php для подключения к MySQL
Это делается в Dockerfile (Поэтому мы убрали image)

Проверяем:
docker ps
CONTAINER ID IMAGE COMMAND PORTS NAMES
06638849b713 tutum/nginx «/usr/sbin/nginx» 0.0.0.0:80->80/tcp web_nginx_1
b840c2388b81 web_php-fpm «docker-php-entrypoi…» 0.0.0.0:9000->9000/tcp web_php-fpm_1
c2de120b6e7f mysql:8.0 «docker-entrypoint.s…» 0.0.0.0:3306->3306/tcp, 33060/tcp web_mysql_1

Выбираем базу данных из файла docker-compose.yml:
show databases;
+———————+
| Database |
+———————+
| dbname |
| information_schema |
| mysql |
| performance_schema |
| sys |
+———————+

Создаем тестовые данные:
CREATE TABLE test
(
id INT NOT NULL auto_increment,
name VARCHAR(30) NOT NULL DEFAULT »,
PRIMARY KEY (id)
);

INSERT INTO test (name) VALUES («testname1»);
INSERT INTO test (name) VALUES («testname2»);
INSERT INTO test (name) VALUES («testname3»);

А эта строка, чтоб не вылезла ошибка
Uncaught PDOException: PDO::__construct():
The server requested authentication method unknown to the client [caching_sha2_password]:
alter user ‘root’@’%’ identified with mysql_native_password by ‘32167’;

Источник

Docker php nginx mysql phpmyadmin

Docker running Nginx, PHP-FPM, Composer, MySQL and PHPMyAdmin.

Before installing project make sure the following prerequisites have been met.

We’ll download the code from its repository on GitHub.

We’ll generate and configure SSL certificate for nginx before running server.

We’ll configure Xdebug for IDE (PHPStorm or Netbeans).

By this point we’ll have all the project pieces in place.

When developing, you can use Makefile for doing recurrent operations.

When running, you can use docker commands for doing recurrent operations.

To run the docker commands without using sudo you must add the docker group to your-user:

All requisites should be available for your distribution. The most important are :

Check if docker-compose is already installed by entering the following command :

Check Docker Compose compatibility :

The following is optional but makes life more enjoyable :

On Ubuntu and Debian these are available in the meta-package build-essential. On other distributions, you may need to install the GNU C++ compiler separately.

You should be careful when installing third party web servers such as MySQL or Nginx.

This project use the following ports :

ServerPort
MySQL8989
PHPMyAdmin8080
Nginx8000
Nginx SSL3000

To install Git, download it and install following the instructions :

Go to the project directory :

Configure Nginx With SSL Certificates

If you modify the host name, do not forget to add it to the /etc/hosts file.

Generate SSL certificates

Do not modify the etc/nginx/default.conf file, it is overwritten by etc/nginx/default.template.conf

Edit nginx file etc/nginx/default.template.conf and uncomment the SSL server section :

If you use another IDE than PHPStorm or Netbeans, go to the remote debugging section of Xdebug documentation.

For a better integration of Docker to PHPStorm, use the documentation.

Get your own local IP address :

Edit php file etc/php/php.ini and comment or uncomment the configuration as needed.

Set the remote_host parameter with your IP :

Run the application

Copying the composer configuration file :

Start the application :

Please wait this might take a several minutes.

Open your favorite browser :

Stop and clear services

When developing, you can use Makefile for doing the following operations :

Источник

Docker-compose for mysql, phpmyadmin and nginx

I want to use a dockerized SQL database server, an additional client (here: phpmyadmin) and a reverse proxy to make the client interface reachable from outside servers.

So far I used this docker-compose file:

The taken from the volume I get the nginx default.conf file as

When using the local machine with http://localhost:9080 I can use the PMA without any problems. When trying to use the reverse proxy address (http://localhost:8000) I only get an nginx error the page I am looking for is unavailable. Inside the logs I see that the reverse proxy fails on the connect() with connection refused.

What am I missing for such setups?

2 Answers 2

Most likely because localhost is container-based. Have you tried putting in your host’s ip address, eg:

You may need to either static your container IPs or request them by their hostname. To use DNS, set the container host name (one way is to set container_name), eg:

and in nginx conf file:

should work because they are on the same container network.

You will need to also set up nginx to receive DNS from docker, in case a container needs to restart or change. There are tutorials on how to do this elsewhere.

docker php nginx mysql phpmyadmin

Two issues with your code :

First :-

/var/dockervolumes/nginx:/etc/nginx This doesn’t let nginx start inside container because nginx configuration doesn’t get auto-created due to volume binding.

Try using docker ps command to verify.

Using /var/dockervolumes/nginx:/etc/nginx/conf.d works

I am assuming you will place your default.conf file inside conf.d folder

Note: If you bind any directory inside container to host system, that directory is not initialised by container.

Second :-

You assuming that localhost inside your container and you real host is same.

Use proxy_pass http://phpmatest; that will work because your service name is phpmatest

Note: If you create a customer docker network i.e dbtest in your case. All services using same network are directly accessible by their name i.e phpmatest in your case.

Источник

Разработка под Docker. Локальное окружение. Часть 2 — Nginx+PHP+MySql+phpMyAdmin

Для лучшего понимания нижеследующего материала сначала рекомендуется ознакомится с Предыдушим постом

Рассмотрим пример развертки локального окружения состоящего из связки Nginx+PHP+MySql+phpMyAdmin. Данная связка очень популярна и может удовлетворить ряд стандартных потребностей рядового разработчика.

Как и в прошлом посте акцент будет смещен в сторону утилиты docker-compose, чем докера в чистом виде.

Итак, поехали!

Начнем вот с такого docker-compose.yml, который лежит в отдельной папке proxy:

В представленном файле описана конфигурация для создания одного контейнера с именем proxy на базе образа image: jwilder/nginx-proxy и создание сети с одноименным именем. Директива networks указывает к каким сетям подключен контейнер, в данном примере, это наша сеть proxy.

При создание сети директиву driver: bridge можно было бы и не указывать. Драйвер типа «мост» является драйвером по умолчанию. Данный контейнер будет связываться по сети с прочими контейнерами.

Образ jwilder/nginx-proxy является базовым и взят и Docker Hub там же представлено довольно обширное и подробное описание по его использованию. Принцип работы nginx-proxy довольно простой, он через пробрасываемый сокет докера получает доступ к информации о запущенных контейнерах, анализирует наличие переменной окружения с именем VIRTUAL_HOST и перенаправляет запросы с указанного хоста на контейнер, у которого данная переменная окружения задана.

Данный вывод информирует нас о том, что в начале была создана сеть proxy_proxy, а затем был создан контейнер proxy_proxy_1. Имя сети получилось из названия папки, в которой размещался файл docker-compose.yml, у меня это proxy и одноименного имени сети.

Если ввести команду docker network ls, то мы увидим список сетей докера в нашей системе и одна из них должна быть proxy_proxy.

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

Создаем второй docker-compose.yml следующего содержания:

Что тут у нас объявлено?

Перечислены четыре сервиса: nginx, php, mysql и phpmyadmin. И две сети. Одна сеть прокси с именем frontend, объявлена как внешняя сеть и новая внутренняя сеть backend. Драйвер для нее не указан, как и писал ранее, будет использоваться драйвер по умолчанию типа bridge.

nginx

Тут примерно должно быть все понятно. Используем базовый образ с докер хаб. Переменная окружения необходима для работы прокси и сообщает ему, по какому адресу должен быть доступен контейнер. Опция depends_on указывает, на зависимость данного контейнера от контейнера php. Это означает, что вперед будет запущен контейнер php, а после него будет выполнен запуск зависимого от него контейнера nginx. Далее пробрасываем конфигурацию для нашего nginx. Она будет чуть ниже и монтируем папку с html. Так же замечаем, что контейнер имеет доступ сразу к двум сетям. Он должен связываться и прокси из сети frontend и с php из сети backend. В принципе, можно было бы все контейнеры и в одну сеть frontend попихать, но я придерживаюсь, что подобное разделение более верное.

default.nginx — это конфиг для nginx, который пробрасывается в контейнер. Ключевой момент тут директива fastcgi_pass php:9000. Она задает адрес FastCGI-сервера. Адрес может быть указан в виде доменного имени или IP-адреса, и порта.

php:9000 — имя сервиса это и есть адрес FastCGI-сервера. Nginx обращаясь по адресу php будет получать IP-адрес контейнера, в котором работает php. Порт 9000 это стандартный порт, он объявлен при создание базового контейнера. Данный порт доступен для nginx по сети, но не доступен на хостовой машине, так как не был проброшен.

Тут необычно то, что не указан образ. Вместо этого происходит сборка собственного образа прямо из compose-файла. Директива context указывает на папку, в которой находится Dockerfile.

В Dockerfile указано, что для сборки используется базовый образ php:7.3.2-fpm, далее выполняется запуск команд для установки php-расширений. Далее копируется composer из другого базового образа и устанавливается рабочая директория для проекта. Детальнее вопросы сборки рассмотрю в других постах.

Также во внутрь контейнера пробрасывается файл php.ini и папка html с нашим проектом.

Заметим, что php находится в сети backend и к примеру прокси к нему доступ получить уже не может.

mysql

База находится в сети backend, что позволяет ей держать связь с php. В базовом образе используется стандартный порт 3306. Он доступен по сети докера для php, но не доступен на хостовой машине. Если выполнить проброс для данного порта, то можно к нему коннектиться к примеру из того же PHPSTORM. Но если вам достаточно интерфейса phpmyadmin, то этого можно и не делать.

phpmyadmin

Официальный образ phpmyadmin. В переменных окружения используется VIRTUAL_HOST для взаимодействия с прокси, аналогично nginx. PMA_USER и PMA_PASSWORD доступ к базе. И PMA_HOST сам хост базы. Но это не localhost, как обычно бывает, а mysql. Т.е. связь с базой доступна по имени ее сервиса, т.е. mysql. Контейнер phpmyadmin может связаться с базой, т.к имеет подключение к сети backend.

Видим следующий вывод:

Видим, что в начале происходит создание сети lesson2_backend, затем сборка образа php, потом может происходить скачивание образов, которых еще нет в системе (pull) и собственно запуск описанных сервисов.

Последний штрих, чтобы все заработало это добавление в hosts или доменов site.local и phpmyadmin.local.

Содержимое index.php может быть следующим:

Тут мы проверяем корректность подключения расширения php — mysqli, которое было добавлено при сборке Dockerfile.

И заметим, что для связи с контейнером используется название сервиса — mysql.

Структура всего проекта получилась следующей:

Источник

Разворачиваем связку Nginx+Php-Fpm+MySQL с magento2 на борту и раскладываем по контейнерам в Docker

Все чаще стучась в различные компании разработчиков в качестве DevOps инженера, я получаю приблизительно одни и те же тестовые задания. Они отличаются друг от друга версиями PHP или проектами которые надо запустить.

Но в целом они упираются в одну связку это Nginx\Appache, SQL (тут вариаций много, все зависит от предпочтений заказчика), PHP и желательно чтобы это было разложено по контейнерам.
Поэтому я решил рассказать на примере, как все это поднять без особых усилий.

Возможно кому-то это поможет понять, на простом примере, что к чему. Описывать что такое Docker я не буду, т.к. статей на эту тему вагон и маленькая тележка.

В данной статье, мы подготовим небольшую структуру:

Все зависит от системы в которой вы хотите работать, в отношении кроссплатформенности, docker приятно удивляет (один и тот же файл конфигурации позволяет собрать и запустить контейнеры на любой системе *nix, Win, iOS).

Для Linux (к примеру в CentOS)

Включаем и стартуем сервис:

Чтобы наша структура создавалась одной командой нам потребуется docker-compose.

Для начала поставим необходимые для него компоненты:

Дальше устанавливаем docker-compose и обновляем python:

(или # pip install docker-compose)

Для Win систем (многие считают это извращением)

Но если вы решили, настоятельно рекомендую вам это делать на версии которая поддерживает Hyper-V (например win10 Prof).

Включаем компонент Hyper-V в «Включении и отключении компонентов Windows» (Turn Windows features on or of).

Скачиваем установщик с оф.сайта докера и устанавливаем. Также, дополнительно вы можете поставить GUI (Kitematiс) для наглядного отображения.

Приступим к созданию окружения:

Для начала создадим под этот проект папку и заходим в нее:

Дальше строим структуру папок таким образом:

Создаем понятную среду для nginx:

MySQL — в этой папке будут храниться базы. Удобно бэкапить и переносить.
Nginx — тут будут храниться логи, файл конфигурации и наш проект.
PHP — сюда мы сложим Dockerfile с настройками и php.ini.
в корне (в нашем случе папка /mage) будет лежать файл docker-compose.yml.

Создадим конфигурационный файл для Nginx:

Можно использовать любой другой редактор. Если его нет — можно установить с помощью:

И добавляем в nginx.conf следующее:

Во втором блоке прописываем параметры fastcgi.

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

В папке www создаем каталог для нашего проекта:

Скачиваем с оф.сайта magento2
и извлекаем из архива в папку /mage/Nginx/www/magento2

C настройками для Nginx мы закончили.

Теперь займемся PHP:

Начнем с Dockerfile

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

В этом файле мы рассказали что должно быть установленно в этом образе, а так же указали где будет располагаться корневая директория и куда скопировать настройки из php.ini

Теперь настроим php.ini:

Это взято из php.ini.sample который предлагают сами разработчики Magento2. Нечего сверхъестественного я в него не добавлял.

Все, на этом настройка PHP закончена.

Дальше создаем файл docker-compose который нам все соберет в одну удобную систему.

Тут мы распишем какие сервисы и с какими настройками должны запуститься:

И по экрану побегут строчки, а вы спокойно можете налить себе кружечку горячего кофе, пока машина будет работать за вас.

После установки, у вас в папке MySQL, создастся много файлов и папок, одна из которых будет magento2, а в папке Nginx/Logs появятся 2 лога.

Открыв браузер и набрав там localhost вы должны увидеть приглашение к установке Magento2.

Если все таки что-то не получилось, то возможно этот список решений, сможет вам помочь:

1) Версия docker-compose файла не подошла, тогда нужно поправить «version: ‘3.3’», посмотреть какая именно подойдет вам можно тут

2) Все нормально запустилось, но браузер открывает чистую страницу, без единой ошибки — поможет строчка в nginx.conf

3) Если после установки самой Magento2 (в браузере) у вас не прорисовываются фреймы и все выглядит как текстовый вариант сайта, вам нужно сделать следующее:

3.1 в SQL, советую зайти через phpmyadmin localhost:8090 логин root пароль mypassword, выбрать базу magento2 и ввести sql запрос

3.2 подключиться к контейнеру c PHP (php-fpm) и набрать

Он должен пересчитать и проверить все. И после этого все корректно должно отображаться.

4.1 в линуксе надо отключить политику защиты

Отключение до перезагрузки

или отключение навсегда

4.2 В windows нужно в настройках docker выбрать shared drivers и выбрать диск на котором у вас лежит проект. После перезапуска Docker проблема уйдет.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *