Bonjour,
Un petit tuto, pour afficher une carte, dans vos Dashboards (Si vous avez pas trouvés, ou si vous avez pas cherchés

)

- 17.png (19.94 KiB) Viewed 11 times
1) Cliquez ici pour créer une visualisation (à partir de l'affichage d'une visualisation en cours).

- 16.png (37.53 KiB) Viewed 11 times
1) Laissez tel quel (car "filebeat-* est présent).
2) Saisissez dans recherche "geo.location"

- 15.png (16.41 KiB) Viewed 11 times
1) Cliquez sur "source.geo.location, sans relâcher,
2) Puis, déplacez-le dans cette zone

- 14.jpg (45.84 KiB) Viewed 11 times
1) Vous avez les IP externes géolocalisés (sources),
2) Selon ce calque,
3) Nous allons ajouter un autre calque (celui des destinations, comme nous avons ajoutés celui des sources)

- 13.png (59.49 KiB) Viewed 11 times
1) Ensuite, cliquez sur "Elasticsearch"
2) "Documents"

- 12.png (23.88 KiB) Viewed 11 times
1) Défilez ici
2) Je choisis tous les champs (pour rester cohérant, avec l'autre calque), mais, vous pouvez tout aussi bien, ne choisir que "filebeat-*", ou ".ds-filebeat-9.4.*", ça doit fonctionner logiquement)

- 11.png (92.99 KiB) Viewed 11 times
1) Supprimez celui-ci, comme on l'a déjà (sinon, il va ajouter 2x le même)

- 10.jpg (39.58 KiB) Viewed 11 times
Choisissez celui-ci

- 9.png (37.62 KiB) Viewed 11 times
Cliquez ici

- 8.png (38.84 KiB) Viewed 11 times
Choisissez une autre couleur que "source.geo.location"

- 7.png (38 KiB) Viewed 11 times
1) Choisissez ici un nom plus intélligible
2) Il se met à jour automatiquement
(vous pouvez, après, changer celui des sources)

- 6.png (50.11 KiB) Viewed 11 times
Fini.

- 5.jpg (58.6 KiB) Viewed 11 times
1) Vous obtenez alors une carte, avec les connexions selon les endroits du monde
2) Cliquez sur "Enregistrer et revenir"

- 4.jpg (71.59 KiB) Viewed 11 times
Voilà , vous avez votre carte avec la géolocalisation.
Et encore mieux, j'ai trouvé des meilleurs tableaux à afficher, qui sont directement crées par filebeat (en fouillant, pour résoudre mes problèmes) :

- 3.png (61.94 KiB) Viewed 11 times
1) Allez à l'accueil (en haut à gauche)

- 2.png (61.98 KiB) Viewed 11 times
1) Cliquez sur "Analytique"

- 1.png (24.48 KiB) Viewed 11 times
1) Dashboard

- 27.jpg (78.33 KiB) Viewed 11 times
1) Il s'agit de celui-là .

- 26.png (22.64 KiB) Viewed 11 times
1) Choisissez ici, "Events" ou "Alerts" (dans Alerts, tout en bas, vous avec 2 cartes avec la géolocalisation des IP problématiques)
Vous avez aussi une autre carte (très utile) ici :

- 25.png (74.29 KiB) Viewed 11 times
Menu : Securité -> Tableaux de bord -> Explorer -> Réseau
D'ailleurs, je vous conseille de vous balader - découvrir, la section "Sécurité", c'est super bien fait, et pour la version gratuite, il y a beaucoup de choses intéressantes, côté cybersécurité (investigation sur une communication, requête whois, virustotal et talos, directement dans les menus, entre autres)…
Si la géolocalisation ne marche pas (comme chez moi), je vous propose ma solution :
Tout d'abord, ChatGPT, m'a conseillé, de recréer une vue de données (.ds-filebeat-9.4.*), contenant le flux de données, filebeat-9.4.0, crée automatiquement par filebeat, sur le serveur suricata (mais, cela reste facultatif.)

