Ana içeriğe atla
OneSignal Databricks entegrasyonu

OneSignal Databricks entegrasyonuna genel bakış


Genel Bakış

OneSignal + Databricks entegrasyonu iki yönlü veri senkronizasyonunu destekler:
  • Analitik, kontrol panelleri ve raporlama için OneSignal mesaj olaylarını Databricks’e aktarın.
  • Yolculukları ve kişiselleştirilmiş kampanyaları tetiklemek için Databricks’ten OneSignal’e özel olayları içe aktarın.
Etkileşim ve davranışsal verilerinizi platformlar arası birleştirmek ve veriye dayalı mesajlaşma stratejileri yürütmek için bu entegrasyonu kullanın.

OneSignal Olaylarını Databricks’e Aktarma

Gerçek zamana yakın analitik ve görünürlük için OneSignal’den push, e-posta, uygulama içi ve SMS olaylarını Databricks lakehouse’unuza senkronize edin. Gereksinimler
  • Profesyonel Plan
  • Özel Olaylar etkinleştirilmiş (olay içe aktarmaları için)
  • Databricks Platformu: AWS, Azure veya GCP
  • Databricks Planı: Premium veya üzeri
  • Databricks Unity Catalog (yönetişim için önerilir)
  • Sorgulama için Databricks SQL Warehouse
  • Delta Lake olay tabloları (özel olay içe aktarma için)
Kurulum Adımları

1. SQL Warehouse Detaylarını Toplayın

1

Databricks çalışma alanınızda oturum açın

Databricks çalışma alanınızda SQL Warehouses bölümüne gidin.
2

Warehouse'unuzu seçin

Warehouse’unuzu seçin ve Connection details sekmesini açın.
3

Aşağıdaki detayları kaydedin

  • Server Hostname
  • Port
  • HTTP Path
Fivetran kurulumu için Databricks SQL bağlantı detayları

Fivetran kurulumu için Databricks SQL bağlantı detayları

2. Bir Service Principal Oluşturun

1

Service Principals sayfasına gidin

Workspace Settings > Identity and Access > Service Principals yolunu izleyin.
2

Yeni bir service principal ekleyin

Add Service Principal’a, ardından Add New’e tıklayın.
3

Service principal'ı adlandırın

Bir isim verin (örneğin, onesignal-sync).
Service principal ekleme modalı, 'Add new' seçeneği vurgulanmış

Service principal ekleme modalı, 'Add new' seçeneği vurgulanmış

3. Bir Secret Oluşturun

1

Oluşturulan principal'a tıklayın

2

Secrets sekmesine gidin

3

Bir secret oluşturun

Generate Secret’a tıklayın ve güvenli bir şekilde kaydedin.
Secret yalnızca bir kez görülebilir—güvenli bir şekilde saklayın.
API kimlik doğrulaması için OAuth secret ve client ID'yi gösteren Databricks 'Generate secret' modalı

API kimlik doğrulaması için OAuth secret ve client ID'yi gösteren Databricks 'Generate secret' modalı

4. İzinleri Atayın

1

Catalog'unuza gidin ve Permissions sekmesini açın

2

Grant'e tıklayın

3

Service principal'a aşağıdaki izinleri atayın

  • USE CATALOG
  • USE SCHEMA
  • SELECT
  • MODIFY
  • CREATE SCHEMA
  • CREATE TABLE
Özel catalog izinleri seçilmiş bir Databricks principal için yetki atama ekranı

Özel catalog izinleri seçilmiş bir Databricks principal için yetki atama ekranı.

5. OneSignal’i Bağlayın

1

Entegrasyonu etkinleştirin

OneSignal’de Data > Integrations > Databricks yolunu izleyin.
2

Detayları girin

  • Server Hostname
  • Port
  • HTTP Path
  • Catalog Name
  • Schema Name
  • Service Principal kimlik bilgileri (ID + Secret)
