Condividi tramite


Eseguire la migrazione delle regole di rilevamento di QRadar a Microsoft Sentinel

Questo articolo descrive come identificare, confrontare ed eseguire la migrazione delle regole di rilevamento di QRadar alle regole predefinite di Microsoft Sentinel.

Identificare ed eseguire la migrazione delle regole

Microsoft Sentinel usa l'analisi di Machine Learning per creare eventi imprevisti ad alta fedeltà e pratica e alcuni rilevamenti esistenti possono essere ridondanti in Microsoft Sentinel. Pertanto, non eseguire la migrazione di tutte le regole di rilevamento e analisi in modo cieco. Esaminare queste considerazioni durante l'identificazione delle regole di rilevamento esistenti.

  • Assicurarsi di selezionare i casi d'uso che giustificano la migrazione delle regole, considerando la priorità aziendale e l'efficienza.
  • Verificare di aver compreso i tipi di regole di Microsoft Sentinel.
  • Verificare di aver compreso la terminologia delle regole.
  • Esaminare le regole che non hanno attivato avvisi negli ultimi 6-12 mesi e determinare se sono ancora pertinenti.
  • Eliminare le minacce o gli avvisi di basso livello che normalmente si ignorano.
  • Usare le funzionalità esistenti e verificare se le regole di analisi predefinite di Microsoft Sentinel potrebbero risolvere i casi d'uso correnti. Poiché Microsoft Sentinel usa l'analisi di Machine Learning per produrre eventi imprevisti ad alta fedeltà e pratica, è probabile che alcuni rilevamenti esistenti non siano più necessari.
  • Verificare le origini dati connesse ed esaminare i metodi di connessione dati. Rivedere le conversazioni di raccolta dati per garantire la profondità e l'ampiezza dei dati nei casi d'uso che si prevede di rilevare.
  • Esplorare le risorse della community, ad esempio SOC Prime Threat Detection Marketplace, per verificare se le regole sono disponibili.
  • Valutare se un convertitore di query online, ad esempio Uncoder.io, potrebbe funzionare per le regole.
  • Se le regole non sono disponibili o non possono essere convertite, devono essere create manualmente usando una query KQL. Esaminare il mapping delle regole per creare nuove query.

Altre informazioni sulle procedure consigliate per la migrazione delle regole di rilevamento.

Per eseguire la migrazione delle regole di analisi a Microsoft Sentinel:

  1. Verificare di disporre di un sistema di test per ogni regola di cui si vuole eseguire la migrazione.

    1. Preparare un processo di convalida per le regole di cui è stata eseguita la migrazione, inclusi scenari di test completi e script.

    2. Assicurarsi che il team disponga di risorse utili per testare le regole di cui è stata eseguita la migrazione.

    3. Verificare di disporre di origini dati necessarie connesse ed esaminare i metodi di connessione dati.

  2. Verificare se i rilevamenti sono disponibili come modelli predefiniti in Microsoft Sentinel:

    • Se le regole predefinite sono sufficienti, usare i modelli di regola predefiniti per creare regole per la propria area di lavoro.

      In Microsoft Sentinel passare a Configurazione > Analisi > Modelli di regole e creare e aggiornare ogni regola di analisi pertinente.

      Per altre informazioni, vedere Creare regole di analisi pianificate dai modelli.

    • Se sono presenti rilevamenti non coperti dalle regole predefinite di Microsoft Sentinel, provare un convertitore di query online, ad esempio Uncoder.io per convertire le query in KQL.

      Identificare la condizione del trigger e l'azione della regola, quindi costruire ed esaminare la query KQL.

    • Se non sono sufficienti né le regole predefinite né un convertitore di regole online, sarà necessario creare la regola manualmente. In questi casi, seguire questa procedura per iniziare a creare la regola:

      1. Identificare le origini dati da usare nella regola. È consigliabile creare una tabella di mapping tra origini dati e tabelle dati in Microsoft Sentinel per identificare le tabelle di cui si vuole eseguire la query.

      2. Identificare gli attributi, i campi o le entità nei dati da usare nelle regole.

      3. Identificare i criteri e la logica delle regole. In questa fase, è possibile usare i modelli di regola come esempi per creare query KQL.

        Prendere in considerazione filtri, regole di correlazione, elenchi attivi, set di riferimenti, watchlist, anomalie di rilevamento, aggregazioni e così via. È possibile usare i riferimenti forniti dal sistema SIEM legacy per comprendere come eseguire il mapping ottimale della sintassi della query.

      4. Identificare la condizione del trigger e l'azione della regola, quindi costruire ed esaminare la query KQL. Quando si esamina la query, prendere in considerazione le risorse di ottimizzazione KQL.

  3. Testare la regola con ogni caso d'uso pertinente. Se non fornisce risultati previsti, è possibile esaminare il KQL e testarlo di nuovo.

  4. Quando si è soddisfatti, è possibile considerare la regola di cui è stata eseguita la migrazione. Creare un playbook per l'azione della regola in base alle esigenze. Per altre informazioni, vedere Automatizzare la risposta alle minacce con i playbook in Microsoft Sentinel

