SlideShare ist ein Scribd-Unternehmen logo
1 von 71
Faster Java EE Builds
with Gradle
RYAN CUPRAK
About
 Ryan Cuprak
 @ctjava
 rcuprak@gmail.com
 http://www.cuprak.info
 https://www.linkedin.com/in/rcuprak
Introducing Gradle
• Open source build automation system
• Apache 2.0 License
• Builds upon Apache Ant and Maven
• First released in 2007
• Uses a Groovy-based DSL (not XML)
• Uses directed acyclic graph to determine build order
• Supports multiple languages: Java, C++, C, etc.
• Rich plug-in architecture
• Convention over configuration but easily
customized/adapted
Introducing Gradle
• Build file can be versioned like dependencies.
Ever run Ant 1.9 file with Ant 1.6?
• Background daemon reduces build-time
• Supports incremental builds
• Built-in profiling support
• Build projects in parallel and some tasks*
• Built-in Ant/Maven integration
• Supported central repositories:
• Maven Central
• Jcenter
• Ivy
Build System Evolution
Ant
Maven
Gradle2004
2007
2000
Gradle versus Maven
Feature Gradle Maven
Fully configurable DAG ✅ ❌
Task Exclusion ✅ ❌
Dry Run ✅ ❌
Advanced Task Ordering ✅ ❌
Custom Distributions ✅ ❌
Checksum Based Cache ✅ ❌
Version Conflict Resolution ✅ ❌
File Based Dependencies ✅ ❌
Finalizers ✅ ❌
Custom Dependency Scopes ✅ ❌
ReplaceByRules ✅ ❌
https://gradle.org/maven-vs-gradle
Why Gradle?
Questions
1. Do you need to learn Groovy?
No (Good idea)
2. Do you need to completely refactor your code base?
No
3. Do you need additional IDE plugins?
Maybe
4. Do you need to change your build process?
Depends
5. Do you need to port your entire build system over?
No – can port over individual modules
6. Can you embed custom Ant logic?
Yes
Questions…
7. Must all dependencies originate from a repository?
No
8. Can artifacts be pushed to a repository?
Yes
9. Can Jenkins initiate Gradle builds?
Yes
Why Gradle for Java EE?
Java EE projects are:
 Large
 Complex
 Contain many dependencies
 Ant lacks dependency management
Large Ant files are a nightmare to debug
Maven isn’t flexible
 Custom plugins aren’t the solution
 Evolving slowly
Installation
 Installation similar to Ant/Maven
 Download and install from gradle.org
 Set environment variables:
 GRADLE_HOME
 PATH (to GRADLE_HOME/bin)
 gradle = ant = mvn
Key Gradle Files
Build file build.gradle
Configuration settings settings.gradle
Local settings ~/.gradle/gradle.properties
Local repository (project)/.gradle
build.gradle = pom.xml = build.xml
Gradle Daemon
Gradle daemon is enabled by default
(Disable for continuous build environments!)
Displaying status
gradle –status
Stopping daemon:
gradle –stop
Disabling daemon:
Add org.gradle.daemon=false to ~/.gradle
Project Creation
To start a new project:
 gradle init – creates a new project
 Uses pom.xml if present.
 Imports multi-model projects
 Optionally specify –type <type>
 java-library
 scala-library
 groovy-library
 basic (default) – no src directories created.
 Central repository defaults to jcenter()
https://bintray.com/bintray/jcenter
Project Creation…
 gradle init --type java-library
