SlideShare una empresa de Scribd logo
1 de 14
1
Devoxx France 2016
Une conf appréciée, un slide
Antoine Rey
13 mai 2016
2
ECMAScript 2015 / ES6 : c’est maintenant !
o ES6 : plus grosse évolution du langage JavaScript depuis 20 ans
• Plus facile : moins de piège, mode strict
• POO : classes, héritage, accesseurs, constructeur …
• Fonctionnalités : déstructuration, rest & spread, fonctions fléchées, modules
…
o ES5 : supporté par IE9+, navigateurs Evergreens, NodeJS, IDE, outils de
builds …
o Utilisation de ES6 via le transpileur Babel
o Zoom sur la syntaxe : http://lebab.io/try-it
3
Architecture technique Stack Overflow
• 2 423 requêtes HTTP / seconde
• 504 millions de requêtes SQL / jour
• 3 To de données émises / jour
• Temps de réponse moyen : 22,21 ms
x4 x2 x3
x9
x4
Angular 2@Component({
providers: [
new Provider(QuestionsStore, {
useFactory: () => new QuestionsStore(SessionStore.read())
})
],
selector: 'summary',
template: `
<div class="mdl-card_sup-text">
<h4>Your score is {{ score }}/{{ total }}</h4>
</div>
<question-card [preview]="true" [question]="question" *ngFor="#question of questions"></question-card>
`,
directives: [QuestionCard]
})
export class Summary implements OnInit {
private questions: IQuestion[];
private score: number;
private total: number;
private questionsStore: IQuestionsStore;
constructor(questionsStore: QuestionsStore) {
this.questionsStore = questionsStore;
this.questionsStore.fetch().then( (questions) => this.questions = questions );
}
ngOnInit() {
this.total = this.questions.length;
this.score = this.questionsStore.computeResult(this.questions);
}
}
Orienté composants
Associé à un selector CSS3
Template HTML inline
Injection de dépendance
Callback sur cycle de vie
Composant enfant
Binding de propriétés
6
Apache Kafka
0 1 2 3
0 1
Topic A
Partition 1
Partition 2
Topic B
0 1 2 Partition 1
Consommateur Ω
Consommateur µ
Zookeeper
Client
A
Client
B
7
Spring Boot & Spring Cloud
“ make jar not war ”Service Discovery
(Eureka)
Config Server
(Spring Cloud)
Micro-service
de réservations
REST
H2
Client de
réservation
GET http://reservation-service/reservations
RabbitMQ
8
Jenkinsfile
“ le pendant du .travis.yml pour Jenkins”
jettyUrl = 'http://localhost:8081/’
def servers
stage ’Build'
node {
checkout scm
servers = load 'servers.groovy'
mvn '-o clean package'
dir('target') {stash name: 'war', includes: 'x.war'}
}
stage ’Acceptance Test'
parallel(longerTests: {
runTests(servers, 30)
}, quickerTests: {
runTests(servers, 20)
})
def mvn(args) {
sh "${tool 'Maven 3.x'}/bin/mvn ${args}"
}
React
10
var HelloMessage = React.createClass({
render: function() {
return <div>Hello {this.props.name}</div>;
}
});
ReactDOM.render(<HelloMessage name="John" />, mountNode);
• Le V de MVC
o Déclaratif
o Composants
• Virtual DOM
o Performance
o Server Side rendering
• React Native
o Learn once, write anywhere
o iOS et Androïd
Une JVM de 3 To
11
Rendre la doc aussi fun que le code
• Conversations over documentation
• Pair programming, mob-programming, revues de code
• Savoir métier et DDD
• Scénarios fonctionnels dans Cucumber, SpecFlow, JGiven
• Session d’Event Storming
• La documentation passe également par le code
• Conventions de nommage, package-info.java
• Annotations Java avec sémantique (ex: @BoundedContext)
• Gérer la documentation comme le code
• Versionnée dans le référentiel de code source
• Présente dans l’IDE pour prendre en compte les refactoring
• Outils de génération de diagrammes : Ditaa, DOT …
12
Bonnes pratiques des revues de code
13
• Prendre le temps, à tête reposée et à un rythme soutenable
• Echangez de vive voix pendant les revues
• L’auteur corrige, en binôme si nécessaire
• Ecrivez vos standards et les faire évoluer
• Critiquez le code, pas le développeur
• Pas de discussions à rallonge
• Trouvez des compromis et en faire un standard
“ 1h de revue = 4h de debug économisée ”
14
Vidéos librement disponibles sur le channel « Devoxx FR 2016 » de Youtube
https://www.youtube.com/channel/UCsVPQfo5RZErDL41LoWvk0A

