SlideShare a Scribd company logo
1 of 143
Download to read offline
at
Productivity and Performance at Scale
You are a developer using Java to
build web services.
This is your life:
Waiting. [1]
tail -f logs/catalina.out
XML soup
"Convenient proxy factory bean superclass for proxy
factory beans that create only singletons." [2]
Thread pool usage
Latency
Thread pool hell
There is a better way.
Ruby on Rails!
Nah, just kidding. We have real work to do.
A modern web framework for Java and Scala
The world’s largest professional network
at
We've been using Play in production for
more than 6 months [3]
A few apps built on Play
Channels (frontend)
Premium Subscriptions (frontend)
Polls (frontend + backend)
REST search (internal tool)
About me
Leading the Play project as part of LinkedIn's Service Infrastructure Team.
Also: hackdays, engineering blog, incubator, open source.
This talk is the story of building web services
at massive scale with Java and Scala...
... while maintaining performance,
reliability, and developer
productivity.
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Download and install Play from
http://www.playframework.com
> play new my-app
> play idea
> play eclipse
> play run
http://localhost:9000
Application layout
app β†’ Application sources
β”” assets β†’ Compiled asset sources
β”” controllers β†’ Application controllers
β”” models β†’ Application business layer
β”” views β†’ Templates
conf β†’ Configurations files
β”” application.conf β†’ Main configuration file
β”” routes β†’ Routes definition
public β†’ Public assets
β”” stylesheets β†’ CSS files
β”” javascripts β†’ Javascript files
β”” images β†’ Image files
project β†’ sbt configuration files
β”” Build.scala β†’ Application build script
β”” plugins.sbt β†’ sbt plugins
lib β†’ Unmanaged libraries
dependencies
logs β†’ Standard logs folder
target β†’ Generated stuff
test β†’ Unit or functional tests
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
public class HelloWorld extends Controller {
public static Result index() {
return ok("Hello World");
}
}
Create a new controller and action
app/controllers/HelloWorld.java
Don't worry about the use of static. Yes,
Play supports IOC. Using static (and other
shortcuts) lets me keep the examples simple.
GET /hello controllers.HelloWorld.index()
Expose the controller/action at a URL
conf/routes
Now, restart the server.
Nah, just kidding. Refresh the page.
Woohoo, hot reload!
http://localhost:9000/hello
public class HelloWorld extends Controller {
public static Result index(String name) {
return ok("Hello " + name);
}
}
Add a parameter
app/controllers/HelloWorld.java
GET /hello controllers.HelloWorld.index( name)
Read the parameter from the query string
conf/routes
http://localhost:9000/hello?name=Jim
GET /hello/:name controllers.HelloWorld.index(name)
Read the parameter from the URL instead
conf/routes
http://localhost:9000/hello/Jim
public class HelloWorld extends Controller {
public static Result index(String name, int age) {
return ok("Hello " + name + " you are " + age +
" years old");
}
}
Add another parameter, this time an int
app/controllers/HelloWorld.java
GET /hello/:name/ :age controllers.HelloWorld.index(name: String, age: Int)
Add the parameter. Note the type checking!
conf/routes
http://localhost:9000/hello/Jim/28
@(name: String, age: Int)
<html>
<head></head>
<body>
<img src="/assets/images/play-logo.png"/>
<p>
Hello <b>@name</b>, you are <b>@age</b> years old
</p>
</body>
</html>
Add a view
app/views/hello.scala.html
public class HelloWorld extends Controller {
public static Result index(String name, int age) {
return ok(views.html.hello.render(name, age));
}
}
Render the view from the controller
app/controllers/HelloWorld.java
http://localhost:9000/hello/Jim/28
location = "JaxConf"
How about some config?
app/conf/application.conf
public class HelloWorld extends Controller {
public static Result index(String name, int age) {
String location = getConfig().getString("location");
return ok(views.html.hello.render(name, age,
location));
}
private static Configuration getConfig() {
return Play.application().configuration();
}
}
Read the config and pass it to the view
app/controllers/HelloWorld.java
@(name: String, age: Int, location: String)
<html>
<head></head>
<body>
<img src="/assets/images/play-logo.png"/>
<p>
Hello <b>@name</b>, you are <b>@age</b> years old
and you are at <b>@location</b>
</p>
</body>
</html>
Update the view
app/views/hello.scala.html
Refresh the page. Config hot reloads too!
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
In dev mode, Play shows error messages
right in the browser.
Parameter type checking
A helpful 404 page
Compile errors show problematic source code
in the browser
Views are compiled as well
The routes file too
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Most people are used to threaded servers
Threaded servers assign one thread per
request and use blocking I/O
void doGet(HttpServletRequest req, HttpServletResponse res) {
// Apache HttpClient
HttpClient client = new HttpClient();
GetMethod method = new GetMethod("www.example.com/");
// executeMethod is a blocking, synchronous call
int statusCode = client.executeMethod(method);
System.out.println("Response " + statusCode);
}
MyServlet.java
Evented servers are gaining popularity
Evented servers have one thread/process per
CPU core and use non-blocking I/O
MyNodeApp.js
var callback = function(data) {
console.log("Response: " + data);
};
var options = {
hostname: 'www.google.com',
path: '/upload'
};
// Non-blocking HTTP call
http.request(options, callback);
console.log('This line may execute before the callback!');
Why threaded vs. evented matters for
LinkedIn
LinkedIn uses a Service Oriented Architecture
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
void doGet(HttpServletRequest req, HttpServletResponse res) {
// Call a number of backend services to get data
Profile profile = profileSvc.getProfile();
Company company = companySvc.getCompany();
Skills skills = skillsSvc.getSkills();
}
MyServlet.java
Our services spend most of their time waiting
for data from other services and data stores
I/O is very expensive [4]
In a threaded server, threads spend most of
the time idle, waiting on I/O
Threading dilemma
1. Creating new threads on the fly is expensive:
a. Use a thread pool
2. Too many threads in the thread pool:
a. Memory overhead
b. Context switching overhead
3. Too few threads in the thread pool:
a. Run out of threads, latency goes up
b. Sensitive to downstream latency!
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
Let's say latency goes
up a little here
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
Causes threads to get
backed up here
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
Latency goes up
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
Now threads get
backed up here
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
And here
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
Here too
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
And there
Internet Load
Balancer
Frontend
Server
Frontend
Server
Frontend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Backend
Server
Data
Store
Data
Store
Data
Store
Data
Store
And... the site is down.
This is thread pool hell [5]
Play is built on top of Netty, so it supports non-
blocking I/O [6]
NIO benefits
1. No sensitivity to downstream slowness
2. Easy to parallelize I/O
3. Supports many concurrent and long-running
connections, enabling:
a. WebSockets
b. Comet
c. Server-Sent Events
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
public class Proxy extends Controller {
public static Result index(String url) {
// Non blocking HTTP call
Promise<Response> responsePromise = WS.url(url).get();
// How do we turn a Promise into a Play Result?
}
}
app/controllers/Proxy.java
Use Play's built in WS library to make a non-
blocking HTTP call
A Promise<T> will eventually contain the
value T (or an error)
(Play Framework source code)
Play has a built-in subclass of Result called
AsyncResult that takes a Promise<Result>
public static class AsyncResult implements Result {
private final Promise<Result> promise;
public AsyncResult(Promise<Result> promise) {
this.promise = promise;
}
}
public class Proxy extends Controller {
public static Result index(String url) {
// Non blocking HTTP call
Promise<Response> response = WS.url(url).get();
// Transform asynchronously into a Play Result
Promise<Result> result = response.map(toResult);
return async(result);
}
// A function that can transform a Response into a Result
private static Function<Response, Result> toResult =
new Function<Response, Result>() {
public Result apply(Response response) {
return ok(response.getBody()).as("text/html");
}
};
}
app/controllers/Proxy.java
We can use the map method to turn a
Promise<Response> into a Promise<Result>
GET /proxy controllers.Proxy.index(url)
Let's add this endpoint to the routes file
conf/routes
http://localhost:9000/proxy?url=http://example.com
We just built a completely
non-blocking proxy!
public class Proxy extends Controller {
public static Result index(String url) {
Logger.info("Before the HTTP call");
Promise<Response> response = WS.url(url).get();
Promise<Result> result = response.map(toResult);
Logger.info("After the HTTP call");
return async(result);
}
private static Function<Response, Result> toResult =
new Function<Response, Result>() {
public Result apply(Response response) {
Logger.info("Inside the toResult function");
return ok(response.getBody()).as("text/html");
}
};
}
app/controllers/Proxy.java
To see that it's non-blocking, let's add logging
Refresh the page and the logs show the
HTTP call really is non-blocking
NIO makes parallel requests easy.
Let's try it.
class Timing {
public String url;
public long latency;
public Timing(String url, long latency) {
this.url = url;
this.latency = latency;
}
// Fire an HTTP request and record how long it took
public static Promise<Timing> timedRequest(final String url) {
final long start = System.currentTimeMillis();
Promise<Response> res = WS.url(url).get();
return res.map(new Function<Response, Timing>() {
public Timing apply(Response response) {
long latency = System.currentTimeMillis() - start;
return new Timing(url, latency);
}
});
}
}
app/models/Timing.java
First, define a class that times an HTTP request
public class Parallel extends Controller {
public static Result index() {
// A Promise that will redeem when the 3 parallel
// HTTP requests are done
Promise<List<Timing>> all = Promise.waitAll(
Timing.timedRequest("http://www.yahoo.com"),
Timing.timedRequest("http://www.google.com"),
Timing.timedRequest("http://www.bing.com")
);
// Asynchronously transform timings into a JSON response
return async(all.map(new Function<List<Timing>, Result>() {
public Result apply(List<Timing> timings) {
return ok(Json.toJson(timings));
}
}));
}
}
app/controllers/Parallel.java
Next, add a controller that fetches 3 URLs in
parallel and returns the timings as JSON
GET /parallel controllers.Parallel.index()
Add it to the routes file
conf/routes
http://localhost:9000/parallel
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Play has native support for Scala
app/controllers/HelloWorldScala.scala
Just add a .scala file under /app and
Play will compile it
object HelloWorldScala extends Controller {
def index = Action {
Ok("Hello World Scala")
}
}
GET /scala controllers.HelloWorldScala.index()
Add it to the routes file as usual
conf/routes
http://localhost:9000/scala
Play/Scala: the good parts
Sequential async calls
// 2 sequential async calls
for {
foo <- WS.url(url1).get()
bar <- WS.url(buildUrl(foo)).get()
} yield {
Ok(...)
}
API is more concise, expressive, &
composable, especially for async code.
Sequential async calls
// 2 parallel async calls
val fooFuture = WS.url(url1).get()
val barFuture = WS.url(url2).get()
for {
foo <- fooFuture
bar <- barFuture
} yield {
Ok(...)
}
Interactive console with full classpath of your app
Play is Scala at its core: main libraries,
routes, templates, SBT, etc [7]
Play/Scala: the less good parts
Simple Build Tool: Play's build system. Very
powerful, but very steep learning curve.
project/Build.scala
val settings = Seq(
bootPath <<= target( _ / "boot" ),
buildDir <<= baseDirectory(_ / ".." / "build"),
srcDir <<= baseDirectory(_/ ".." / "src"),
enableConfigCompile := true,
fabrics <++= Seq("EI", "EI2")
)
Abandon all hope, ye who enter here
without knowing Scala.
project/Build.scala
fabrics <++= Seq("EI", "EI2")
WTF is <++=? Some kind of fish bones?
How do I google that?
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Is Play web scale? [8]
Scalability can be measured along
many dimensions
Raw
horsepower
Concurrent
horsepower
Single
developer
Multiple
developers
Raw horsepower: theoretical maximum
performance for the server in ideal
conditions. A measure of language and
framework overhead.
Concurrent horsepower: performance with
many users, I/O, and more real-world
scenarios. A measure of the framework's
approach to concurrency.
Single developer: how easy it is to get
started, how quickly a single developer can
build things. A measure of the framework's
raw productivity and tooling.
Multiple developers: how the framework
tolerates many developers working
concurrently over many years. A measure of
code rot and maintainability.
Here is how I'd rate some of the
frameworks I've used. YMMV.
● Pros
β—‹ Good raw throughput (qps, latency)
β—‹ Type safety reduces code rot
● Cons
β—‹ Not developer friendly. Getting things done takes
forever.
β—‹ Threaded, synchronous approach difficult to scale
for lots of I/O in a SOA environment.
MVC
Raw
horsepower
Concurrent
horsepower
Single
developer
Multiple
developers
SpringMVC
● Pros
β—‹ Set the bar for developer productivity; all other
frameworks are still trying to catch up.
● Cons
β—‹ Ruby is slow
β—‹ Ruby doesn't have real multithreading nor a great
evented framework
β—‹ Dynamic language makes it tougher to maintain a
large codebase
Raw
horsepower
Concurrent
horsepower
Single
developer
Multiple
developers
Rails
● Pros
β—‹ v8 engine is pretty fast for raw throughput
β—‹ Non-blocking I/O at the core makes concurrency
easy
β—‹ Strong open source community and lightning fast
startup time makes it easy to get things done quickly
● Cons
β—‹ Dynamic language makes it tougher to maintain a
large codebase
β—‹ Lots of immature libraries that constantly make
backwards incompatible changes
Raw
horsepower
Concurrent
horsepower
Single
developer
Multiple
developers
Node.js
● Pros
β—‹ Fast for raw throughput
β—‹ Non-blocking I/O at the core makes concurrency
easy
β—‹ Hot reload makes it possible to get things done
quickly
β—‹ Strong type safety throughout reduces code rot
● Cons
β—‹ Even with hot reload, a compiled statically typed
language isn't quite as fast as an interpreted
dynamically typed language
Raw
horsepower
Concurrent
horsepower
Single
developer
Multiple
developers
Play
Outline
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
Play is open source [7]
LinkedIn is contributing
Very active google group (mailing list) [9]
StackOverflow tag [10]
Open source modules and plugins [11]
We've open sourced a few of our plugins,
with many more on the way [12]
Commercial support from Typesafe [13]
Recap
1. Getting started with Play
2. Make a change and reload
3. Error handling
4. Threaded vs. evented
5. Non-blocking I/O
6. Scala
7. Performance
8. Community
That's the story of Play at LinkedIn so far...
But we're just getting started.
LinkedIn Engineering Blog [14]
@LinkedInEng on twitter [15]
Thank you!
References
1. http://zeroturnaround.com/java-ee-productivity-report-2011/
2. http://static.springsource.org/spring/docs/2.5.x/api/org/springframework/...
3. http://engineering.linkedin.com/play/play-framework-linkedin
4. http://www.eecs.berkeley.edu/~rcs/research/interactive_latency.html
5. http://engineering.linkedin.com/play/play-framework-async-io-without...
6. http://netty.io/
7. https://github.com/playframework/Play20
8. http://mongodb-is-web-scale.com/
9. https://groups.google.com/forum/?fromgroups#!forum/play-framework
10. http://stackoverflow.com/tags/playframework
11. http://www.playframework.com/documentation/2.1.1/Modules
12. https://github.com/linkedin
13. http://typesafe.com/platform/runtime/playframework
14. http://engineering.linkedin.com/
15. https://twitter.com/LinkedInEng

