İçeriğe geç

Platform Mimarisi

inSCADA, saha cihazlarından veri toplamak, işlemek, görselleştirmek ve otomasyon kurmak için tasarlanmış bir SCADA platformudur. Tek bir uygulama olarak çalışır — tüm bileşenler tek dosyada birleşiktir.

inSCADA’daki tüm veriler aşağıdaki hiyerarşik yapıda organize edilir:

Space (Çalışma Alanı)
├── [Space Seviyesi Bileşenler]
│ ├── Custom Menu (Özel Menü)
│ ├── Dashboard (Pano)
│ ├── Expression (Paylaşımlı Formüller)
│ └── Symbol (SVG Sembol Kütüphanesi)
└── Project (Proje)
├── [Haberleşme]
│ └── Connection (Bağlantı)
│ └── Device (Cihaz)
│ └── Frame (Veri Çerçevesi)
│ └── Variable (Değişken)
├── [İzleme & Alarm]
│ ├── Alarm Group (Alarm Grubu)
│ │ └── Alarm Definition (Alarm Tanımı)
│ └── Trend (Trend Grafiği)
│ └── Trend Tag
├── [Otomasyon]
│ ├── Script (Otomasyon Scripti)
│ └── Data Transfer (Veri Aktarımı)
├── [Görselleştirme]
│ ├── Animation (SVG Ekran)
│ └── Faceplate (Tekrar Kullanılabilir Bileşen)
└── [Raporlama]
└── Report (Rapor)

Space, en üst seviye izolasyon birimidir. Her space kendi proje, kullanıcı ve yapılandırma setine sahiptir. Farklı space’ler birbirinden tamamen bağımsızdır.

Kullanım senaryoları:

  • Müşteri izolasyonu — her müşteri için ayrı space
  • Ortam ayrımı — geliştirme, test, üretim
  • Departman ayrımı — enerji, su, bina otomasyonu

Proje, bir tesis, saha veya mantıksal birim temsil eder. Bir space altında birden fazla proje olabilir. Projedeki tüm bileşenler (bağlantı, alarm, script, ekran vb.) proje kapsamında çalışır.

Örnek projeler:

  • “Ankara Fabrika” — bir üretim tesisi
  • “GES-01” — bir güneş enerji santrali
  • “Bina-A HVAC” — bir binanın iklimlendirme sistemi

Her projenin opsiyonel olarak enlem/boylam koordinatları olabilir ve harita ekranında görselleştirilebilir.

Bağlantı, bir saha cihazına veya sisteme olan haberleşme kanalıdır. Her bağlantı bir protokol kullanır.

Desteklenen protokoller:

GrupProtokoller
EndüstriyelMODBUS TCP/UDP/RTU, S7, EtherNet/IP, Fatek
EnerjiDNP3, IEC 60870-5-104, IEC 61850
Açık StandartOPC UA, OPC DA, OPC XML, MQTT
YerelLOCAL (simülasyon / dahili hesaplama)

Her bağlantı bağımsız olarak başlatılıp durdurulabilir ve durumu izlenebilir (Connected, Disconnected, Error).

Cihaz, bir bağlantı üzerindeki fiziksel veya mantıksal birimi temsil eder. Örneğin bir MODBUS bağlantısı üzerinde birden fazla slave cihaz olabilir.

Frame, bir cihazdan okunan veri bloğudur. Her frame belirli bir adres aralığını ve okuma periyodunu tanımlar.

ParametreAçıklama
Başlangıç AdresiOkunacak ilk adres
MiktarOkunacak register/nokta sayısı
PeriyotOkuma sıklığı (ms)

Değişken, platformdaki en temel veri birimidir. Bir sıcaklık ölçümü, bir motor durumu, bir sayaç değeri — her biri bir değişkendir.

Her değişkenin temel özellikleri:

ÖzellikAçıklama
NameBenzersiz ad (proje içinde)
TypeFloat, Integer, Boolean, String
UnitMühendislik birimi (°C, kW, bar, V, A…)
ÖlçeklemeRaw → Engineering dönüşümü (engZeroScale, engFullScale)
LoglamaTarihsel veri kayıt tipi ve periyodu
ExpressionÖzel değer hesaplama formülü

Ham (raw) değer, mühendislik değerine lineer olarak dönüştürülür:

Engineering = engZeroScale + (raw - rawZeroScale) ×
(engFullScale - engZeroScale) / (rawFullScale - rawZeroScale)

Örnek: 4-20mA sensör → 0-100°C ölçekleme:

  • Raw: 4mA → 0°C, 20mA → 100°C
  • engZeroScale=0, engFullScale=100, rawZeroScale=4, rawFullScale=20