Altre informazioni sulle regole di analisi:

Confrontare la terminologia delle regole

Questa tabella aiuta a chiarire il concetto di regola in Microsoft Sentinel rispetto a QRadar.

QRadar Microsoft Sentinel
Tipo di regola • Eventi
• Flusso
• Comuni
• Violazione
• Regole di rilevamento anomalie
• Query pianificata
• Fusione
• Microsoft Security
• Analisi del comportamento di Machine Learning (ML)
Criteri Definire nella condizione di test Definire in KQL
Condizione trigger Definire nella regola Soglia: numero di risultati della query
Azione • Creare una violazione
• Inviare un nuovo evento
• Aggiungere al set di riferimenti o ai dati
• E altro ancora
• Creare un avviso o un evento imprevisto
• Si integra con App per la logica

Eseguire il mapping e confrontare gli esempi di regole

Usare questi esempi per confrontare ed eseguire il mapping delle regole da QRadar a Microsoft Sentinel in vari scenari.

Regola Sintassi Regola di rilevamento di esempio (QRadar) Query KQL di esempio Risorse
Test delle proprietà comuni Sintassi QRadar Esempio di espressione regolare
Esempio di query di filtro AQL
Esempio di uguale a/diverso da
Esempio di espressione regolare
Esempio di query di filtro AQL
Esempio di uguale a/diverso da
• Espressione regolare: corrisponde a regex
• Query di filtro AQL: operatori di stringa
• Uguale a/diverso da: operatori di stringa
Test di data/ora Sintassi QRadar Esempio di giorno del mese selezionato
Esempio di giorno della settimana selezionato
Esempio di dopo le/prima delle/alle
Esempio di giorno del mese selezionato
Esempio di giorno della settimana selezionato
Esempio di dopo le/prima delle/alle
Operatori di data e ora
• Giorno del mese selezionato: dayofmonth()
• Giorno della settimana selezionato: dayofweek()
• Dopo le/prima delle/alle: format_datetime()
Test delle proprietà dell'evento Sintassi QRadar Esempio di protocollo IP
Esempio di stringa del payload dell'evento
Esempio di protocollo IP
Esempio di stringa del payload dell'evento
• Protocollo IP: operatori di stringa
• Stringa del payload dell'evento: has
Funzioni: contatori Sintassi QRadar Esempio di ora e proprietà dell'evento Esempio di ora e proprietà dell'evento summarize
Funzioni: condizioni negative Sintassi QRadar Esempio di condizioni negative Esempio di condizioni negative join()
Operatori di stringa
Operatori numerici
Funzioni: semplice Sintassi QRadar Esempio di condizioni semplici Esempio di condizioni semplici or
Test di IP/porta Sintassi QRadar Esempio di porta di origine
Esempio di IP di origine
Esempio di porta di origine
Esempio di IP di origine
Test di origine log Sintassi QRadar Esempio di origine log Esempio di origine log

Sintassi dei test delle proprietà comuni

Ecco la sintassi QRadar per una regola di test delle proprietà comuni.

Diagramma che illustra la sintassi comune di una regola di test delle proprietà.

Test delle proprietà comuni: esempio di espressione regolare (QRadar)

Ecco la sintassi per una regola di test delle proprietà comuni QRadar di esempio che usa un'espressione regolare:

when any of <these properties> match <this regular expression>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test delle proprietà comuni che usa un'espressione regolare.

Test delle proprietà comuni: esempio di espressione regolare (KQL)

Ecco la regola dei test delle proprietà comuni con un'espressione regolare in KQL.