More Related Content

What's hot

Git One Day Training Notes
Git One Day Training NotesGit One Day Training Notes
Git One Day Training Notesglen_a_smith
Β 
Functional Application Logging : Code Examples Using Spring Boot and Logback
Functional Application Logging : Code Examples Using Spring Boot and LogbackFunctional Application Logging : Code Examples Using Spring Boot and Logback
Functional Application Logging : Code Examples Using Spring Boot and LogbackMohammad Sabir Khan
Β 
Gitlab flow
Gitlab flowGitlab flow
Gitlab flowviniciusban
Β 
Spring Boot and REST API
Spring Boot and REST APISpring Boot and REST API
Spring Boot and REST API07.pallav
Β 
Difference between Github vs Gitlab vs Bitbucket
Difference between Github vs Gitlab vs BitbucketDifference between Github vs Gitlab vs Bitbucket
Difference between Github vs Gitlab vs Bitbucketjeetendra mandal
Β 
NiFi μ‹œμž‘ν•˜κΈ°
NiFi μ‹œμž‘ν•˜κΈ°NiFi μ‹œμž‘ν•˜κΈ°
NiFi μ‹œμž‘ν•˜κΈ°Byunghwa Yoon
Β 
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)Junyoung Lee
Β 
使用 laravel ηš„ε‰θˆ‡εΎŒ
使用 laravel ηš„ε‰θˆ‡εΎŒδ½Ώη”¨ laravel ηš„ε‰θˆ‡εΎŒ
使用 laravel ηš„ε‰θˆ‡εΎŒShengyou Fan
Β 
Introduction to GitHub Actions
Introduction to GitHub ActionsIntroduction to GitHub Actions
Introduction to GitHub ActionsBo-Yi Wu
Β 
Maven Introduction
Maven IntroductionMaven Introduction
Maven IntroductionSandeep Chawla
Β 
Grails Simple Login
Grails Simple LoginGrails Simple Login
Grails Simple Loginmoniguna
Β 
The Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication TutorialThe Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication TutorialJean-François Gagné
Β 
Java Persistence API (JPA) Step By Step
Java Persistence API (JPA) Step By StepJava Persistence API (JPA) Step By Step
Java Persistence API (JPA) Step By StepGuo Albert
Β 
Git Tutorial I
Git Tutorial IGit Tutorial I
Git Tutorial IJim Yeh
Β 
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가?
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가? Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가?
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가? μ •λ―Ό μ•ˆ
Β 
Spring Boot
Spring BootSpring Boot
Spring BootJiayun Zhou
Β 

