Solution de transfert mobile - Formats d'échange

O
OCTO TechnologyOCTO Technology
Formats d’échange
SOLUTION
DE TRANSFERT MOBILE
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Vers un monde sans chargement...
☉ Aller toujours plus vite est devenu un besoin capital pour
nos applications. Un temps de chargement trop long est
une des causes de dépréciation et de désinstallation
d’une application.
☉ Deux paramètres peuvent être modulés pour accélérer l’
échange de données et adapter le réseau aux usages
d’aujourd’hui : le protocole de communication utilisé et le
format d’échange des données.
☉ Le couple HTTP1.1 – JSON est aujourd’hui
majoritairement utilisé dans les communications entre
un mobile et un serveur. Mais ce choix est-il performant
ou simplement une habitude ? Est-il adapté au mobile
ou seulement une transposition des acquis du web ?
☉ Cette présentation a pour but d’aider à la réflexion sur le
format d’échange à utiliser dans un projet Mobile. Les
résultats sont tirés d’expériences concrètes et poussent
à remettre en question le standard JSON
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Comment aller toujours plus vite côté mobile?
Jouer sur deux paramètres
Formats d’échange Protocoles de communication
Temps de traitement des données Stabilité
Poids des données Adapté au mobile
>01 JSON
OCTO TECHNOLOGY > THERE IS A BETTER WAY
JSON
Le format d’échange devenu standard…
☉ JavaScript Object Notation :
> Format de données textuelles dérivé de la notation JavaScript
> Format souvent renvoyé par les WebServices
☉ Référence : RFC7159
OCTO TECHNOLOGY > THERE IS A BETTER WAY
JSON
Le format d’échange devenu standard…
> Lisible : textuel
> Flexible :
pas de schéma à suivre
> Répandu :
très utilisé pour le web
> Données lourdes : texte
> Pas d’identification précise
de la structure
> Peut devenir ingérable avec un
nombre grandissant de champs
AVANTAGES INCONVENIENTS
OCTO TECHNOLOGY > THERE IS A BETTER WAY
JSON
Le format d’échange devenu standard…
[
“Octo”: {
“name”: “Dupont”,
“age”: 36,
“Tribu”: {
“label”: “Team”,
“manager”: “Herbert”
},
“Skills”: [“Android”, “TDD”]
}
]
> Exemple
>02 MessagePack
OCTO TECHNOLOGY > THERE IS A BETTER WAY
MessagePack
Format binaire sans schéma…
☉ MessagePack :
> Format d’échange binaire sans schéma
> A pour but d’être le plus simple et le plus
compact possible
☉ Licence : Apache
OCTO TECHNOLOGY > THERE IS A BETTER WAY
> Binaire : léger
> Flexible : pas de schéma
à suivre
> Disponible dans 50 langages
> Encode/Décode longue sous
Android
> Communauté fragmentée
et peu active
> Mauvaise compression avec
des chaînes de caractères
MessagePack
Format binaire sans schéma…
AVANTAGES INCONVENIENTS
OCTO TECHNOLOGY > THERE IS A BETTER WAY
MessagePack
Format binaire sans schéma…
[
“Octo”: {
“name”: “Dupont”,
“age”: 36,
“skills”: [“Android”,
“TDD”]
}
]
JSON MessagePack
81 a4 4f 63 74 6f 83 a4 6e 61 6d 65 a6
44 75 70 6f 6e 74 a3 61 67 65 24 a6 73
6b 69 6c 6c 73 92 a7 41 6e 64 72 6f 69
64 a3 54 44 44
62 bytes 44 bytes
> Exemple
>03 Protocol Buffers
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Protocol Buffers
Format binaire #madebygoogle…
☉ Protocol Buffers :
> Format d’échange binaire avec langage de description d’interface
> Indépendant du langage et de la plateforme
☉ Licence : BSD
☉ Dernière version: 3.1.0 (Norme Proto3)
OCTO TECHNOLOGY > THERE IS A BETTER WAY
AVANTAGES INCONVENIENTS
> Binaire : léger
> Structure définie
> Multiplateforme
> Maintenu
> Encode/Décode rapide sous
Android
> Binaire : illisible
> Nécessite le schéma pour
encoder/décoder
> Peu d’outils disponible pour
la dernière version
Protocol Buffers
Format binaire #madebygoogle…
OCTO TECHNOLOGY > THERE IS A BETTER WAY
syntax = "proto3";
message Octo {
string name = 1;
int32 age = 2;
Tribu tribu = 3 repeated
Skill skills = 4;
}
message Tribu {
string label = 1;
Octo manager = 2;
}
message Skill {
String label = 1;
}
Protocol Buffers
> Exemple : Fichier de structure
Format binaire #madebygoogle…
>04 Benchmarks
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Environnement des tests
Les données échangées sont exclusivement au format texte.
Ce type est le moins favorable pour les formats d’échange binaires.
Je veux 150 paragraphes en format xx.
150 paragraphes dans le format xx.
HTTP/2
Traitement
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Résultats des test
Temps de transfert de X paragraphes
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Résultats des test
JSON Protocol Buffers MessagePack
Vitesse de traitement des
données
1
(Données de référence)
0,5 1,5
Poids des données après
sérialisation
1
(Données de référence)
0,93 0,98
Encodeurs/Décodeurs testés Jackson, Jackson Jr, Moshi Protobuf Officiel, Wire Jackson
Meilleurs Encodeurs/
Décodeurs en temps de
traitement et facilité
d’utilisation
Jackson Wire Jackson
Mise en place dans un projet
Android
Nécessite l’analyse de la
structure de donnée pour
créer les objets Java
Partage du schéma entre le
serveur et le client Android:
création automatique des
objets
Nécessite l’analyse de la
structure de donnée pour
créer les objets Java
Exemple d’utilisation
professionnel
Enormement d’API Web
Google (utilisation interne),
PokemonGo
Pinterest, Fluent, Treasure
OCTO TECHNOLOGY > THERE IS A BETTER WAY
Protocol Buffers: Gagnant?
☉ Les résultats de Protocol Buffers sont très bons
> Temps de traitement 2 fois inférieur à JSON
> Consommation mémoire identique à JSON
> Poids des données faible : transfert plus rapide
☉ Mais la solution est-elle envisageable?
1 sur 20

