الانتقال إلى المحتوى الرئيسي
تستعرض هذه الصفحة الخيارات التالية لدمج PostgreSQL مع ClickHouse:
  • استخدام محرك الجدول PostgreSQL للقراءة من جدول في PostgreSQL
  • استخدام محرك قاعدة البيانات التجريبي MaterializedPostgreSQL لمزامنة قاعدة بيانات في PostgreSQL مع قاعدة بيانات في ClickHouse
اطّلع على خدمة Managed Postgres الخاصة بنا. فهي تعتمد على تخزين NVMe موجود فعليًا إلى جانب موارد الحوسبة، ما يوفّر أداءً أسرع حتى 10 مرات لأحمال العمل المقيّدة بأداء القرص مقارنةً بالبدائل التي تستخدم التخزين المتصل بالشبكة مثل EBS، كما تتيح لك نسخ بيانات Postgres إلى ClickHouse باستخدام موصل Postgres CDC في ClickPipes.

استخدام محرك الجدول PostgreSQL

يتيح محرك الجدول PostgreSQL تنفيذ عمليتي SELECT وINSERT على البيانات المخزنة على خادم PostgreSQL البعيد من داخل ClickHouse. تهدف هذه المقالة إلى توضيح طرق التكامل الأساسية باستخدام جدول واحد.

1. إعداد PostgreSQL

  1. في ملف postgresql.conf، أضِف الإدخال التالي لتمكين PostgreSQL من الاستماع عبر واجهات الشبكة:
  listen_addresses = '*'
  1. أنشئ مستخدمًا للاتصال عبر ClickHouse. ولأغراض التوضيح، يمنح هذا المثال صلاحيات مستخدم فائق كاملة.
  CREATE ROLE clickhouse_user SUPERUSER LOGIN PASSWORD 'ClickHouse_123';
  1. أنشئ قاعدة بيانات جديدة في PostgreSQL:
  CREATE DATABASE db_in_psg;
  1. أنشئ جدولًا جديدًا:
  CREATE TABLE table1 (
      id         integer primary key,
      column1    varchar(10)
  );
  1. لنُضِف بضعة صفوف للاختبار:
  INSERT INTO table1
    (id, column1)
  VALUES
    (1, 'abc'),
    (2, 'def');
  1. لتهيئة PostgreSQL للسماح بإجراء اتصالات بقاعدة البيانات الجديدة باستخدام المستخدم الجديد لأغراض النسخ المتماثل، أضف الإدخال التالي إلى ملف pg_hba.conf. حدِّث سطر العنوان باستخدام الشبكة الفرعية أو عنوان IP لخادم PostgreSQL:
  # TYPE  DATABASE        USER            ADDRESS                 METHOD
  host    db_in_psg             clickhouse_user 192.168.1.0/24          password
  1. أعد تحميل إعدادات pg_hba.conf (عدّل هذا الأمر وفقًا لإصدارك):
  /usr/pgsql-12/bin/pg_ctl reload
  1. تحقّق من إمكانية تسجيل دخول المستخدم الجديد clickhouse_user:
  psql -U clickhouse_user -W -d db_in_psg -h <your_postgresql_host>
إذا كنت تستخدم هذه الميزة في ClickHouse Cloud، فقد تحتاج إلى السماح لعناوين IP الخاصة بـ ClickHouse Cloud بالوصول إلى مثيل PostgreSQL لديك. راجع واجهة برمجة تطبيقات Cloud Endpoints في ClickHouse للاطّلاع على تفاصيل حركة المرور الصادرة.

2. عرّف جدولًا في ClickHouse

  1. سجّل الدخول إلى clickhouse-client:
  clickhouse-client --user default --password ClickHouse123!
  1. لننشئ قاعدة بيانات جديدة:
  CREATE DATABASE db_in_ch;
  1. أنشئ جدولًا يستخدم PostgreSQL:
  CREATE TABLE db_in_ch.table1
  (
      id UInt64,
      column1 String
  )
  ENGINE = PostgreSQL('postgres-host.domain.com:5432', 'db_in_psg', 'table1', 'clickhouse_user', 'ClickHouse_123');
الحد الأدنى من المعلمات المطلوبة هو:
المعلمةالوصفالمثال
host:portاسم المضيف أو عنوان IP والمنفذpostgres-host.domain.com:5432
databaseاسم قاعدة بيانات PostgreSQLdb_in_psg
userاسم المستخدم للاتصال بـ Postgresclickhouse_user
passwordكلمة المرور للاتصال بـ PostgresClickHouse_123
راجع صفحة وثائق محرك الجدول PostgreSQL للحصول على قائمة كاملة بالمعلمات.