Catalog, hostname, HTTP path ve OAuth kimlik bilgileri için alanları içeren OneSignal Databricks Yapılandırma formu

Catalog, hostname, HTTP path ve OAuth kimlik bilgileri için alanları içeren OneSignal Databricks Yapılandırma formu.

3

Entegrasyonu yapılandırın

  • Sync Frequency: her 15 dakikada bir kadar sık
  • Dataset/Table Names: onesignal_events_<app-id> ve message_events olarak önceden ayarlanmıştır (düzenlenebilir)
  • Event Types: hangi olayların senkronize edileceğini seçin—tümünü veya yalnızca ihtiyacınız olanları seçin
4

Olayları seçin

Databricks catalog’unuzda almak istediğiniz olayları seçin.
Senkronizasyon durumunu, veri seti yapılandırmasını ve seçili mesaj olay türlerini gösteren OneSignal olay dışa aktarma ayarları ekranı

Senkronizasyon durumunu, veri seti yapılandırmasını ve seçili mesaj olay türlerini gösteren OneSignal olay dışa aktarma ayarları ekranı.

5

Kurulumu tamamlayın

Save’e tıklayın ve başarı onayını bekleyin
İlk veri senkronizasyonunun BigQuery’de görünmesi 15-30 dakika sürebilir.Beklerken, seçilen olayları tetiklemek için push, e-posta, uygulama içi veya SMS yoluyla mesajlar gönderin.

6. Databricks’te Verileri Görüntüleyin

  1. Databricks’te Catalog’unuzu açın.
  2. Senkronizasyon tamamlandığında, yapılandırılmış şemanız görünecektir.
  3. message_events tablosuna erişin ve sorgulayın.
    Bir üretim şeması altında OneSignal mesaj olayları tablosunu gösteren Databricks Catalog görünümü

    Bir üretim şeması altında OneSignal mesaj olayları tablosunu gösteren Databricks Catalog görünümü.

  4. Örnek veri önizlemesi için tablolara tıklayın.
    Senkronize edilmiş OneSignal olay alanları ile message_events_1 tablosundan örnek veriler

    Senkronize edilmiş OneSignal olay alanları ile message_events_1 tablosundan örnek veriler.

Eksik şemalar, izin hataları veya hatalı biçimlendirilmiş olaylar gibi sorunlarla karşılaşırsanız, support@onesignal.com ile iletişime geçin.

Message events and properties

Message event kinds

Property: event_kind Type: String The kind of message and event (e.g. message.push.received, message.push.sent).
Message Event (OneSignal)event_kindDescription
Push Sentmessage.push.sentPush notification successfully sent.
Push Receivedmessage.push.receivedDelivered push (see Confirmed Delivery).
Push Clickedmessage.push.clickedUser clicked the push.
Push Failedmessage.push.failedDelivery failure. See message reports.
Push Unsubscribedmessage.push.unsubscribedUser unsubscribed from push.
In-App Impressionmessage.iam.displayedIn-App message shown.
In-App Clickedmessage.iam.clickedIn-App message clicked.
In-App Page Viewedmessage.iam.pagedisplayedIn-App page shown.
Email Sentmessage.email.sentEmail delivered.
Email Receivedmessage.email.receivedEmail accepted by recipient’s mail server.
Email Openedmessage.email.openedEmail opened. See Email Reports.
Email Link Clickedmessage.email.clickedLink in email clicked.
Email Unsubscribedmessage.email.unsubscribedRecipient unsubscribed.
Email Marked Spammessage.email.resporedasspamMarked as spam. See Email Deliverability.
Email Bouncedmessage.email.hardbouncedBounce due to permanent delivery failure.
Email Failedmessage.email.failedDelivery failed.
Email Suppressedmessage.email.supressedSuppressed due to suppression list.
SMS Sentmessage.sms.sentSMS sent.
SMS Deliveredmessage.sms.deliveredSMS successfully delivered.
SMS Failedmessage.sms.failedSMS failed to deliver.
SMS Undeliveredmessage.sms.undeliveredSMS rejected or unreachable.