Contenu connexe

Similaire à Solution de transfert mobile - Formats d'échange

manager vs leader.pptxmanager vs leader.pptx
manager vs leader.pptxnadinelaabidi
47 vues11 diapositives
Priorité des fluxPriorité des flux
Priorité des fluxbuffy14
1.9K vues11 diapositives

Plus de OCTO Technology(20)

Refcard GraphQLRefcard GraphQL
Refcard GraphQL
OCTO Technology18 vues
RefCard Tests sur tous les frontsRefCard Tests sur tous les fronts
RefCard Tests sur tous les fronts
OCTO Technology10 vues
RefCard RESTful API DesignRefCard RESTful API Design
RefCard RESTful API Design
OCTO Technology22 vues
RefCard API Architecture StrategyRefCard API Architecture Strategy
RefCard API Architecture Strategy
OCTO Technology73 vues

Solution de transfert mobile - Formats d'échange

  • 2. OCTO TECHNOLOGY > THERE IS A BETTER WAY Vers un monde sans chargement... ☉ Aller toujours plus vite est devenu un besoin capital pour nos applications. Un temps de chargement trop long est une des causes de dépréciation et de désinstallation d’une application. ☉ Deux paramètres peuvent être modulés pour accélérer l’ échange de données et adapter le réseau aux usages d’aujourd’hui : le protocole de communication utilisé et le format d’échange des données. ☉ Le couple HTTP1.1 – JSON est aujourd’hui majoritairement utilisé dans les communications entre un mobile et un serveur. Mais ce choix est-il performant ou simplement une habitude ? Est-il adapté au mobile ou seulement une transposition des acquis du web ? ☉ Cette présentation a pour but d’aider à la réflexion sur le format d’échange à utiliser dans un projet Mobile. Les résultats sont tirés d’expériences concrètes et poussent à remettre en question le standard JSON
  • 3. OCTO TECHNOLOGY > THERE IS A BETTER WAY Comment aller toujours plus vite côté mobile? Jouer sur deux paramètres Formats d’échange Protocoles de communication Temps de traitement des données Stabilité Poids des données Adapté au mobile
  • 5. OCTO TECHNOLOGY > THERE IS A BETTER WAY JSON Le format d’échange devenu standard… ☉ JavaScript Object Notation : > Format de données textuelles dérivé de la notation JavaScript > Format souvent renvoyé par les WebServices ☉ Référence : RFC7159
  • 6. OCTO TECHNOLOGY > THERE IS A BETTER WAY JSON Le format d’échange devenu standard… > Lisible : textuel > Flexible : pas de schéma à suivre > Répandu : très utilisé pour le web > Données lourdes : texte > Pas d’identification précise de la structure > Peut devenir ingérable avec un nombre grandissant de champs AVANTAGES INCONVENIENTS
  • 7. OCTO TECHNOLOGY > THERE IS A BETTER WAY JSON Le format d’échange devenu standard… [ “Octo”: { “name”: “Dupont”, “age”: 36, “Tribu”: { “label”: “Team”, “manager”: “Herbert” }, “Skills”: [“Android”, “TDD”] } ] > Exemple
  • 9. OCTO TECHNOLOGY > THERE IS A BETTER WAY MessagePack Format binaire sans schéma… ☉ MessagePack : > Format d’échange binaire sans schéma > A pour but d’être le plus simple et le plus compact possible ☉ Licence : Apache
  • 10. OCTO TECHNOLOGY > THERE IS A BETTER WAY > Binaire : léger > Flexible : pas de schéma à suivre > Disponible dans 50 langages > Encode/Décode longue sous Android > Communauté fragmentée et peu active > Mauvaise compression avec des chaînes de caractères MessagePack Format binaire sans schéma… AVANTAGES INCONVENIENTS
  • 11. OCTO TECHNOLOGY > THERE IS A BETTER WAY MessagePack Format binaire sans schéma… [ “Octo”: { “name”: “Dupont”, “age”: 36, “skills”: [“Android”, “TDD”] } ] JSON MessagePack 81 a4 4f 63 74 6f 83 a4 6e 61 6d 65 a6 44 75 70 6f 6e 74 a3 61 67 65 24 a6 73 6b 69 6c 6c 73 92 a7 41 6e 64 72 6f 69 64 a3 54 44 44 62 bytes 44 bytes > Exemple
  • 13. OCTO TECHNOLOGY > THERE IS A BETTER WAY Protocol Buffers Format binaire #madebygoogle… ☉ Protocol Buffers : > Format d’échange binaire avec langage de description d’interface > Indépendant du langage et de la plateforme ☉ Licence : BSD ☉ Dernière version: 3.1.0 (Norme Proto3)
  • 14. OCTO TECHNOLOGY > THERE IS A BETTER WAY AVANTAGES INCONVENIENTS > Binaire : léger > Structure définie > Multiplateforme > Maintenu > Encode/Décode rapide sous Android > Binaire : illisible > Nécessite le schéma pour encoder/décoder > Peu d’outils disponible pour la dernière version Protocol Buffers Format binaire #madebygoogle…
  • 15. OCTO TECHNOLOGY > THERE IS A BETTER WAY syntax = "proto3"; message Octo { string name = 1; int32 age = 2; Tribu tribu = 3 repeated Skill skills = 4; } message Tribu { string label = 1; Octo manager = 2; } message Skill { String label = 1; } Protocol Buffers > Exemple : Fichier de structure Format binaire #madebygoogle…
  • 17. OCTO TECHNOLOGY > THERE IS A BETTER WAY Environnement des tests Les données échangées sont exclusivement au format texte. Ce type est le moins favorable pour les formats d’échange binaires. Je veux 150 paragraphes en format xx. 150 paragraphes dans le format xx. HTTP/2 Traitement
  • 18. OCTO TECHNOLOGY > THERE IS A BETTER WAY Résultats des test Temps de transfert de X paragraphes
  • 19. OCTO TECHNOLOGY > THERE IS A BETTER WAY Résultats des test JSON Protocol Buffers MessagePack Vitesse de traitement des données 1 (Données de référence) 0,5 1,5 Poids des données après sérialisation 1 (Données de référence) 0,93 0,98 Encodeurs/Décodeurs testés Jackson, Jackson Jr, Moshi Protobuf Officiel, Wire Jackson Meilleurs Encodeurs/ Décodeurs en temps de traitement et facilité d’utilisation Jackson Wire Jackson Mise en place dans un projet Android Nécessite l’analyse de la structure de donnée pour créer les objets Java Partage du schéma entre le serveur et le client Android: création automatique des objets Nécessite l’analyse de la structure de donnée pour créer les objets Java Exemple d’utilisation professionnel Enormement d’API Web Google (utilisation interne), PokemonGo Pinterest, Fluent, Treasure
  • 20. OCTO TECHNOLOGY > THERE IS A BETTER WAY Protocol Buffers: Gagnant? ☉ Les résultats de Protocol Buffers sont très bons > Temps de traitement 2 fois inférieur à JSON > Consommation mémoire identique à JSON > Poids des données faible : transfert plus rapide ☉ Mais la solution est-elle envisageable?