remote позволяет обращаться к удалённым серверам на лету, то есть без создания Distributed таблицы. Табличная функция remoteSecure аналогична remote, но использует защищённое соединение.
Обе функции можно использовать в запросах SELECT и INSERT.
Синтаксис
Параметры
| Аргумент | Описание |
|---|---|
addresses_expr | Адрес удалённого сервера или выражение, генерирующее несколько адресов удалённых серверов. Формат: host или host:port.host можно указать как имя сервера либо как адрес IPv4 или IPv6. Адрес IPv6 необходимо указывать в [].port — TCP-порт удалённого сервера. Если порт не указан, используется tcp_port из файла конфигурации сервера для табличной функции remote (по умолчанию 9000) и tcp_port_secure для табличной функции remoteSecure (по умолчанию 9440).Для адресов IPv6 указание порта обязательно. Если указан только параметр addresses_expr, для db и table по умолчанию используется system.one.Тип: String. |
db | Имя базы данных. Тип: String. |
table | Имя таблицы. Тип: String. |
user | Имя пользователя. Если не указано, используется default. Тип: String. |
password | Пароль пользователя. Если не указан, используется пустой пароль. Тип: String. |
sharding_key | Ключ сегментирования для распределения данных по узлам. Например: insert into remote('127.0.0.1:9000,127.0.0.2', db, table, 'default', rand()). Тип: UInt32. |
Возвращаемое значение
Использование
remote и remoteSecure заново устанавливают соединение для каждого запроса, вместо них рекомендуется использовать таблицу Distributed. Кроме того, если указаны имена хостов, выполняется разрешение имён, а ошибки при работе с различными репликами не учитываются. При обработке большого количества запросов всегда заранее создавайте таблицу Distributed и не используйте табличную функцию remote.
Табличная функция remote может быть полезна в следующих случаях:
- Однократная миграция данных из одной системы в другую
- Доступ к конкретному серверу для сравнения данных, отладки и тестирования, то есть разовые ad hoc-подключения.
- Запросы между различными кластерами ClickHouse в исследовательских целях.
- Нечастые распределённые запросы, выполняемые вручную.
- Распределённые запросы, в которых набор серверов каждый раз задаётся заново.
Адреса
Примеры
Выборка данных с удалённого сервера:
Вставка данных в таблицу на удалённом сервере:
Миграция таблиц из одной системы в другую:
imdb, а таблица — actors.
В исходной системе ClickHouse (системе, где сейчас хранятся данные)
-
Проверьте исходную базу данных и имя таблицы (
imdb.actors) - Получите оператор CREATE TABLE в исходной системе:
В целевой системе ClickHouse
-
Создайте целевую базу данных:
-
Используя оператор CREATE TABLE из исходной системы, создайте целевую таблицу:
Возвращаемся к исходному развертыванию
Глоббинг
{ } используются для генерации набора сегментов и указания реплик. Если есть несколько пар { }, генерируется декартово произведение соответствующих наборов.
Поддерживаются следующие типы шаблонов.
{a,b,c}- Обозначает любую из альтернативных строкa,bилиc. Шаблон заменяется наaв адресе первого сегмента, наb— в адресе второго сегмента и так далее. Например,example0{1,2}-1генерирует адресаexample01-1иexample02-1.{N..M}- Диапазон чисел. Этот шаблон генерирует адреса сегментов с последовательно возрастающими индексами отNдоMвключительно. Например,example0{1..2}-1генерируетexample01-1иexample02-1.{0n..0m}- Диапазон чисел с ведущими нулями. Этот шаблон сохраняет ведущие нули в индексах. Например,example{01..03}-1генерируетexample01-1,example02-1иexample03-1.{a|b}- Любое количество вариантов, разделённых символом|. Шаблон задаёт реплики. Например,example01-{1|2}генерирует репликиexample01-1иexample01-2.
remote реплики перебираются в порядке, заданном параметром load_balancing.
Количество генерируемых адресов ограничено параметром table_function_remote_max_addresses.