Default Project Layout
src
main
resources
test
java
resources
build.gradle
settings.gradle
java
project
Initial Gradle File
Command line – listing tasks
gradle –q tasks
------------------------------------------------------------
All tasks runnable from root project
------------------------------------------------------------
Build tasks
-----------
assemble - Assembles the outputs of this project.
build - Assembles and tests this project.
buildDependents - Assembles and tests this project and all
projects that depend on it.
buildNeeded - Assembles and tests this project and all projects
it depends on.
classes - Assembles classes 'main'.
clean - Deletes the build directory.
jar - Assembles a jar archive containing the main classes.
testClasses - Assembles classes 'test'.
Tasks Continued…
Build Setup tasks
-----------------
init - Initializes a new Gradle build. [incubating]
wrapper - Generates Gradle wrapper files. [incubating]
Documentation tasks
-------------------
javadoc - Generates Javadoc API documentation for the
main source code.
Tasks Continue…
Help tasks
----------
components - Displays the components produced by root
project 'scratch'. [incubating]
dependencies - Displays all dependencies declared in root
project 'scratch'.
dependencyInsight - Displays the insight into a specific
dependency in root project 'scratch'.
help - Displays a help message.
model - Displays the configuration model of root project
'scratch'. [incubating]
projects - Displays the sub-projects of root project 'scratch'.
properties - Displays the properties of root project 'scratch'.
tasks - Displays the tasks runnable from root project 'scratch'.
Verification tasks
------------------
check - Runs all checks.
test - Runs the unit tests.
Sample Output
gradle build
src
build
scratch-1.0-SNAPSHOT.jar
libs
project
Output
Projects versus Tasks
Project 1 Project 2
Project 3
Task 1
Task 3
Task 2
Depends on
Task 1
Task 2
Depends on
Task 1
Task 3
Task 2
Depends on
Task 3
Depends on
Understanding build.gradle
org.gradle.api.Project
apply(options: Map<String,?>)
buildscript(config: Closure)
dependencies(config: Closure)
configurations(config: Closure)
getDependencies()
getConfigurations()
getAnt()
getName()
getDescription()
getGroup()
getPath()
getVersion()
getLogger()
setDescription(description: String)
setVersion(version: Object)
file(path: Object)
task(args: Map<String,?>,name: String)
Project is an implicit object.
Project.apply plugin: ‘java
Understanding Gradle Tasks
org.gradle.api.Task
dependsOn(tasks: Object…)
doFirst(action: Closure)
doLast(action: Closure)
getActions()
getInputs()
getOutputs()
getAnt()
getDescription()
getEnabled()
getGroup()
setDescription(description: String)
setEnabled(enabled: boolean)
setGroup(group: String)
Tasks are built on the Task object.
Defining Tasks
Task Dependencies
Grouping Tasks
Grouping Tasks
Custom Group
Plugins
Plugin ID Automatically
Applies
Works With Description
java java-base Java compilation/testing
application java,distribution
ear java Java EE Support
maven java,war Maven publishing
war java Assembles WAR files
java-library-
distribution
java, distribution Support for tar/zip
distributions for Java
library.
idea java Generates IDEA files
eclipse java,groovy,
scala
Generates Eclipse files
Standard: https://docs.gradle.org/current/userguide/standard_plugins.html
Third party: https://plugins.gradle.org
Multi-Module Projects
Multi-Module Projects
admin-web
model
myApp
web
mobile-app
build.gradle
gradle.properties
admin-web
model
myApp
web
mobile-app
build.gradle
gradle.properties
master
Hierarchical Layout Flat Layout
Hierarchical Layout: Example Project
ctjava
build.gradle
settings.gradle
ctcore
build.gradle
settings.gradle
ctweb
build.gradle
settings.gradle
migrate
build.gradle
settings.gradle
Hierarchical Layout: Top Level
build.gradle gradle.settings
ctjava
Hierarchical Layout: Second Level
 gradle.settings for ctcore/migrate/ctweb:
rootProject.name = 'ctjava’
 migrate/ctweb dependencies on ctcore