TipAçıklama
PeriodicallySabit aralıkla kayıt (logPeriod saniye)
When ChangedDeğer değiştiğinde kayıt
NoneKayıt yok

Değişkene özel bir hesaplama formülü atanabilir. Her okuma döngüsünde bu formül çalışır ve sonucu değişkenin değeri olur:

// Örnek: Sinüs dalga simülasyonu
var t = new Date().getTime() / 1000;
return (Math.sin(t / 60) * 150 + 450).toFixed(2) * 1;

Alarmlar grup halinde organize edilir. Her alarm grubu bir proje altındadır ve toplu olarak etkinleştirilebilir/devre dışı bırakılabilir.

Project
└── Alarm Group (örn: "Sıcaklık Alarmları")
├── Alarm: Temperature_C > 60°C (Yüksek Sıcaklık)
├── Alarm: Temperature_C > 80°C (Kritik Sıcaklık)
└── Alarm: Temperature_C < 10°C (Düşük Sıcaklık)
TipAçıklamaParametreler
AnalogSayısal değer eşik kontrolüHigh, High-High, Low, Low-Low
DigitalBoolean durum kontrolüON → Alarm, OFF → Normal
CustomScript tabanlı özel koşulJavaScript expression
Normal → Fired (tetiklendi) → Acknowledged (onaylandı) → Off (kapandı)

Her alarm olayı tarihsel olarak kaydedilir: tetiklenme zamanı, kapanma zamanı, onaylayan kullanıcı, süre.


Script’ler platformun otomasyon motorudur. Sunucu tarafında çalışır ve tüm platform verilerine erişebilir.

AlanAçıklamaÖrnek
Zamanlanmış görevPeriyodik veya saatli çalışmaHer 10 saniyede enerji hesaplama
Değişken formülüDeğer dönüşümüİki değişkenden üçüncüyü türetme
Alarm koşuluÖzel alarm mantığıBirden fazla değişkene bağlı koşul
Veri entegrasyonuREST API çağrısıHava durumu API’sinden veri çekme
RaporlamaOtomatik raporHer sabah PDF rapor e-posta ile gönderme
BildirimOlay bazlı bildirimAlarm tetiklenince SMS gönderme
TipKullanım
PeriodicHer X milisaniyede bir çalışır
DailyHer gün belirli saatte çalışır
OnceBir kez çalışıp durur
NoneYalnızca manuel veya API ile tetiklenir

Detaylı bilgi: Script Engine →


SVG Animation — Energy Monitoring Dashboard

SVG tabanlı interaktif SCADA ekranları. Değişken değerleri ekran üzerinde gerçek zamanlı olarak gösterilir: renk değişimi, hareket, sayısal gösterim, açma/kapama kontrolleri.

Tekrar kullanılabilir SVG bileşenleri. Bir motor, vana, pompa gibi sık kullanılan görsel öğeler faceplate olarak tanımlanıp birden fazla animation ekranında kullanılabilir.

Symbol (SVG Sembol Kütüphanesi) — Space Seviyesi

Section titled “Symbol (SVG Sembol Kütüphanesi) — Space Seviyesi”

Space genelinde paylaşılan SVG sembol kütüphanesi. Tüm projelerdeki animation ve faceplate’ler bu sembolleri kullanabilir.

Farklı projelerden verileri tek bir panoda birleştirmek için kullanılır. Space seviyesinde tanımlandığı için projeler arası veri karşılaştırması yapılabilir.

Değişkenlerin zaman içindeki değişimini gösteren grafikler. Birden fazla değişken aynı grafikte gösterilebilir (Trend Tag). Geçmişe dönük veri inceleme ve karşılaştırma için kullanılır.

Custom Menu (Özel Menü) — Space Seviyesi

Section titled “Custom Menu (Özel Menü) — Space Seviyesi”

Kullanıcıya özel menü yapısı oluşturmak için kullanılır. Space seviyesinde tanımlanır — farklı roller için farklı menüler atanabilir. Operatör yalnızca izleme ekranlarını, yönetici raporları, mühendis yapılandırma sayfalarını görür.

Rapor sistemi, PDF ve Excel formatında çıktı üretir. Zamanlanabilir, e-posta ile gönderilebilir, dosyaya kaydedilebilir.

Expression (Paylaşımlı Formül) — Space Seviyesi

Section titled “Expression (Paylaşımlı Formül) — Space Seviyesi”