- 24.png (67.67 KiB) Viewed 11 times
Allez tout en bas du menu d'ELK (dans Kibana), afin de cliquer sur "Gestion de la suite"

- 23.png (7.39 KiB) Viewed 11 times
Cliquez sur "Vue de données"

- 22.png (14.85 KiB) Viewed 11 times
-> "Créer une vue de données" (tout en haut à droite)

- 21.png (17.77 KiB) Viewed 11 times
1) Saisissez ici, le nom (arbitraire)
2) Saisissez ici le nom "filebeat-", ainsi que le numéro de la version, (majeure et mineure) en remplaçant, le dernier chiffre, par * (pour moi 9.4.*)
3) Ici apparaissent les sources concernés
4) Saisissez @timestamp comme champ d'horodatage
5) Enregistrez.

- 20.jpg (135.06 KiB) Viewed 11 times
1) Vous pouvez vérifier que pour la vue de données crée,
2) En saisissant ici le champ "source.geo.country_iso_code"
3) Le champ apparaît bien.
Problème sans doute de la base de données GeoLite2 (c'était le cas chez moi…)
Dans une console PowerShell :
curl -v https://geoip.elastic.co/v1/database
Doit se terminer par :
geoip.elastic.co:443 left intact
(j'avais un problème à ce niveau, mon antivirus me bloquait le (réécrivait sans doute) le certificat HTTPS)
Ensuite, dans la console de débogage, de Kibana, faire (pour vérifier si GeoIP est actif) :
Dans la console management ELK :

- 19.png (27.13 KiB) Viewed 11 times
Pour rappel, la console de management ELK se trouve ici
Saisissez à l'intérieur :
Code: Select all
GET _cluster/settings?include_defaults=true
Et chercher dans la réponse :

- 18.png (18.19 KiB) Viewed 11 times
Tapez [ctrl]+[f] et recherchez "geo"
Observez les différents éléments, vous montrant que geoip n'a pas été téléchargé, et n'est pas activé.
Puis, pour activer le module GeoIP, saisissez (toujours dans la console de management Kibana) :
Code: Select all
PUT _cluster/settings
{
"persistent": {
"ingest.geoip.downloader.enabled": true
}
}
Réponse :
{
"acknowledged": true,
"persistent": {
"ingest": {
"geoip": {
"downloader": {
"enabled": "true"
}
}
}
},
"transient": {}
}
Puis, pour forcer le téléchargement :
Réponse :
{
"stats": {
"successful_downloads": 3,
"failed_downloads": 0,
"total_download_time": 26400,
"databases_count": 3,
"skipped_updates": 0,
"expired_databases": 0
},
"nodes": {
"azerty…": {
"databases": [
{
"name": "GeoLite2-ASN.mmdb"
},
{
"name": "GeoLite2-City.mmdb"
},
{
"name": "GeoLite2-Country.mmdb"
}
],
…
Vous voyez ici les 3 bases de données GeoIP (GeoLite2) qui sont en cours de téléchargement/sont téléchargés
Vérifier avec le DNS de google (8.8.8.8) :
Code: Select all
POST _ingest/pipeline/_simulate
{
"pipeline": {
"processors": [
{
"geoip": {
"field": "client.ip"
}
}
]
},
"docs": [
{
"_source": {
"client": {
"ip": "8.8.8.8"
}
}
}
]
}
Réponse :
{
"docs": [
{
"doc": {
"_index": "_index",
"_version": "-3",
"_id": "_id",
"_source": {
"client": {
"ip": "8.8.8.8"
},
"geoip": {
"continent_name": "North America",
"country_name": "United States",
"location": {
"lon": -97.822,
"lat": 37.751
},
"country_iso_code": "US"
}
},
"_ingest": {
"timestamp": "2026-05-11T16:09:06.7635894Z"
}
}
}
]
}
Bonne fin de nuit.
Source : Merci ChatGPT.