What's hot (20)

Git One Day Training Notes
Git One Day Training NotesGit One Day Training Notes
Git One Day Training Notes
Β 
Github in Action
Github in ActionGithub in Action
Github in Action
Β 
Functional Application Logging : Code Examples Using Spring Boot and Logback
Functional Application Logging : Code Examples Using Spring Boot and LogbackFunctional Application Logging : Code Examples Using Spring Boot and Logback
Functional Application Logging : Code Examples Using Spring Boot and Logback
Β 
Gitlab flow
Gitlab flowGitlab flow
Gitlab flow
Β 
Spring Boot and REST API
Spring Boot and REST APISpring Boot and REST API
Spring Boot and REST API
Β 
Difference between Github vs Gitlab vs Bitbucket
Difference between Github vs Gitlab vs BitbucketDifference between Github vs Gitlab vs Bitbucket
Difference between Github vs Gitlab vs Bitbucket
Β 
Argocd up and running
Argocd up and runningArgocd up and running
Argocd up and running
Β 
NiFi μ‹œμž‘ν•˜κΈ°
NiFi μ‹œμž‘ν•˜κΈ°NiFi μ‹œμž‘ν•˜κΈ°
NiFi μ‹œμž‘ν•˜κΈ°
Β 
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)
Git λ”ν•˜κΈ° GitHub(ꡬ름IDE ν™˜κ²½)
Β 
使用 laravel ηš„ε‰θˆ‡εΎŒ
使用 laravel ηš„ε‰θˆ‡εΎŒδ½Ώη”¨ laravel ηš„ε‰θˆ‡εΎŒ
使用 laravel ηš„ε‰θˆ‡εΎŒ
Β 
Introduction to GitHub Actions
Introduction to GitHub ActionsIntroduction to GitHub Actions
Introduction to GitHub Actions
Β 
Spring Security 5
Spring Security 5Spring Security 5
Spring Security 5
Β 
Maven Introduction
Maven IntroductionMaven Introduction
Maven Introduction
Β 
Grails Simple Login
Grails Simple LoginGrails Simple Login
Grails Simple Login
Β 
The Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication TutorialThe Full MySQL and MariaDB Parallel Replication Tutorial
The Full MySQL and MariaDB Parallel Replication Tutorial
Β 
Advanced Git
Advanced GitAdvanced Git
Advanced Git
Β 
Java Persistence API (JPA) Step By Step
Java Persistence API (JPA) Step By StepJava Persistence API (JPA) Step By Step
Java Persistence API (JPA) Step By Step
Β 
Git Tutorial I
Git Tutorial IGit Tutorial I
Git Tutorial I
Β 
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가?
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가? Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가?
Let'Swift 2023 iOS μ• ν”Œλ¦¬μΌ€μ΄μ…˜ 개발 생산성 고찰
- μ •μ‹œ 퇴근을 μœ„ν•΄ μš°λ¦¬λŠ” μ–΄λ–»κ²Œ ν•΄μ•Όν•  것인가?
Β 
Spring Boot
Spring BootSpring Boot
Spring Boot
Β 

