Главная страницаHome AssistantHome Assistant в Docker ContainerDocker часть 5: MariaDB
Docker часть 5: MariaDB

Docker часть 5: MariaDB

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

Контейнер с MariaDB

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

version: '3.0'

services:
  portainer:         # часть 2
    [...]
  homeassistant:     # часть 3
    [...]
  hass-configurator: # часть 4
    [...]

  mariadb:
    container_name: mariadb
    image: mariadb:latest
    restart: unless-stopped
    environment:
      - TZ=Europe/Moscow
      - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
      - MYSQL_DATABASE=${MYSQL_HA_DATABASE}
      - MYSQL_USER=${MYSQL_HA_USER}
      - MYSQL_PASSWORD=${MYSQL_HA_PASSWORD}
    ports:
      - "3306:3306"
    volumes:
      - ./mariadb:/var/lib/mysql

Так же создаем папку для mariadb

mkdir mariadb

Переменные окружения

Возможно вы заметили, что в docker-compose.yaml появились записи подобного типа ${MYSQL_ROOT_PASSWORD}. Они хранят конфиденциальные данные в отдельном файле. Это особенно полезно, когда мы хотим создать резервную копию и/или распространить нашу конфигурацию Docker в системе контроля версий (VCS), такой как GitHub/Gitlab.

Чтобы указать значение для этих переменных среды, создайте файл .env в том же каталоге, что и файл docker-compose.yaml.

sudo nano .env

# Так же настроим права на запись, чтобы не приходилось каждый раз писать sudo
sudo chown root:docker .env
sudo chmod g+w .env

.env файл будет выглядеть так, обязательно поменяйте пароли

MYSQL_ROOT_PASSWORD=mariadbrootpassword
MYSQL_HA_DATABASE=ha_db
MYSQL_HA_USER=homeassistant
MYSQL_HA_PASSWORD=mariadbhapassword

Зависимости контейнеров

Если перезагрузим нашу систему Docker, мы также хотим, чтобы контейнер Home Assistant перед запуском ждал, пока контейнер MariaDB запустится. Это необходимо, чтобы данные из HA не потерялись.

Поэтому добавьте следующее в запись конфигурации в контейнере homeassistant

[...]
  homeassistant:
    [...]
    depends_on:
      - mariadb

После всего перезапускам Docker

docker compose up -d

Конфигурация Home Assistant

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

Секреты

Открываем файл secrets.yaml с помощью File Editor и добавляем новую переменную. Не забудьте поменять ip адрес, а также если вы меняли пароли, то замените их.

mariadb: "mysql://homeassistant:mariadbhapassword@<ip>:3306/ha_db?charset=utf8mb4"

Соединение с базой данных

Далее переходим к configuration.yaml. В него вставляем новую запись, в которой будет происходить соединение с базой данных.

recorder:
  db_url: !secret mariadb
  purge_keep_days: 30

Перезапуск

Последним этапом заходим в интерфейс Панель разработчика и проверяем все ли правильно мы заполнили. В случае успешной проверки нажимаем «Перезапуск». Теперь база данных будет MariaDB.

Управление базой из Home Assistant

Если вам необходим доступ напрямую в базу данных, то можно установить любой web клиент. Самым простым решением будет Adminer.

Для этого добавляем новый контейнер в docker-compose.yaml

adminer:
  container_name: adminer
  image: adminer
  restart: unless-stopped
  environment:
    - ADMINER_DEFAULT_SERVER=mariadb
    - ADMINER_PLUGINS=frames
  ports:
    - "8077:8080/tcp"
  depends_on:
    - mariadb

Ну и конечно вывести его в интерфейс Home Assistant, файл configuration.yaml

panel_iframe:
  [...]
  
  adminer:
    title: Adminer
    icon: mdi:database
    url: "http://<ip>:8077"
    require_admin: true

Итоговая структура проекта

home-assistant
├── .env
├── docker-compose.yaml
├── fileeditor
├── homeassistant
├── mariadb
│   └── ...
└── portainer

Список всех частей

Был ли полезен материал?

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

Комментарии
  • Александр
    Александр
    03.10.2023 00:05

    Можете помочь, не пойму какой ip вставлять? По каким адресам контейнеры между собой общаються?

    • Alexander Pushkarev
      Alexander Pushkarev
      03.10.2023 11:15

      Про какой шаг идет речь?

  • Алексей
    Алексей
    13.12.2023 21:51

    Спасибо за отменный материал.

    Хотелось бы уточнить один момент для будущих последователей.
    Настанет момент когда будете делать сенсор в HA который будет отображать объем места занимаемой системой MySql

    Запрос подают такой

    SELECT table_schema "database", Round(Sum(data_length + index_length) / 1048576, 2) "value"
    FROM information_schema.tables
    WHERE table_schema="homeassistant"
    GROUP BY table_schema;

    и вот тут у меня он возвращал пустоту — table_schema="homeassistant" — не было такой записи
    Стал писать вопрос сюда и обозревая текст запроса и структуру баз — догал, что table_schema — это имя БД homeassistant, которое вы указали в настройках docker-compose. Т.к. я не иду простыми путями и даю свои имена, вот и попался.

    Откорректируйте запрос под вашу БД

    WHERE table_schema="имя-вашей бд-homeassistant"
  • Валерий
    Валерий
    25.01.2024 23:17

    При установке марии на raspberry pi 3 по инструкции возникает ошибка no matching manifest for linux/arm/v7 in the manifest list entries
    В этом случае образ марии можно использовать yobasystems/alpine-mariadb
    (аналогичная проблема имеется с code-server, но ему решения я не искал)

    • Alexander Pushkarev
      Alexander Pushkarev
      05.02.2024 15:32

      Все так, официальный образ MariaDB не поставляется для arm/v7.

Оставить комментарий