3 اختبر التكامل

  1. في ClickHouse، اعرض الصفوف المبدئية:
  SELECT * FROM db_in_ch.table1
يجب أن يُملأ جدول ClickHouse تلقائيًا بالصفّين اللذين كانا موجودين بالفعل في جدول PostgreSQL:
  Query id: 34193d31-fe21-44ac-a182-36aaefbd78bf

  ┌─id─┬─column1─┐
  │  1 │ abc     │
  │  2 │ def     │
  └────┴─────────┘
  1. في PostgreSQL مرة أخرى، أضف صفَّين إلى الجدول:
  INSERT INTO table1
    (id, column1)
  VALUES
    (3, 'ghi'),
    (4, 'jkl');
  1. من المفترض أن يظهر هذان الصفّان الجديدان في جدول ClickHouse لديك:
  SELECT * FROM db_in_ch.table1
يجب أن تكون الاستجابة كما يلي:
  Query id: 86fa2c62-d320-4e47-b564-47ebf3d5d27b

  ┌─id─┬─column1─┐
  │  1 │ abc     │
  │  2 │ def     │
  │  3 │ ghi     │
  │  4 │ jkl     │
  └────┴─────────┘
  1. لنرَ ما يحدث عند إضافة صفوف إلى جدول ClickHouse:
  INSERT INTO db_in_ch.table1
    (id, column1)
  VALUES
    (5, 'mno'),
    (6, 'pqr');
  1. يجب أن تظهر الصفوف المضافة إلى ClickHouse في الجدول في PostgreSQL:
  db_in_psg=# SELECT * FROM table1;
  id | column1
  ----+---------
    1 | abc
    2 | def
    3 | ghi
    4 | jkl
    5 | mno
    6 | pqr
  (6 rows)
عرض هذا المثال التكامل الأساسي بين PostgreSQL وClickHouse باستخدام محرك الجدول PostrgeSQL. اطّلع على صفحة التوثيق الخاصة بمحرك جدول PostgreSQL لمزيد من الميزات، مثل تحديد المخططات، وإرجاع مجموعة فرعية من الأعمدة فقط، والاتصال بعدة نُسخ متماثلة. واطّلع أيضًا على مدونة ClickHouse and PostgreSQL - a match made in data heaven - part 1.

استخدام محرك قاعدة البيانات MaterializedPostgreSQL

يستخدم محرك قاعدة البيانات PostgreSQL ميزات النسخ المتماثل في PostgreSQL لإنشاء نسخة مطابقة من قاعدة البيانات تتضمن جميع المخططات والجداول أو مجموعة فرعية منها. تهدف هذه المقالة إلى توضيح الأساليب الأساسية للتكامل باستخدام قاعدة بيانات واحدة ومخطط واحد وجدول واحد. في الإجراءات التالية، يُستخدم PostgreSQL CLI ‏(psql) وClickHouse CLI ‏(clickhouse-client). خادم PostgreSQL مُثبّت على Linux. وفيما يلي الحد الأدنى من الإعدادات إذا كانت قاعدة بيانات PostgreSQL عبارة عن تثبيت اختباري جديد

1. في PostgreSQL

  1. في postgresql.conf، عيّن الحد الأدنى لمستويات الاستماع، ومستوى WAL للنسخ المتماثل، وفتحات النسخ المتماثل:
أضِف الإدخالات التالية:
listen_addresses = '*'
max_replication_slots = 10
wal_level = logical
*يتطلب ClickHouse حدًا أدنى لمستوى wal يبلغ logical، وحدًا أدنى قدره 2 من replication slots
  1. باستخدام حساب مسؤول، أنشئ مستخدمًا لكي يتصل ClickHouse من خلاله:
CREATE ROLE clickhouse_user SUPERUSER LOGIN PASSWORD 'ClickHouse_123';
*لأغراض التوضيح، مُنحت صلاحيات المستخدم الفائق الكاملة.
  1. أنشئ قاعدة بيانات جديدة:
CREATE DATABASE db1;
  1. اتصل بقاعدة البيانات الجديدة باستخدام psql:
\connect db1
  1. أنشئ جدولًا جديدًا:
CREATE TABLE table1 (
    id         integer primary key,
    column1    varchar(10)
);
  1. أضف الصفوف الأولية:
INSERT INTO table1
(id, column1)
VALUES
(1, 'abc'),
(2, 'def');
  1. اضبط PostgreSQL للسماح بالاتصال بقاعدة البيانات الجديدة باستخدام المستخدم الجديد لأغراض النسخ المتماثل. فيما يلي الحد الأدنى من الإدخالات التي يجب إضافتها إلى ملف pg_hba.conf:
# TYPE  DATABASE        USER            ADDRESS                 METHOD
host    db1             clickhouse_user 192.168.1.0/24          password
*لأغراض العرض التوضيحي، تُستخدم هنا طريقة المصادقة بكلمة مرور بنص صريح. حدِّث سطر العنوان ليستخدم إمّا الشبكة الفرعية أو عنوان الخادم وفقًا لوثائق PostgreSQL
  1. أعد تحميل إعداد pg_hba.conf بشيءٍ مثل هذا (عدِّله بما يناسب إصدارك):
/usr/pgsql-12/bin/pg_ctl reload
  1. اختبر تسجيل الدخول باستخدام اسم المستخدم الجديد clickhouse_user:
 psql -U clickhouse_user -W -d db1 -h <your_postgresql_host>

2. في ClickHouse

  1. سجّل الدخول إلى ClickHouse CLI
clickhouse-client --user default --password ClickHouse123!
  1. فعِّل الميزة التجريبية لـ PostgreSQL في محرك قاعدة البيانات:
SET allow_experimental_database_materialized_postgresql=1
  1. أنشئ قاعدة البيانات الجديدة التي ستخضع للنسخ المتماثل، وعرّف الجدول الأولي:
CREATE DATABASE db1_postgres
ENGINE = MaterializedPostgreSQL('postgres-host.domain.com:5432', 'db1', 'clickhouse_user', 'ClickHouse_123')
SETTINGS materialized_postgresql_tables_list = 'table1';
الحد الأدنى من الخيارات:
المعلمةالوصفمثال
host:portاسم المضيف أو عنوان IP والمنفذpostgres-host.domain.com:5432
databaseاسم قاعدة بيانات PostgreSQLdb1
userاسم المستخدم للاتصال بـ Postgresclickhouse_user
passwordكلمة المرور للاتصال بـ PostgresClickHouse_123
settingsإعدادات إضافية للمحرّكmaterialized_postgresql_tables_list = ‘table1’
للاطلاع على الدليل الكامل لمحرك قاعدة البيانات PostgreSQL، راجع https://clickhouse.com/docs/engines/database-engines/materialized-postgresql/#settings
  1. تحقّق من أن الجدول الأول يحتوي على بيانات:
ch_env_2 :) select * from db1_postgres.table1;

SELECT *
FROM db1_postgres.table1
Query id: df2381ac-4e30-4535-b22e-8be3894aaafc

┌─id─┬─column1─┐
│  1 │ abc     │
└────┴─────────┘
┌─id─┬─column1─┐
│  2 │ def     │
└────┴─────────┘

3. اختبار النسخ المتماثل الأساسي

  1. في PostgreSQL، أضِف صفوفًا جديدة:
INSERT INTO table1
(id, column1)
VALUES
(3, 'ghi'),
(4, 'jkl');
  1. في ClickHouse، تأكّد من ظهور الصفوف الجديدة:
ch_env_2 :) select * from db1_postgres.table1;

SELECT *
FROM db1_postgres.table1
Query id: b0729816-3917-44d3-8d1a-fed912fb59ce

┌─id─┬─column1─┐
│  1 │ abc     │
└────┴─────────┘
┌─id─┬─column1─┐
│  4 │ jkl     │
└────┴─────────┘
┌─id─┬─column1─┐
│  3 │ ghi     │
└────┴─────────┘
┌─id─┬─column1─┐
│  2 │ def     │
└────┴─────────┘

4. الملخص

ركّز دليل التكامل هذا على مثال بسيط يوضّح كيفية إجراء النسخ المتماثل لقاعدة بيانات تضم جدولًا واحدًا، لكن تتوفر أيضًا خيارات أكثر تقدمًا، مثل إجراء النسخ المتماثل لقاعدة البيانات بالكامل أو إضافة جداول ومخططات جديدة إلى عمليات النسخ المتماثل القائمة. وعلى الرغم من أن أوامر DDL غير مدعومة في هذا النوع من النسخ المتماثل، يمكن تهيئة المحرّك لاكتشاف التغييرات وإعادة تحميل الجداول عند إجراء تغييرات هيكلية.
للاطلاع على مزيد من الميزات المتاحة ضمن الخيارات المتقدمة، يُرجى مراجعة الوثائق المرجعية.
آخر تعديل في ٢٩ يونيو ٢٠٢٦