Similar to The Play Framework at LinkedIn

Play Framework: async I/O with Java and Scala
Play Framework: async I/O with Java and ScalaPlay Framework: async I/O with Java and Scala
Play Framework: async I/O with Java and ScalaYevgeniy Brikman
Β 
Play Framework: The Basics
Play Framework: The BasicsPlay Framework: The Basics
Play Framework: The BasicsPhilip Langer
Β 
Play framework
Play frameworkPlay framework
Play frameworksambaochung
Β 
node.js: Javascript's in your backend
node.js: Javascript's in your backendnode.js: Javascript's in your backend
node.js: Javascript's in your backendDavid Padbury
Β 
Play framework productivity formula
Play framework   productivity formula Play framework   productivity formula
Play framework productivity formula Sorin Chiprian
Β 
01 overview-and-setup
01 overview-and-setup01 overview-and-setup
01 overview-and-setupsnopteck
Β 
Play Framework: Intro & High-Level Overview
Play Framework: Intro & High-Level OverviewPlay Framework: Intro & High-Level Overview
Play Framework: Intro & High-Level OverviewJosh Padnick
Β 
Dave Orchard - Offline Web Apps with HTML5
Dave Orchard - Offline Web Apps with HTML5Dave Orchard - Offline Web Apps with HTML5
Dave Orchard - Offline Web Apps with HTML5Web Directions
Β 
Developing Java Web Applications
Developing Java Web ApplicationsDeveloping Java Web Applications
Developing Java Web Applicationshchen1
Β 
Drupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp NorthDrupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp NorthPhilip Norton
Β 
Silicon Valley Code Camp 2011: Play! as you REST
Silicon Valley Code Camp 2011: Play! as you RESTSilicon Valley Code Camp 2011: Play! as you REST
Silicon Valley Code Camp 2011: Play! as you RESTManish Pandit
Β 
Play Support in Cloud Foundry
Play Support in Cloud FoundryPlay Support in Cloud Foundry
Play Support in Cloud Foundryrajdeep
Β 
cdac@parag.gajbhiye@test123
cdac@parag.gajbhiye@test123cdac@parag.gajbhiye@test123
cdac@parag.gajbhiye@test123Parag Gajbhiye
Β 
eXo Platform SEA - Play Framework Introduction
eXo Platform SEA - Play Framework IntroductioneXo Platform SEA - Play Framework Introduction
eXo Platform SEA - Play Framework Introductionvstorm83
Β 
Follow these reasons to know java’s importance
Follow these reasons to know java’s importanceFollow these reasons to know java’s importance
Follow these reasons to know java’s importancenishajj
Β 
An Overview of Node.js
An Overview of Node.jsAn Overview of Node.js
An Overview of Node.jsAyush Mishra
Β 
Introduction to node.js
Introduction to node.jsIntroduction to node.js
Introduction to node.jsSu Zin Kyaw
Β 
Programming Server side with Sevlet
 Programming Server side with Sevlet  Programming Server side with Sevlet