CommonSecurityLog
| where tostring(SourcePort) matches regex @"\d{1,5}" or tostring(DestinationPort) matches regex @"\d{1,5}"

Test delle proprietà comuni: esempio di query di filtro AQL (QRadar)

Ecco la sintassi per una regola di test delle proprietà comuni QRadar di esempio che usa una query di filtro AQL.

when the event matches <this> AQL filter query

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test delle proprietà comuni che usa una query di filtro AQL.

Test delle proprietà comuni: esempio di query di filtro AQL (KQL)

Ecco la regola dei test delle proprietà comuni con una query di filtro AQL in KQL.

CommonSecurityLog
| where SourceIP == '10.1.1.10'

Test delle proprietà comuni: esempio di uguale a/diverso da (QRadar)

Ecco la sintassi per una regola di test delle proprietà comuni QRadar di esempio che usa l'operatore equals o not equals.

and when <this property> <equals/not equals> <this property>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test delle proprietà comuni che usa uguale a/diverso da.

Test delle proprietà comuni: esempio di uguale a/diverso da (KQL)

Ecco la regola dei test delle proprietà comuni con l'operatore equals o not equals in KQL.

CommonSecurityLog
| where SourceIP == DestinationIP

Sintassi dei test di data/ora

Ecco la sintassi QRadar per una regola di test di data/ora.

Diagramma che illustra la sintassi di una regola di test di data/ora.

Test di data/ora: esempio di giorno del mese selezionato (QRadar)

Ecco la sintassi per una regola di test di data/ora QRadar di esempio che usa un giorno del mese selezionato.

and when the event(s) occur <on/after/before> the <selected> day of the month

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test di data/ora che usa un giorno selezionato.

Test di data/ora: esempio di giorno del mese selezionato (KQL)

Ecco la regola di test di data/ora con un giorno del mese selezionato in KQL.

SecurityEvent
 | where dayofmonth(TimeGenerated) < 4

Test di data/ora: esempio di giorno della settimana selezionato (QRadar)

Ecco la sintassi per una regola di test di data/ora QRadar di esempio che usa un giorno della settimana selezionato:

and when the event(s) occur on any of <these days of the week{Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday}>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test di data/ora che usa un giorno della settimana selezionato.

Test di data/ora: esempio di giorno della settimana selezionato (KQL)

Ecco la regola di test di data/ora con un giorno della settimana selezionato in KQL.

SecurityEvent
 | where dayofweek(TimeGenerated) between (3d .. 5d)

Test di data/ora: esempio di dopo le/prima delle/alle (QRadar)

Ecco la sintassi per una regola di test di data/ora QRadar di esempio che usa l'operatore after, before o at.

and when the event(s) occur <after/before/at> <this time{12.00AM, 12.05AM, ...11.50PM, 11.55PM}>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test di data/ora che usa l'operatore dopo le/prima delle/alle.

Test di data/ora: esempio di dopo le/prima delle/alle (KQL)

Ecco la regola di test di data/ora che usa l'operatore after, before o at in KQL.

SecurityEvent
| where format_datetime(TimeGenerated,'HH:mm')=="23:55"

TimeGenerated è in UTC/GMT.

Sintassi dei test delle proprietà dell'evento

Ecco la sintassi QRadar per una regola di test delle proprietà dell'evento.

Diagramma che illustra la sintassi di una regola di test delle proprietà dell'evento.

Test delle proprietà dell'evento: esempio di protocollo IP (QRadar)

Ecco la sintassi per una regola di test delle proprietà dell'evento QRadar di esempio che usa un protocollo IP.

and when the IP protocol is one of the following <protocols>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test delle proprietà dell'evento che usa un protocollo IP.

Test delle proprietà dell'evento: esempio di protocollo IP (KQL)

CommonSecurityLog
| where Protocol in ("UDP","ICMP")

Test delle proprietà dell'evento: esempio di stringa del payload dell'evento (QRadar)

Ecco la sintassi per una regola di test delle proprietà dell'evento QRadar di esempio che usa un valore di stringa Event Payload.

and when the Event Payload contains <this string>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di test delle proprietà dell'evento che usa una stringa del payload dell'evento.

Test delle proprietà dell'evento: esempio di stringa del payload dell'evento (KQL)

CommonSecurityLog
| where DeviceVendor has "Palo Alto"

search "Palo Alto"