Más contenido relacionado

La actualidad más candente

La actualidad más candente (20)

Les dessous du framework spring
Les dessous du framework springLes dessous du framework spring
Les dessous du framework spring
 
ParisJUG Spring Boot
ParisJUG Spring BootParisJUG Spring Boot
ParisJUG Spring Boot
 
Architecture java j2 ee a partager
Architecture java j2 ee a partagerArchitecture java j2 ee a partager
Architecture java j2 ee a partager
 
Mockito Chti JUG
Mockito Chti JUGMockito Chti JUG
Mockito Chti JUG
 
Les Streams de Java 8
Les Streams de Java 8Les Streams de Java 8
Les Streams de Java 8
 
Maven
MavenMaven
Maven
 
Tp java ee.pptx
Tp java ee.pptxTp java ee.pptx
Tp java ee.pptx
 
Hibernate jpa
Hibernate jpaHibernate jpa
Hibernate jpa
 
"Input/Ouput, 16 ans après" à Devoxx France 2012
"Input/Ouput, 16 ans après" à Devoxx France 2012"Input/Ouput, 16 ans après" à Devoxx France 2012
"Input/Ouput, 16 ans après" à Devoxx France 2012
 
Spring mvc
Spring mvcSpring mvc
Spring mvc
 
Spring 3.0
Spring 3.0Spring 3.0
Spring 3.0
 
Installation et Configuration ee JDK et de Tomcat
Installation et Configuration ee JDK et de TomcatInstallation et Configuration ee JDK et de Tomcat
Installation et Configuration ee JDK et de Tomcat
 
Cours jee 1
Cours jee 1Cours jee 1
Cours jee 1
 
Introduction à Angular JS
Introduction à Angular JSIntroduction à Angular JS
Introduction à Angular JS
 
JBoss - chapitre JMX
JBoss - chapitre JMXJBoss - chapitre JMX
JBoss - chapitre JMX
 
Spring Batch 17-05-2011
Spring Batch 17-05-2011Spring Batch 17-05-2011
Spring Batch 17-05-2011
 
Formation jpa-hibernate-spring-data
Formation jpa-hibernate-spring-dataFormation jpa-hibernate-spring-data
Formation jpa-hibernate-spring-data
 
Présentation1
Présentation1Présentation1
Présentation1
 
Les Servlets et JSP
Les Servlets et JSPLes Servlets et JSP
Les Servlets et JSP
 
Bean Validation - Cours v 1.1
Bean Validation - Cours v 1.1Bean Validation - Cours v 1.1
Bean Validation - Cours v 1.1
 

Similar a Retours Devoxx France 2016

Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs Web
Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs WebUne visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs Web
Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs WebFrédéric Harper
 
Rouabhi algiers meetup
Rouabhi algiers meetupRouabhi algiers meetup
Rouabhi algiers meetupSamir Rouabhi
 
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfdevoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfJean-Michel Doudoux
 
JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?Microsoft
 
Server Side Javascript in the cloud
Server Side Javascript in the cloudServer Side Javascript in the cloud
Server Side Javascript in the cloudstefounet
 
JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?benjguin
 
Workshop mesos docker devoxx fr 2016
Workshop mesos docker devoxx fr 2016Workshop mesos docker devoxx fr 2016
Workshop mesos docker devoxx fr 2016Julia Mateo
 
CI-Jenkins.pptx
CI-Jenkins.pptxCI-Jenkins.pptx
CI-Jenkins.pptxMEDOBEST1
 
Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Jean-Michel Doudoux
 