Programming Server side with Sevlet backdoor
Β 

Similar to The Play Framework at LinkedIn (20)

Play Framework: async I/O with Java and Scala
Play Framework: async I/O with Java and ScalaPlay Framework: async I/O with Java and Scala
Play Framework: async I/O with Java and Scala
Β 
Play Framework: The Basics
Play Framework: The BasicsPlay Framework: The Basics
Play Framework: The Basics
Β 
Play framework
Play frameworkPlay framework
Play framework
Β 
node.js: Javascript's in your backend
node.js: Javascript's in your backendnode.js: Javascript's in your backend
node.js: Javascript's in your backend
Β 
Play framework productivity formula
Play framework   productivity formula Play framework   productivity formula
Play framework productivity formula
Β 
01 overview-and-setup
01 overview-and-setup01 overview-and-setup
01 overview-and-setup
Β 
Play Framework: Intro & High-Level Overview
Play Framework: Intro & High-Level OverviewPlay Framework: Intro & High-Level Overview
Play Framework: Intro & High-Level Overview
Β 
Dave Orchard - Offline Web Apps with HTML5
Dave Orchard - Offline Web Apps with HTML5Dave Orchard - Offline Web Apps with HTML5
Dave Orchard - Offline Web Apps with HTML5
Β 
Developing Java Web Applications
Developing Java Web ApplicationsDeveloping Java Web Applications
Developing Java Web Applications
Β 
Drupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp NorthDrupal Performance : DrupalCamp North
Drupal Performance : DrupalCamp North
Β 
Silicon Valley Code Camp 2011: Play! as you REST
Silicon Valley Code Camp 2011: Play! as you RESTSilicon Valley Code Camp 2011: Play! as you REST
Silicon Valley Code Camp 2011: Play! as you REST
Β 
Play Support in Cloud Foundry
Play Support in Cloud FoundryPlay Support in Cloud Foundry
Play Support in Cloud Foundry
Β 
cdac@parag.gajbhiye@test123
cdac@parag.gajbhiye@test123cdac@parag.gajbhiye@test123
cdac@parag.gajbhiye@test123
Β 
Best Of Jdk 7
Best Of Jdk 7Best Of Jdk 7
Best Of Jdk 7
Β 
eXo Platform SEA - Play Framework Introduction
eXo Platform SEA - Play Framework IntroductioneXo Platform SEA - Play Framework Introduction
eXo Platform SEA - Play Framework Introduction
Β 
Follow these reasons to know java’s importance
Follow these reasons to know java’s importanceFollow these reasons to know java’s importance
Follow these reasons to know java’s importance
Β 
NodeJS
NodeJSNodeJS
NodeJS
Β 
An Overview of Node.js
An Overview of Node.jsAn Overview of Node.js
An Overview of Node.js
Β 
Introduction to node.js
Introduction to node.jsIntroduction to node.js
Introduction to node.js
Β 
Programming Server side with Sevlet
 Programming Server side with Sevlet  Programming Server side with Sevlet