Event data schema

For each message event generated by a user, the following metadata will be attached to the record.
Column NameTypeDescription
event_idUUIDUnique identifier for the event
event_timestampTimestampTime of event occurrence
event_kindStringThe Event Kind
subscription_device_typeStringDevice type (e.g., iOS, Android, Web, Email, SMS)
languageStringSubscription language code
versionStringIntegration version
device_osStringDevice operating system version
device_typeNumberNumeric device type
tokenStringPush token, phone number, or email
subscription_idUUIDSubscription ID
subscribedBooleanSubscription status
onesignal_idUUIDOneSignal user ID
last_activeStringLast active timestamp
sdkStringOneSignal SDK version
external_idStringExternal user ID that should match the integration user ID
app_idUUIDApp ID from OneSignal
template_idUUIDTemplate ID (if applicable)
message_idUUIDMessage batch/request ID
message_nameStringName of the message
message_titleStringMessage title (English only)
message_contentsStringTruncated message body (English only)
_created, _id, _index, _fivetran_syncedInternal useFivetran sync metadata

Notes

  • Syncs after saving/activating may take an additional 15-30 minutes to complete.
  • Deactivating may still result in one final sync after deactivation.
  • To ensure efficient data synchronization, our system automatically creates and manages staging datasets. These datasets, named with a pattern like fivetran_{two random words}_staging, temporarily store data during processing before it’s integrated into your main schema. These staging datasets are essential for maintaining a streamlined workflow and should not be deleted, as they will be automatically recreated.

Databricks’ten Olayları İçe Aktarma

Aşağıdakiler için Databricks’ten OneSignal’e davranışsal olay verilerini gönderin:
  • Kullanıcı etkinliğine dayalı Yolculukları tetikleyin
  • Davranışsal verilere dayalı mesajlaşmayı kişiselleştirin
Gereksinimler
  • SQL Warehouse veya compute cluster ile Databricks workspace
  • Uygun izinlere sahip Personal Access Token
  • Delta Lake formatında davranışsal veriler içeren Olay veri tabloları
  • Unity Catalog (veri yönetişimi için önerilir)
Kurulum Adımları
1

Databricks Personal Access Token Oluşturun

OneSignal’in Databricks çalışma alanınıza erişmesi için bir Personal Access Token oluşturun:
  1. Databricks çalışma alanınızda User Settings’e gidin
  2. Developer sekmesine ve ardından Access tokens’a tıklayın
  3. Generate new token’a tıklayın
  4. “OneSignal Integration” gibi bir yorum girin ve son kullanma tarihi belirleyin (90 gün önerilir)
  5. Oluşturulan token’ı kaydedin (OneSignal için buna ihtiyacınız olacak)
2

SQL Warehouse erişimini yapılandırın

OneSignal’in SQL Warehouse aracılığıyla olay verilerinizi sorgulayabildiğinden emin olun:
  1. Databricks çalışma alanınızda SQL Warehouses’a gidin
  2. OneSignal erişimi için bir SQL Warehouse seçin veya oluşturun
  3. Bağlantı detaylarından Server Hostname ve HTTP Path’i not edin
  4. Warehouse’un olay veri tablolarınıza erişimi olduğundan emin olun
3

Tablo izinlerini verin

OneSignal’e olay verilerini içeren tablolara okuma erişimi verin:
-- Unity Catalog etkinleştirilmiş workspace'ler için
GRANT SELECT ON TABLE catalog.schema.event_table TO `onesignal@yourdomain.com`;

-- Hive metastore tabloları için
GRANT SELECT ON TABLE database.event_table TO `onesignal@yourdomain.com`;
4

OneSignal'de entegrasyonu ekleyin