Per ottimizzare le prestazioni, evitare di usare il comando search se si conosce già il nome della tabella.

Funzioni: sintassi dei contatori

Ecco la sintassi QRadar per una regola di funzioni che usa contatori.

Diagramma che illustra la sintassi di una regola di funzioni che usa contatori.

Contatori: esempio di ora e proprietà dell'evento (QRadar)

Ecco la sintassi per una regola di funzioni QRadar di esempio che usa un numero definito di proprietà dell'evento in un numero definito di minuti.

and when at least <this many> events are seen with the same <event properties> in <this many> <minutes>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di funzioni che usa le proprietà dell'evento.

Contatori: esempio di ora e proprietà dell'evento (KQL)

CommonSecurityLog
| summarize Count = count() by SourceIP, DestinationIP
| where Count >= 5

Funzioni: sintassi delle condizioni negative

Ecco la sintassi QRadar per una regola di funzioni che usa condizioni negative.

Diagramma che illustra la sintassi di una regola di funzioni che usa condizioni negative.

Esempio di condizioni negative (QRadar)

Ecco la sintassi per una regola di funzioni QRadar di esempio che usa condizioni negative.

and when none of <these rules> match in <this many> <minutes> after <these rules> match with the same <event properties>

Ecco due regole definite in QRadar. Le condizioni negative saranno basate su queste regole.

Diagramma che illustra una regola di test delle proprietà dell'evento da usare per una regola di condizioni negative.

Diagramma che illustra una regola di test delle proprietà comuni da usare per una regola di condizioni negative.

Ecco un esempio di regola di condizioni negative basata sulle regole precedenti.

Diagramma che illustra una regola di funzioni con condizioni negative.

Esempio di condizioni negative (KQL)

let spanoftime = 10m;
let Test2 = (
CommonSecurityLog
| where Protocol !in ("UDP","ICMP")
| where TimeGenerated > ago(spanoftime)
);
let Test6 = (
CommonSecurityLog
| where SourceIP == DestinationIP
);
Test2
| join kind=rightanti Test6 on $left. SourceIP == $right. SourceIP and $left. Protocol ==$right. Protocol

Funzioni: sintassi delle condizioni semplici

Ecco la sintassi QRadar per una regola di funzioni che usa condizioni semplici.

Diagramma che illustra la sintassi di una regola di funzioni che usa condizioni semplici.

Esempio di condizioni semplici (QRadar)

Ecco la sintassi per una regola di funzioni QRadar di esempio che usa condizioni semplici.

and when an event matches <any|all> of the following <rules>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola di funzioni con condizioni semplici.

Esempio di condizioni semplici (KQL)

CommonSecurityLog
| where Protocol !in ("UDP","ICMP") or SourceIP == DestinationIP

Sintassi dei test di IP/porta

Ecco la sintassi QRadar per una regola di test di IP/porta.

Diagramma che illustra la sintassi di una regola di test di IP/porta.

Test di IP/porta: esempio di porta di origine (QRadar)

Ecco la sintassi per una regola QRadar di esempio che specifica una porta di origine.

and when the source port is one of the following <ports>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola che specifica una porta di origine.

Test di IP/porta: esempio di porta di origine (KQL)

CommonSecurityLog
| where SourcePort == 20

Test di IP/porta: esempio di IP di origine (QRadar)

Ecco la sintassi per una regola QRadar di esempio che specifica un IP di origine.

and when the source IP is one of the following <IP addresses>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola che specifica un indirizzo IP di origine.

Test di IP/porta: esempio di IP di origine (KQL)

CommonSecurityLog
| where SourceIP in (“10.1.1.1”,”10.2.2.2”)

Sintassi dei test di origine log

Ecco la sintassi QRadar per una regola di test di origine log.

Diagramma che illustra la sintassi di una regola di test di origine log.

Esempio di origine log (QRadar)

Ecco la sintassi per una regola QRadar di esempio che specifica le origini di log.

and when the event(s) were detected by one or more of these <log source types>

Ecco la regola di esempio in QRadar.

Diagramma che illustra una regola che specifica le origini di log.

Esempio di origine log (KQL)

OfficeActivity
| where OfficeWorkload == "Exchange"

Passaggi successivi

In questo articolo è stato illustrato come eseguire il mapping delle regole di migrazione da QRadar a Microsoft Sentinel.