Programming Server side with Sevlet
Β 

More from Yevgeniy Brikman

Cloud adoption fails - 5 ways deployments go wrong and 5 solutions
Cloud adoption fails - 5 ways deployments go wrong and 5 solutionsCloud adoption fails - 5 ways deployments go wrong and 5 solutions
Cloud adoption fails - 5 ways deployments go wrong and 5 solutionsYevgeniy Brikman
Β 
How to test infrastructure code: automated testing for Terraform, Kubernetes,...
How to test infrastructure code: automated testing for Terraform, Kubernetes,...How to test infrastructure code: automated testing for Terraform, Kubernetes,...
How to test infrastructure code: automated testing for Terraform, Kubernetes,...Yevgeniy Brikman
Β 
Lessons learned from writing over 300,000 lines of infrastructure code
Lessons learned from writing over 300,000 lines of infrastructure codeLessons learned from writing over 300,000 lines of infrastructure code
Lessons learned from writing over 300,000 lines of infrastructure codeYevgeniy Brikman
Β 
Gruntwork Executive Summary
Gruntwork Executive SummaryGruntwork Executive Summary
Gruntwork Executive SummaryYevgeniy Brikman
Β 
Reusable, composable, battle-tested Terraform modules
Reusable, composable, battle-tested Terraform modulesReusable, composable, battle-tested Terraform modules
Reusable, composable, battle-tested Terraform modulesYevgeniy Brikman
Β 
The Truth About Startups: What I wish someone had told me about entrepreneurs...
The Truth About Startups: What I wish someone had told me about entrepreneurs...The Truth About Startups: What I wish someone had told me about entrepreneurs...
The Truth About Startups: What I wish someone had told me about entrepreneurs...Yevgeniy Brikman
Β 
An intro to Docker, Terraform, and Amazon ECS
An intro to Docker, Terraform, and Amazon ECSAn intro to Docker, Terraform, and Amazon ECS
An intro to Docker, Terraform, and Amazon ECSYevgeniy Brikman
Β 
Comprehensive Terraform Training
Comprehensive Terraform TrainingComprehensive Terraform Training
Comprehensive Terraform TrainingYevgeniy Brikman
Β 
Infrastructure as code: running microservices on AWS using Docker, Terraform,...
Infrastructure as code: running microservices on AWS using Docker, Terraform,...Infrastructure as code: running microservices on AWS using Docker, Terraform,...
Infrastructure as code: running microservices on AWS using Docker, Terraform,...Yevgeniy Brikman
Β 
Agility Requires Safety
Agility Requires SafetyAgility Requires Safety
Agility Requires SafetyYevgeniy Brikman
Β 
Startup Ideas and Validation
Startup Ideas and ValidationStartup Ideas and Validation
Startup Ideas and ValidationYevgeniy Brikman
Β 
A Guide to Hiring for your Startup
A Guide to Hiring for your StartupA Guide to Hiring for your Startup
A Guide to Hiring for your StartupYevgeniy Brikman
Β 
Startup DNA: Speed Wins
Startup DNA: Speed WinsStartup DNA: Speed Wins
Startup DNA: Speed WinsYevgeniy Brikman
Β 
Node.js vs Play Framework (with Japanese subtitles)
Node.js vs Play Framework (with Japanese subtitles)Node.js vs Play Framework (with Japanese subtitles)
Node.js vs Play Framework (with Japanese subtitles)Yevgeniy Brikman
Β 
Node.js vs Play Framework
Node.js vs Play FrameworkNode.js vs Play Framework
Node.js vs Play FrameworkYevgeniy Brikman
Β 
Composable and streamable Play apps
Composable and streamable Play appsComposable and streamable Play apps
Composable and streamable Play appsYevgeniy Brikman
Β 
Kings of Code Hack Battle
Kings of Code Hack BattleKings of Code Hack Battle
Kings of Code Hack BattleYevgeniy Brikman
Β 
Hackdays and [in]cubator
Hackdays and [in]cubatorHackdays and [in]cubator
Hackdays and [in]cubatorYevgeniy Brikman
Β 
Startup DNA: the formula behind successful startups in Silicon Valley (update...
Startup DNA: the formula behind successful startups in Silicon Valley (update...Startup DNA: the formula behind successful startups in Silicon Valley (update...
Startup DNA: the formula behind successful startups in Silicon Valley (update...Yevgeniy Brikman
Β 

More from Yevgeniy Brikman (20)

Cloud adoption fails - 5 ways deployments go wrong and 5 solutions
Cloud adoption fails - 5 ways deployments go wrong and 5 solutionsCloud adoption fails - 5 ways deployments go wrong and 5 solutions
Cloud adoption fails - 5 ways deployments go wrong and 5 solutions
Β 
How to test infrastructure code: automated testing for Terraform, Kubernetes,...
How to test infrastructure code: automated testing for Terraform, Kubernetes,...How to test infrastructure code: automated testing for Terraform, Kubernetes,...
How to test infrastructure code: automated testing for Terraform, Kubernetes,...
Β 
Lessons learned from writing over 300,000 lines of infrastructure code
Lessons learned from writing over 300,000 lines of infrastructure codeLessons learned from writing over 300,000 lines of infrastructure code
Lessons learned from writing over 300,000 lines of infrastructure code
Β 
Gruntwork Executive Summary
Gruntwork Executive SummaryGruntwork Executive Summary
Gruntwork Executive Summary
Β 
Reusable, composable, battle-tested Terraform modules
Reusable, composable, battle-tested Terraform modulesReusable, composable, battle-tested Terraform modules
Reusable, composable, battle-tested Terraform modules
Β 
The Truth About Startups: What I wish someone had told me about entrepreneurs...
The Truth About Startups: What I wish someone had told me about entrepreneurs...The Truth About Startups: What I wish someone had told me about entrepreneurs...
The Truth About Startups: What I wish someone had told me about entrepreneurs...
Β 
An intro to Docker, Terraform, and Amazon ECS
An intro to Docker, Terraform, and Amazon ECSAn intro to Docker, Terraform, and Amazon ECS
An intro to Docker, Terraform, and Amazon ECS
Β 
Comprehensive Terraform Training
Comprehensive Terraform TrainingComprehensive Terraform Training
Comprehensive Terraform Training
Β 
Infrastructure as code: running microservices on AWS using Docker, Terraform,...
Infrastructure as code: running microservices on AWS using Docker, Terraform,...Infrastructure as code: running microservices on AWS using Docker, Terraform,...
Infrastructure as code: running microservices on AWS using Docker, Terraform,...
Β 
Agility Requires Safety
Agility Requires SafetyAgility Requires Safety
Agility Requires Safety
Β 
Startup Ideas and Validation
Startup Ideas and ValidationStartup Ideas and Validation
Startup Ideas and Validation
Β 
A Guide to Hiring for your Startup
A Guide to Hiring for your StartupA Guide to Hiring for your Startup
A Guide to Hiring for your Startup
Β 
Startup DNA: Speed Wins
Startup DNA: Speed WinsStartup DNA: Speed Wins
Startup DNA: Speed Wins
Β 
Node.js vs Play Framework (with Japanese subtitles)
Node.js vs Play Framework (with Japanese subtitles)Node.js vs Play Framework (with Japanese subtitles)
Node.js vs Play Framework (with Japanese subtitles)
Β 
Node.js vs Play Framework
Node.js vs Play FrameworkNode.js vs Play Framework
Node.js vs Play Framework
Β 
Rapid prototyping
Rapid prototypingRapid prototyping
Rapid prototyping
Β 
Composable and streamable Play apps
Composable and streamable Play appsComposable and streamable Play apps
Composable and streamable Play apps
Β 
Kings of Code Hack Battle
Kings of Code Hack BattleKings of Code Hack Battle
Kings of Code Hack Battle
Β 
Hackdays and [in]cubator
Hackdays and [in]cubatorHackdays and [in]cubator
Hackdays and [in]cubator
Β 
Startup DNA: the formula behind successful startups in Silicon Valley (update...
Startup DNA: the formula behind successful startups in Silicon Valley (update...Startup DNA: the formula behind successful startups in Silicon Valley (update...
Startup DNA: the formula behind successful startups in Silicon Valley (update...
Β 

Recently uploaded

Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel AraΓΊjo
Β 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonetsnaman860154
Β 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...gurkirankumar98700
Β 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonAnna Loughnan Colquhoun
Β 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)Gabriella Davis
Β 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationRadu Cotescu
Β 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
Β 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationSafe Software
Β 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024The Digital Insurer
Β 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
Β 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘RTylerCroy
Β 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsRoshan Dwivedi
Β 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreternaman860154
Β 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking MenDelhi Call girls
Β 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
Β 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
Β 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024Results
Β 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilV3cube
Β 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc
Β 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking MenDelhi Call girls
Β 

Recently uploaded (20)

Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Β 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
Β 
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Kalyanpur ) Call Girls in Lucknow Finest Escorts Service 🍸 8923113531 🎰 Avail...
Β 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
Β 
A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)A Domino Admins Adventures (Engage 2024)
A Domino Admins Adventures (Engage 2024)
Β 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
Β 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
Β 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
Β 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
Β 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
Β 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘
Β 
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live StreamsTop 5 Benefits OF Using Muvi Live Paywall For Live Streams
Top 5 Benefits OF Using Muvi Live Paywall For Live Streams
Β 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
Β 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
Β 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Β 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
Β 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
Β 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of Brazil
Β 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
Β 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
Β 

The Play Framework at LinkedIn