# Présentation et Installation

# Prérequis

# Docker et Docker Compose

  • Docker version 19.03.15 ou supérieure (MacOSX, Linux ou Windows 10).
  • Docker Compose version 1.20.0 ou supérieure (MacOSX, Linux ou Windows 10).

Vous pouvez vérifier la version de Docker et de Docker Compose que vous avez installée avec les commandes suivantes à partir de votre terminal :

docker --version
docker-compose --version

L'installation de Docker pour Mac ou Windows installera également Docker Compose. Si Docker est déjà installé, vous devez vérifier que Docker Compose version 1.20.0 ou supérieure est installé. Sinon, nous vous recommandons d'installer une version plus récente de Docker.

# Java

Java 11 ou supérieure (MacOSX, Linux ou Windows 10).

À vérifier dans votre terminal via la commande suivante :

java --version

# Un IDE "digne de ce nom"

# Hardware

Si possible, paramétrez un minimum de 2 GO de RAM dans docker afin de garantir une stabilité à l'ensemble de la stack.

# Setup

  • ⚠️ Clone du repository GIT et checkout de la branche step01 ⚠️.
git clone https://github.com/Zenika/nc-kafka-fundamentals && cd nc-kafka-fundamentals && git checkout step01
  • Setup de la stack docker
cd Lab01-init && docker-compose up -d
  • Pour vérifier que l'ensemble fonctionne :
docker-compose ps 
Name               Command               State                    Ports                  
-----------------------------------------------------------------------------------------
akhq    docker-entrypoint.sh ./akhq      Up      0.0.0.0:8080->8080/tcp,:::8080->8080/tcp
kafka   /etc/confluent/docker/run        Up      0.0.0.0:9092->9092/tcp,:::9092->9092/tcp
tools   bash -c echo Waiting for K ...   Up      9092/tcp                                
zk      /etc/confluent/docker/run        Up      2181/tcp, 2888/tcp, 3888/tcp  
  • Exposer les conteneurs au sein de votre OS en ajoutant dans votre fichier /etc/hosts (à ouvrir en tant qu'administrateur)
    • OSX/Linux : /etc/hosts
    • Windows : C:\Windows\System32\drivers\etc\hosts
127.0.0.1 akhq
127.0.0.1 kafka
127.0.0.1 schema-registry 
127.0.0.1 connect
  • Grace à cette exposition vous pourrez accéder aux différents conteneurs en utilisant les noms d'hôtes des conteneurs, exemple :
    • http://akhq:8080/ pour accéder à akhq
    • kafka:9092 pour que vos applications ou le CLI accède à votre broker kafka
    • etc.

# Le petit mot de vos "speakers"

Adrien Wattez

Consultant & Formateur @ Zenika Rennes

adrien

Mickael Boixiere

Consultant & Formateur @ Zenika Rennes

mickael

# Un peu d'histoire et de contexte

  • 2009 : début du projet (opensourcé par LinkedIn)

  • 2011 : première version publique

  • 2012 : incubation par Apache

  • 2014 : création de Confluent

  • Kafka est gratuit et open-source.

  • Confluent propose des solutions d’hébergements (cloud et on-premise), des outils (connecteurs), du support, des formations et des certifications.

Confluent

  • Durant ce workshop nous utilisons des images confluentinc : confluentinc/cp-zookeeperet confluentinc/cp-kafka.

# Sommaire

Sommaire