Flex, une techno RIA incontournable pour les futures app web ?
Flex, une techno RIA incontournable pour les futures app web ?Flex, une techno RIA incontournable pour les futures app web ?
Flex, une techno RIA incontournable pour les futures app web ?GreenIvory
 
0251-formation-java-programmation-objet.pdf
0251-formation-java-programmation-objet.pdf0251-formation-java-programmation-objet.pdf
0251-formation-java-programmation-objet.pdfOmbotimbe Salifou
 
Voxxeddays lux 2018 apres java 8, java 9 et 10
Voxxeddays lux 2018 apres java 8, java 9 et 10Voxxeddays lux 2018 apres java 8, java 9 et 10
Voxxeddays lux 2018 apres java 8, java 9 et 10Jean-Michel Doudoux
 
AngularJS et autres techno frontend
AngularJS et autres techno frontendAngularJS et autres techno frontend
AngularJS et autres techno frontendyllieth
 
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système Java
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système JavaLes ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système Java
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système JavaDocDoku
 

Similar a Retours Devoxx France 2016 (20)

Vert.x 3
Vert.x 3Vert.x 3
Vert.x 3
 
Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs Web
Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs WebUne visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs Web
Une visite guidée d’Internet Explorer 9 et HTML5 pour les développeurs Web
 
Rouabhi algiers meetup
Rouabhi algiers meetupRouabhi algiers meetup
Rouabhi algiers meetup
 
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdfdevoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
devoxx 2022 - 10 ans de Devoxx FR et de Java.pdf
 
JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?
 
Server Side Javascript in the cloud
Server Side Javascript in the cloudServer Side Javascript in the cloud
Server Side Javascript in the cloud
 
JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?JavaScript aussi sur le serveur et jusque dans le cloud?
JavaScript aussi sur le serveur et jusque dans le cloud?
 
Introduction à node.js
Introduction à node.js Introduction à node.js
Introduction à node.js
 
The Future of Javascript
The Future of JavascriptThe Future of Javascript
The Future of Javascript
 
The future of JavaScript
The future of JavaScriptThe future of JavaScript
The future of JavaScript
 
Support NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDBSupport NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDB
 
Workshop mesos docker devoxx fr 2016
Workshop mesos docker devoxx fr 2016Workshop mesos docker devoxx fr 2016
Workshop mesos docker devoxx fr 2016
 
Vert.x
Vert.xVert.x
Vert.x
 
CI-Jenkins.pptx
CI-Jenkins.pptxCI-Jenkins.pptx
CI-Jenkins.pptx
 
Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17Javaday Paris 2022 - Java en 2022 : profiter de Java 17
Javaday Paris 2022 - Java en 2022 : profiter de Java 17
 
Flex, une techno RIA incontournable pour les futures app web ?
Flex, une techno RIA incontournable pour les futures app web ?Flex, une techno RIA incontournable pour les futures app web ?
Flex, une techno RIA incontournable pour les futures app web ?
 
0251-formation-java-programmation-objet.pdf
0251-formation-java-programmation-objet.pdf0251-formation-java-programmation-objet.pdf
0251-formation-java-programmation-objet.pdf
 
Voxxeddays lux 2018 apres java 8, java 9 et 10
Voxxeddays lux 2018 apres java 8, java 9 et 10Voxxeddays lux 2018 apres java 8, java 9 et 10
Voxxeddays lux 2018 apres java 8, java 9 et 10
 
AngularJS et autres techno frontend
AngularJS et autres techno frontendAngularJS et autres techno frontend
AngularJS et autres techno frontend
 
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système Java
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système JavaLes ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système Java
Les ZAPeroTech #4 : REX Oracle Code One 2019 sur l'éco-système Java
 