compile project (':ctcore’)
IDE Support
IDE Support
IDE Separate Plugin Java EE Support
IDEA (free) No Yes
IDEA (paid) No Yes
NetBeans Yes Yes
Eclipse Yes Yes
Eclipse Gradle Support
 http://download.eclipse.org/buildship/updates/e46/r
eleases/1.0
NetBeans Gradle Support
Multi-project Java EE projects not recognized.
IntelliJ Support
Legacy Project
NetBeans EE Project to Gradle
File System Project Representation
NetBeans EE Project to Gradle
Java Source
directories
WAR Plugin
Local JARs
NetBeans EE Project to Gradle
Web resource
directory
Java EE
Dependencies
Local JAR
Continued…
WAR Plugin Configuration
Configuration Description
from Adds a file-set to the root of the archive
webInf Adds a file-set to the WEB-INF dir.
classpath Adds a file-set to the WEB-INF/lib dir
webAppDirName The name of the web application source directory, relative
to the project directory.
webXml Copies a file to WEB-INF/web.xml
Recipes
JavaScript Minification
Minification Output
Google Minifier
JavaScript Minification…
 Extend JavaExec Task to invoke Minifier
JavaScript Minification…
gradle -PjsOptimize=true build
Node/Webpack Integration
Node Gradle Plugin
https://github.com/srs/gradle-node-plugin
Supports: NodeJS, Yarn, Grunt, Gulp
Generating JPA Meta-Model
Create custom plugin to run Java Annotation Processor:
implementation-class=JavaAptPlugin
Custom Annotation Processor
Custom annotation processor
Custom Annotation Processor
Custom annotation processor
Custom Annotation Processor:
Build Plugin
Exclude everything
but JPA entities
Custom annotation processor
EAR Projects
Project Output
Contents of EAR
EAR Project
EAR plugin
Provided Scope – Non-WAR Projects
• providedCompile is a configuration on WAR plugin.
• Non-WAR projects must add a custom scope.
jaxb Code Generation
POJOxsd
Generating JAX-WS Client
 Generate JAX-WS client for WSDL using wsimport
 Plugin:
 https://plugins.gradle.org/plugin/me.seeber.wsimport
 Generated source code:
 build/generated-src/wsimport
Generating JAX-WS Client
https://plugins.gradle.org/plugin/me.seeber.wsimport
Generating JAX-WS Client
Generated Source Code
Docker
 Build Docker images from project output:
 Transmode/gradle-docker - http://tinyurl.com/k7o7nab
 Build/publish docker files from build script – not Dockerfile
 bmuschko/gradle-docker-plugin -
http://tinyurl.com/hg4q6jr
 docker-remote-api – interacts with Docker via remote API
 docker-java-application – creates/pushes docker images for java
applications
 Run Docker containers during build
 palantir/gradle-docker - http://tinyurl.com/hpw853h
 docker – building and pushing docker images
 docker-compose - populating placeholders in a docker-compose
template
 docker-run – starting/stopping/status on named images
Building Docker Images
Simple Docker Example – Run
Container
Available Tasks:
• dockerRun
• dockerStop
• dockerRunStatus
• dockerRemoveContainer
Docker & Testing
 Launch PostgreSQL Docker container before unit tests
execute
 Test cleanup:
 Leave container running if any tests fail
 Destroy container if tests succeed
Docker & Testing
Docker Database Testing
Parameter Substitution: persistence.xml
Parameter Substitution: build.gradle
Testing with Arquillian/Selenium
Misc
 View Dependencies:
gradle -q ctweb:dependencies
 Build GUI:
gradle –gui
 Profiling:
gradle –profile
 Dryrun
gradle –m build
Reasons to Convert
 Incremental compilation
 Better dependency management/control
 Customizable without needing plugins
 Supports multiple languages/platforms
 Build system can be versioned
Q&A

Weitere ähnliche Inhalte

Was ist angesagt?

Developing Plug-Ins for NetBeans
Developing Plug-Ins for NetBeansDeveloping Plug-Ins for NetBeans
Developing Plug-Ins for NetBeans
elliando dias
 
Enabling White-Box Reuse in a Pure Composition Language
Enabling White-Box Reuse in a Pure Composition LanguageEnabling White-Box Reuse in a Pure Composition Language
Enabling White-Box Reuse in a Pure Composition Language
elliando dias
 

Was ist angesagt? (20)

Exploring Java Heap Dumps (Oracle Code One 2018)
Exploring Java Heap Dumps (Oracle Code One 2018)Exploring Java Heap Dumps (Oracle Code One 2018)
Exploring Java Heap Dumps (Oracle Code One 2018)
 
Batching and Java EE (jdk.io)
Batching and Java EE (jdk.io)Batching and Java EE (jdk.io)
Batching and Java EE (jdk.io)
 
Polygot Java EE on the GraalVM
Polygot Java EE on the GraalVMPolygot Java EE on the GraalVM
Polygot Java EE on the GraalVM
 
An introduction to maven gradle and sbt
An introduction to maven gradle and sbtAn introduction to maven gradle and sbt
An introduction to maven gradle and sbt
 
Developing Plug-Ins for NetBeans
Developing Plug-Ins for NetBeansDeveloping Plug-Ins for NetBeans
Developing Plug-Ins for NetBeans
 
Web application development using Play Framework (with Java)
Web application development using Play Framework (with Java)Web application development using Play Framework (with Java)
Web application development using Play Framework (with Java)
 
Gradle - Build system evolved
Gradle - Build system evolvedGradle - Build system evolved
Gradle - Build system evolved
 
Java 9 preview
Java 9 previewJava 9 preview
Java 9 preview
 
Spring Framework 3.2 - What's New
Spring Framework 3.2 - What's NewSpring Framework 3.2 - What's New
Spring Framework 3.2 - What's New
 
Play vs Grails Smackdown - Devoxx France 2013
Play vs Grails Smackdown - Devoxx France 2013Play vs Grails Smackdown - Devoxx France 2013
Play vs Grails Smackdown - Devoxx France 2013
 
Enabling White-Box Reuse in a Pure Composition Language
Enabling White-Box Reuse in a Pure Composition LanguageEnabling White-Box Reuse in a Pure Composition Language
Enabling White-Box Reuse in a Pure Composition Language
 
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
Spring 3.1 to 3.2 in a Nutshell - Spring I/O 2012
 
Java build tool_comparison
Java build tool_comparisonJava build tool_comparison
Java build tool_comparison
 
Getting Started with Java EE 7
Getting Started with Java EE 7Getting Started with Java EE 7
Getting Started with Java EE 7
 
Gradle Introduction
Gradle IntroductionGradle Introduction
Gradle Introduction
 
Intelligent Projects with Maven - DevFest Istanbul
Intelligent Projects with Maven - DevFest IstanbulIntelligent Projects with Maven - DevFest Istanbul
Intelligent Projects with Maven - DevFest Istanbul
 
Apache DeltaSpike the CDI toolbox
Apache DeltaSpike the CDI toolboxApache DeltaSpike the CDI toolbox
Apache DeltaSpike the CDI toolbox
 
Maven
MavenMaven
Maven
 
Why Play Framework is fast
Why Play Framework is fastWhy Play Framework is fast
Why Play Framework is fast
 
Introduction tomaven
Introduction tomavenIntroduction tomaven
Introduction tomaven
 

Ähnlich wie Faster Java EE Builds with Gradle

Gradle - time for a new build
Gradle - time for a new buildGradle - time for a new build
Gradle - time for a new build
Igor Khotin
 
How to start using Scala
How to start using ScalaHow to start using Scala
How to start using Scala
Ngoc Dao
 
Gradleintroduction 111010130329-phpapp01
Gradleintroduction 111010130329-phpapp01Gradleintroduction 111010130329-phpapp01
Gradleintroduction 111010130329-phpapp01
Tino Isnich
 

Ähnlich wie Faster Java EE Builds with Gradle (20)

Gradle - time for a new build
Gradle - time for a new buildGradle - time for a new build
Gradle - time for a new build
 
OpenCms Days 2012 - Developing OpenCms with Gradle
OpenCms Days 2012 - Developing OpenCms with GradleOpenCms Days 2012 - Developing OpenCms with Gradle
OpenCms Days 2012 - Developing OpenCms with Gradle
 
Gradle: The Build System you have been waiting for!
Gradle: The Build System you have been waiting for!Gradle: The Build System you have been waiting for!
Gradle: The Build System you have been waiting for!
 
Gradle - Build System
Gradle - Build SystemGradle - Build System
Gradle - Build System
 
Gradle notes
Gradle notesGradle notes
Gradle notes
 
Introduction to gradle
Introduction to gradleIntroduction to gradle
Introduction to gradle
 
Gradle: The Build system you have been waiting for
Gradle: The Build system you have been waiting forGradle: The Build system you have been waiting for
Gradle: The Build system you have been waiting for
 
GradleFX
GradleFXGradleFX
GradleFX
 
Javaone - Gradle: Harder, Better, Stronger, Faster
Javaone - Gradle: Harder, Better, Stronger, Faster Javaone - Gradle: Harder, Better, Stronger, Faster
Javaone - Gradle: Harder, Better, Stronger, Faster
 
Make Your Build Great Again (DroidConSF 2017)
Make Your Build Great Again (DroidConSF 2017)Make Your Build Great Again (DroidConSF 2017)
Make Your Build Great Again (DroidConSF 2017)
 
Android gradle-build-system-overview
Android gradle-build-system-overviewAndroid gradle-build-system-overview
Android gradle-build-system-overview
 
Android presentation - Gradle ++
Android presentation - Gradle ++Android presentation - Gradle ++
Android presentation - Gradle ++
 
How to start using Scala
How to start using ScalaHow to start using Scala
How to start using Scala
 
What's new in Gradle 4.0
What's new in Gradle 4.0What's new in Gradle 4.0
What's new in Gradle 4.0
 
Gradle - the Enterprise Automation Tool
Gradle  - the Enterprise Automation ToolGradle  - the Enterprise Automation Tool
Gradle - the Enterprise Automation Tool
 
Gradle 2.Write once, builde everywhere
Gradle 2.Write once, builde everywhereGradle 2.Write once, builde everywhere
Gradle 2.Write once, builde everywhere
 
Gradle como alternativa a maven
Gradle como alternativa a mavenGradle como alternativa a maven
Gradle como alternativa a maven
 
Enterprise build tool gradle
Enterprise build tool gradleEnterprise build tool gradle
Enterprise build tool gradle
 
Gradle
GradleGradle
Gradle
 
Gradleintroduction 111010130329-phpapp01
Gradleintroduction 111010130329-phpapp01Gradleintroduction 111010130329-phpapp01
Gradleintroduction 111010130329-phpapp01
 

Mehr von Ryan Cuprak

Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and
Ryan Cuprak
 

Mehr von Ryan Cuprak (13)

Jakarta EE Test Strategies (2022)
Jakarta EE Test Strategies (2022)Jakarta EE Test Strategies (2022)
Jakarta EE Test Strategies (2022)
 
DIY Home Weather Station (Devoxx Poland 2023)
DIY Home Weather Station (Devoxx Poland 2023)DIY Home Weather Station (Devoxx Poland 2023)
DIY Home Weather Station (Devoxx Poland 2023)
 
Containerless in the Cloud with AWS Lambda
Containerless in the Cloud with AWS LambdaContainerless in the Cloud with AWS Lambda
Containerless in the Cloud with AWS Lambda
 
Java script nirvana in netbeans [con5679]
Java script nirvana in netbeans [con5679]Java script nirvana in netbeans [con5679]
Java script nirvana in netbeans [con5679]
 
Jms deep dive [con4864]
Jms deep dive [con4864]Jms deep dive [con4864]
Jms deep dive [con4864]
 
Top 50 java ee 7 best practices [con5669]
Top 50 java ee 7 best practices [con5669]Top 50 java ee 7 best practices [con5669]
Top 50 java ee 7 best practices [con5669]
 
Developing in the Cloud
Developing in the CloudDeveloping in the Cloud
Developing in the Cloud
 
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
Combining R With Java For Data Analysis (Devoxx UK 2015 Session)
 
Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and Hybrid Mobile Development with Apache Cordova and
Hybrid Mobile Development with Apache Cordova and
 
JavaFX Versus HTML5 - JavaOne 2014
JavaFX Versus HTML5 - JavaOne 2014JavaFX Versus HTML5 - JavaOne 2014
JavaFX Versus HTML5 - JavaOne 2014
 
50 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
50 EJB 3 Best Practices in 50 Minutes - JavaOne 201450 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
50 EJB 3 Best Practices in 50 Minutes - JavaOne 2014
 
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
Hybrid Mobile Development with Apache Cordova and Java EE 7 (JavaOne 2014)
 
JavaOne 2013: Organizing Your Local Community
JavaOne 2013: Organizing Your Local CommunityJavaOne 2013: Organizing Your Local Community
JavaOne 2013: Organizing Your Local Community
 

Kürzlich hochgeladen

AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM TechniquesAI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
VictorSzoltysek
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
Health
 
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
9953056974 Low Rate Call Girls In Saket, Delhi NCR
 

Kürzlich hochgeladen (20)

Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) SolutionIntroducing Microsoft’s new Enterprise Work Management (EWM) Solution
Introducing Microsoft’s new Enterprise Work Management (EWM) Solution
 
AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM TechniquesAI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
AI Mastery 201: Elevating Your Workflow with Advanced LLM Techniques
 
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
+971565801893>>SAFE AND ORIGINAL ABORTION PILLS FOR SALE IN DUBAI AND ABUDHAB...
 
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
Tech Tuesday-Harness the Power of Effective Resource Planning with OnePlan’s ...
 
Exploring the Best Video Editing App.pdf
Exploring the Best Video Editing App.pdfExploring the Best Video Editing App.pdf
Exploring the Best Video Editing App.pdf
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdfThe Ultimate Test Automation Guide_ Best Practices and Tips.pdf
The Ultimate Test Automation Guide_ Best Practices and Tips.pdf
 
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICECHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
CHEAP Call Girls in Pushp Vihar (-DELHI )🔝 9953056974🔝(=)/CALL GIRLS SERVICE
 
Unlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language ModelsUnlocking the Future of AI Agents with Large Language Models
Unlocking the Future of AI Agents with Large Language Models
 
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdfAzure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
Azure_Native_Qumulo_High_Performance_Compute_Benchmarks.pdf
 
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
call girls in Vaishali (Ghaziabad) 🔝 >༒8448380779 🔝 genuine Escort Service 🔝✔️✔️
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS LiveVip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
 
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
W01_panagenda_Navigating-the-Future-with-The-Hitchhikers-Guide-to-Notes-and-D...
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial Goals
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected WorkerHow To Troubleshoot Collaboration Apps for the Modern Connected Worker
How To Troubleshoot Collaboration Apps for the Modern Connected Worker
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 
8257 interfacing 2 in microprocessor for btech students
8257 interfacing 2 in microprocessor for btech students8257 interfacing 2 in microprocessor for btech students
8257 interfacing 2 in microprocessor for btech students
 

Faster Java EE Builds with Gradle