Space genelinde paylaşılan hesaplama formülleri. Birden fazla değişken veya alarm tarafından ortak kullanılabilir. Tekrarlanan formülleri merkezi olarak yönetmeyi sağlar.

Project Map

GIS harita üzerinde projelerin coğrafi konumlarını gösterir. Her proje noktasında anlık değerler, alarm durumu ve bağlantı durumu popup olarak görüntülenir.


inSCADA üç farklı veritabanı katmanı kullanır. Her biri farklı bir veri tipine optimize edilmiştir:

Proje tanımları, değişken ayarları, kullanıcılar, roller, alarm tanımları, script kodları — kısaca platformun tüm yapılandırma verileri burada tutulur.

Bu veriler nadiren değişir, ilişkisel yapıdadır ve tutarlılık (consistency) önceliklidir.

Değişken tarihsel değerleri, alarm geçmişi, olay logları, giriş denemeleri — zaman damgalı tüm veriler burada tutulur.

Bu veriler sürekli yazılır, nadiren güncellenir ve zaman aralığına göre sorgulanır. Saklama politikaları (retention policy) ile eski veriler otomatik temizlenebilir.

Veri TipiVarsayılan Saklama
Değişken değerleri365 gün
Alarm geçmişi365 gün
Olay logları14 gün
Giriş denemeleri365 gün

Tüm değişkenlerin son güncel değerleri bellekte (cache) tutulur. ins.getVariableValue() veya REST API ile değer okunduğunda cache’ten döner — veritabanına gitmez.

Bu sayede:

  • Anlık değer okuma < 1ms
  • Binlerce değişken eşzamanlı okunabilir
  • Web arayüzü ve script’ler aynı güncel veriye erişir

Bir saha cihazından web ekranına kadar verinin izlediği yol:

┌─────────┐ ┌──────────┐ ┌─────────┐ ┌────────┐ ┌────────┐
│ Saha │───▶│ Bağlantı │───▶│ Frame │───▶│ Ham │───▶│Ölçekle │
│ Cihazı │ │(Protokol)│ │ (Okuma) │ │ Değer │ │ me │
└─────────┘ └──────────┘ └─────────┘ └────────┘ └───┬────┘
┌───────────────────────────────────────────┘
┌──────────┐ ┌──────────┐ ┌──────────┐
│ Cache │───▶│ Loglama │ │ Alarm │
│(Anlık) │ │(Tarihsel)│ │ Kontrol │
└────┬─────┘ └──────────┘ └──────────┘
┌────────┼────────┐
▼ ▼ ▼
┌────────┐┌────────┐┌────────┐
│ Web ││ Script ││ REST │
│ UI ││ Engine ││ API │
└────────┘└────────┘└────────┘
  1. Saha Cihazı — PLC, RTU, sensör, sayaç vb.
  2. Bağlantı — Belirlenen protokol ile cihaza bağlanır
  3. Frame Okuma — Tanımlı periyotta adres bloğunu okur
  4. Ham Değer — Cihazdan gelen raw veri
  5. Ölçekleme — Raw → Engineering dönüşümü (varsa)
  6. Cache — Güncel değer bellek cache’ine yazılır
  7. Loglama — Loglama tipine göre zaman serisi veritabanına kayıt
  8. Alarm Kontrol — Alarm tanımlarına göre eşik kontrolü
  9. Tüketim — Web UI (WebSocket), Script Engine, REST API aynı cache’ten okur
UI / Script / API → Cache Güncelleme → Bağlantı → Protokol Yazma → Saha Cihazı

ins.setVariableValue() veya UI üzerinden değer yazıldığında, komut bağlantı üzerinden saha cihazına iletilir.


inSCADA Instance
├── Space: "enerji"
│ ├── Project: "GES-01"
│ ├── Project: "GES-02"
│ └── Project: "RES-01"
├── Space: "bina"
│ ├── Project: "Merkez Ofis"
│ └── Project: "Depo"
└── Space: "su"
├── Project: "Arıtma Tesisi"
└── Project: "Pompa İstasyonları"

Her space:

  • Kendi proje seti
  • Kendi kullanıcı yetkileri
  • Birbirinden bağımsız veri

Kullanıcılar birden fazla space’e erişebilir ve oturum sırasında space değiştirebilir.


PortKullanım
8081HTTP — Web arayüzü ve REST API
8082HTTPS — Web arayüzü ve REST API (şifreli)

Web arayüzü herhangi bir modern tarayıcıdan erişilebilir. Mobil cihazlardan da (tablet, telefon) responsive olarak çalışır. Ek bir istemci yazılımı kurulumu gerekmez.

Yapılandırma detayları: Yapılandırma →