Retours Devoxx France 2016

  • 1. 1 Devoxx France 2016 Une conf appréciée, un slide Antoine Rey 13 mai 2016
  • 2. 2
  • 3. ECMAScript 2015 / ES6 : c’est maintenant ! o ES6 : plus grosse évolution du langage JavaScript depuis 20 ans • Plus facile : moins de piège, mode strict • POO : classes, héritage, accesseurs, constructeur … • Fonctionnalités : déstructuration, rest & spread, fonctions fléchées, modules … o ES5 : supporté par IE9+, navigateurs Evergreens, NodeJS, IDE, outils de builds … o Utilisation de ES6 via le transpileur Babel o Zoom sur la syntaxe : http://lebab.io/try-it 3
  • 4. Architecture technique Stack Overflow • 2 423 requêtes HTTP / seconde • 504 millions de requêtes SQL / jour • 3 To de données émises / jour • Temps de réponse moyen : 22,21 ms x4 x2 x3 x9 x4
  • 5. Angular 2@Component({ providers: [ new Provider(QuestionsStore, { useFactory: () => new QuestionsStore(SessionStore.read()) }) ], selector: 'summary', template: ` <div class="mdl-card_sup-text"> <h4>Your score is {{ score }}/{{ total }}</h4> </div> <question-card [preview]="true" [question]="question" *ngFor="#question of questions"></question-card> `, directives: [QuestionCard] }) export class Summary implements OnInit { private questions: IQuestion[]; private score: number; private total: number; private questionsStore: IQuestionsStore; constructor(questionsStore: QuestionsStore) { this.questionsStore = questionsStore; this.questionsStore.fetch().then( (questions) => this.questions = questions ); } ngOnInit() { this.total = this.questions.length; this.score = this.questionsStore.computeResult(this.questions); } } Orienté composants Associé à un selector CSS3 Template HTML inline Injection de dépendance Callback sur cycle de vie Composant enfant Binding de propriétés
  • 6. 6 Apache Kafka 0 1 2 3 0 1 Topic A Partition 1 Partition 2 Topic B 0 1 2 Partition 1 Consommateur Ω Consommateur µ Zookeeper Client A Client B
  • 7. 7 Spring Boot & Spring Cloud “ make jar not war ”Service Discovery (Eureka) Config Server (Spring Cloud) Micro-service de réservations REST H2 Client de réservation GET http://reservation-service/reservations RabbitMQ
  • 8. 8
  • 9. Jenkinsfile “ le pendant du .travis.yml pour Jenkins” jettyUrl = 'http://localhost:8081/’ def servers stage ’Build' node { checkout scm servers = load 'servers.groovy' mvn '-o clean package' dir('target') {stash name: 'war', includes: 'x.war'} } stage ’Acceptance Test' parallel(longerTests: { runTests(servers, 30) }, quickerTests: { runTests(servers, 20) }) def mvn(args) { sh "${tool 'Maven 3.x'}/bin/mvn ${args}" }
  • 10. React 10 var HelloMessage = React.createClass({ render: function() { return <div>Hello {this.props.name}</div>; } }); ReactDOM.render(<HelloMessage name="John" />, mountNode); • Le V de MVC o Déclaratif o Composants • Virtual DOM o Performance o Server Side rendering • React Native o Learn once, write anywhere o iOS et Androïd
  • 11. Une JVM de 3 To 11
  • 12. Rendre la doc aussi fun que le code • Conversations over documentation • Pair programming, mob-programming, revues de code • Savoir métier et DDD • Scénarios fonctionnels dans Cucumber, SpecFlow, JGiven • Session d’Event Storming • La documentation passe également par le code • Conventions de nommage, package-info.java • Annotations Java avec sémantique (ex: @BoundedContext) • Gérer la documentation comme le code • Versionnée dans le référentiel de code source • Présente dans l’IDE pour prendre en compte les refactoring • Outils de génération de diagrammes : Ditaa, DOT … 12
  • 13. Bonnes pratiques des revues de code 13 • Prendre le temps, à tête reposée et à un rythme soutenable • Echangez de vive voix pendant les revues • L’auteur corrige, en binôme si nécessaire • Ecrivez vos standards et les faire évoluer • Critiquez le code, pas le développeur • Pas de discussions à rallonge • Trouvez des compromis et en faire un standard “ 1h de revue = 4h de debug économisée ”
  • 14. 14 Vidéos librement disponibles sur le channel « Devoxx FR 2016 » de Youtube https://www.youtube.com/channel/UCsVPQfo5RZErDL41LoWvk0A