In OneSignal, go to Data > Integrations and click Add Integration.Databricks’i seçin ve şunları sağlayın:
  • Server Hostname: Databricks SQL Warehouse hostname’iniz
  • HTTP Path: SQL Warehouse HTTP path’i
  • Personal Access Token: 1. adımda oluşturulan token
  • Catalog (isteğe bağlı): Unity Catalog kullanıyorsanız Unity Catalog adı
5

Olay veri kaynağını yapılandırın

Olay verilerinizi içeren Databricks tablosunu belirtin:
  • Database/Schema: Olay tablolarını içeren veritabanı veya şema adı
  • Table: Olay kayıtlarını içeren tablo adı (örneğin, user_events)
  • Event Query: Olay verilerini filtrelemek veya dönüştürmek için isteğe bağlı SQL sorgusu
Olay tablonuz şunlar için sütunlar içermelidir:
  • Olay adı/türü (String)
  • Kullanıcı tanımlayıcısı (String)
  • Olay zaman damgası (Timestamp)
  • Ek olay özellikleri
6

Bağlantıyı test edin

OneSignal’in Databricks çalışma alanınıza erişebildiğini ve olay verilerini okuyabildiğini doğrulamak için Test Connection’a tıklayın.

Event data mapping

Map your to OneSignal’s custom events format:
OneSignal FieldDescriptionRequired
nameevent_nameEvent identifierYes
external_iduser_idUser identifierYes
timestampevent_timestampWhen event occurredNo
propertiesevent_dataNo

Gelişmiş Yapılandırma

Unity Catalog Entegrasyonu

Yönetilen veri erişimi için Unity Catalog’dan yararlanın:
SELECT
  event_name,
  user_id,
  event_timestamp,
  to_json(
    named_struct(
      'product_id', product_id,
      'purchase_amount', purchase_amount,
      'category', category
    )
  ) as payload
FROM catalog.schema.user_events
WHERE event_timestamp >= current_timestamp() - INTERVAL 7 DAYS

Delta Lake Optimizasyonu

Daha iyi sorgu performansı için olay tablolarını optimize edin:
  • Partitioning: Daha hızlı zamana dayalı sorgular için tarihe göre bölümlendirin (event_date)
  • Z-Ordering: Daha iyi filtreleme için user_id ve event_name’e göre Z-order uygulayın
  • Delta Lake Features: Otomatik optimizasyon için liquid clustering kullanın

Streaming Event Processing

Gerçek zamanlı olay işleme için şunları göz önünde bulundurun:
  • Structured Streaming: Olayları geldikçe işleyin
  • Delta Live Tables: Sağlam olay işleme hattları oluşturun
  • Auto Loader: Yeni olay dosyalarını sürekli olarak alın
SQL Warehouse’unuzun diğer iş yüklerini etkilemeden OneSignal’in sorgularını işlemek için yeterli işlem kaynaklarına sahip olduğundan emin olun.

SSS

Neden aynı içeriğe sahip farklı mesaj ID’leri görüyorum?

Bu, aynı mesajın birden fazla kez gönderilmesi durumunda olur; muhtemelen işlemsel bir akış aracılığıyla veya birden fazla gönderimde yeniden kullanılan bir mesaj şablonu.

OneSignal Databricks’ten olayları ne sıklıkla senkronize eder?

OneSignal, minimum 15 dakikalık aralıklarla yapılandırılmış programınıza göre olay verilerini senkronize eder.

Olay işleme için Databricks notebook’larını kullanabilir miyim?

Evet, olay verilerini işlemek ve hazırlamak için notebook’lar kullanabilir, ardından OneSignal’in sorgulayabileceği tablolar aracılığıyla sunabilirsiniz.

Olay sorguları için maliyet optimizasyonu hakkında ne söylenebilir?

Sorgu yüküne göre otomatik olarak ölçeklenen maliyet etkin, isteğe bağlı işlem için serverless SQL Warehouse’ları kullanmayı düşünün.