Notas del editor

  1. JavaScript 2015, Angular 2, React, Big Server, Reactive, Cloud, Test, Git, Spring Boot, HTTP 2.0, Kubernetes, Lean, Blockchain, Microservice, Kafka, Jenkins, Maven, Test, Docker, TypesScript, Jgiven, Java 9, Jigsaw, D3.JS, Toast Tk, Akka, SonarLint, Security, Docker, Continous Delivery, Vue.js, SQL, Polymer, Ansible, Vert.x, Spark, HBase, Scala, React, Mesos, Event Storming, Bluemix, Androïd, Feignant, Postgresql, Dropwizard, JavaScript, Java 8, Ionic, Traefik, Redux, RxJs,, Elasticsearch, Lucene, Ansible, Hadoop, OpenShift, TDD, JVM, DevOps, TDD, JHipster, Hibernate, EhCache, Chronicle Queue, JSPM, Systemjs, Gruntjs, Zeppelin, RAML, REST, H2O, Haskell, Gradle, Asciidoctor, SQL, Eclipse, Spring Cloud, Swift, Jigsaw, Big Data, AWS, CDI, jOOQ, Timelion, DDD, Les Cast Codeurs
  2. D’après le talk ES6+ maintenant ! de Christophe Porteneuve Slides : http://tdd.github.io/devoxx-es6-maintenant/
  3. D’après le talk Stack Overflow behind the scenes. How it’s made de Oded Coster Slides : http://OdedCoster.com/Devoxx.fr-2016
  4. Extrait simplifié du fichier Summary.ts https://github.com/manekinekko/angular2-codelab Syntaxe TypeScript
  5. D’après le Hand’s on Lab sur Kafka animé par Matthieu Blanc & Sylvain Lequeur Kafka est un journal de log distribué, hautement disponible et performant. Cette solution peut être considérée comme une base de donneés. Son stockage de données est sûr et la persistance est au cœur même du système. GitHub : https://github.com/mblanc/hands_on_kafka
  6. Basé sur la conférence The Bootiful Microservice de Josh Long (Pivotal) Présentation : http://github.com/joshlong/bootiful-microservices
  7. D’après la conférence String Concaténation de 1 à 9 animée par Rémi Forax Slides : https://speakerdeck.com/forax/string-concatenation-de-1-a-9 N’utiliser les StringBuilder que pour les boucles, sinon l’opérateur + : le compilateur et la JVM s’occupent de tout. Dans Java 9, à cause de la JEP 254, les chaines de caractères ne sont plus codées avec des char mais avec des tableaux de bytes. Il y’a un paramètre supplémentaire qui indique l’encodage (LATIN, UTF16)
  8. Inspiré du Tools in action De Jenkins Maven / Freestyle à Pipeline animé par Adrien Lecharpentier Slides : https://speakerdeck.com/alecharp/freestyle-a-pipeline Exemple de script Groovy extrait de https://github.com/jenkinsci/workflow-aggregator-plugin/blob/master/demo/repo/Jenkinsfile
  9. D’après la conférence Let’s React animée par Mathieu Ancelin Youtube : https://www.youtube.com/watch?v=IFM8krjbKmQ Exemple JSX du Hello World extrait de https://facebook.github.io/react/
  10. Photo prise lors de la conférence Comment faire tourner une JVM de 16 To animée par Antoine Chambille et Romain Colle (Quartet FS) Big Memory Servers avec architecture NUMA : - Bullion 24 TB – 288 Cores – Linux : serveur modulaire qu’on peut étendre, assemblé en France - Oracle Sparc M7-16 : 16 TB – 512 Cores – Solaris
  11. D’après la conférence Live Documentation : vous allez aimer la documentation animée par Cyrille Martraire
  12. D’après le quickie Ratez ses revues de code en 5 leçons animée parMichel Domenjoud (Octo) Partager les connaissances et les standards 3 types de revue de code : par un pair, collective ou pair programming