This document discusses using WebSockets in Unity games and describes how to implement a finite state machine to handle asynchronous WebSocket events on the main thread. It begins with an overview of WebSockets and their advantages over polling. It then demonstrates how to connect to a WebSocket server and handle events like connection, receiving messages, and disconnection using the WebSocket Sharp library. To address Unity's single-threaded model, it presents a finite state machine pattern that queues asynchronous WebSocket events to be processed on the main thread. Sample code is provided to illustrate setting up and transitioning between states to safely coordinate the WebSocket connection and events.
- The document discusses Neutron L3 HA (VRRP) and summarizes a presentation given on the topic.
- Neutron L3 HA uses the VRRP protocol to provide redundancy and failover for virtual routers across multiple network nodes. A heartbeat network is created for each tenant using their tenant network.
- When a router is created, a heartbeat port and interface are created on each L3 agent node using the tenant's heartbeat network to enable communication between the agents for the VRRP implementation.
Prometheus monitoring from outside of Kubernetes? ?と?うして厘?はKubernetes貧のPromet...whywaita
?
talked by Prometheus Tokyo Meetup #2 https://prometheus.connpass.com/event/127574/
re-upload: https://speakerdeck.com/whywaita/prometheus-monitoring-from-outside-of-kubernetes-kubernetesprometheus-prometheustokyo
The document discusses using WebSockets, Unity3D, and Clojure to build mobile games. It describes how WebSockets enable bidirectional communication between a server and client. It also discusses using Clojure and AWS services like SNS, SQS, and DynamoDB to build a server that can handle real-time events and scale. The server uses HTTP Kit to implement WebSockets and pubsub to distribute messages between clients.
High Performance web apps in Om, React and ClojureScriptLeonardo Borges
?
The document discusses using Om and React for building high performance web user interfaces. It begins with an overview of React, including how it uses virtual DOM and efficient diff algorithms. It then introduces Om as a ClojureScript interface for React that allows leveraging immutable data structures for even faster rendering. A basic counter component is demonstrated in both React JSX and equivalent Om. Larger examples show building reusable editable components and an app with speakers/sessions data and undo functionality using Om.
Prometheus monitoring from outside of Kubernetes? ?と?うして厘?はKubernetes貧のPromet...whywaita
?
talked by Prometheus Tokyo Meetup #2 https://prometheus.connpass.com/event/127574/
re-upload: https://speakerdeck.com/whywaita/prometheus-monitoring-from-outside-of-kubernetes-kubernetesprometheus-prometheustokyo
The document discusses using WebSockets, Unity3D, and Clojure to build mobile games. It describes how WebSockets enable bidirectional communication between a server and client. It also discusses using Clojure and AWS services like SNS, SQS, and DynamoDB to build a server that can handle real-time events and scale. The server uses HTTP Kit to implement WebSockets and pubsub to distribute messages between clients.
High Performance web apps in Om, React and ClojureScriptLeonardo Borges
?
The document discusses using Om and React for building high performance web user interfaces. It begins with an overview of React, including how it uses virtual DOM and efficient diff algorithms. It then introduces Om as a ClojureScript interface for React that allows leveraging immutable data structures for even faster rendering. A basic counter component is demonstrated in both React JSX and equivalent Om. Larger examples show building reusable editable components and an app with speakers/sessions data and undo functionality using Om.
This document discusses Clojure and the architecture used at Nuday Games for their game Rock Science. Key points include:
- Nuday Games uses Clojure for its backend due to benefits like concurrency, small team productivity, and attracting good engineers
- The architecture includes a frontend iOS app, load balancers, HTTP servers running a REST API on Tomcat, and databases
- The REST API is built with Liberator and routes/resources are defined with namespaces, schemas are used for validation
- Events are stored in a DynamoDB table and can be queried to retrieve events by player ID and timestamp
- Mutation commands could be replayed by reading from the event log in
All you need to know about Kinect2 development.
With these slides you can understand the system requirements needed to start developing with Kinect2 sensor, the available sources accessible with the sensor and the gestures you can perform in order to interact with touchless interfaces.
Construindo aplica??es com HTML5, WebSockets, e Java EE 7Bruno Borges
?
A fam┴lia de tecnologias HTML5 avan?ou e foi bem longe, comparado com tecnologias rich client e possibilitou clientes Web com cada vez mais capacidade de execu??o nos navegadores de hoje. Em particular, WebSockets trazem novas oportunidades para a comunica??o eficiente peer-to-peer, fornecendo a base para uma nova gera??o de aplica??es web interativas e "ao vivo". Esta sess?o examina os esfor?os com JSR 356 para apoiar WebSocket no modelo de programa??o Java, a partir de sua integra??o ao n┴vel de base nos recipientes Java Servlet e Java EE para um novo, API f│cil de usar e conjunto de ferramentas que faz parte do padr?o plataforma Java.
WebSocket is a protocol that provides bidirectional communication over a single TCP connection. It uses an HTTP handshake to establish a connection and then transmits messages as frames that can contain text or binary data. The frames include a header with metadata like opcode and payload length. WebSocket aims to provide a standard for browser-based applications that require real-time data updates from a server.
Space Ape's Live Ops Stack: Engineering Mobile Games for Live Ops from Day 1Simon Hade
?
To view the accompanying video see http://links.spaceapegames.com/liveops
Around half of the $80m revenue generated by Space Ape¨s three mid-core build and battle games is attributable to in game events. By adopting a flexible forward looking approach to tools development Space Ape efficiently operates their games with very small non-technical teams maintaining major weekly content update cycles.
In this talk, Space Ape¨s senior Live Ops specialists give a demo of their tools and workflows and share the content strategies that have allowed them to grow revenues whilst enabling the studio to focus the majority of its development capacity on creating new games and IP.
DESIGNING SUCCESSFUL LIVE OPS SYSTEMS IN FREE TO PLAY GACHA ECONOMIES
Space Ape shipped Transformers:Earth Wars in the Summer pre-baked with the community events tools that had worked so well in their previous game, Rival Kingdoms. However, they soon realised that many of the old tricks did not apply to the game¨s gacha collection economy which had more in common with Kabam¨s Contest of Champions than the linear economies of most Build and Battle games. In this talk Space Ape¨s Live Ops Lead Andrew Munden (formerly Live Ops Lead at Kabam) will share the content strategies that work in gacha collection games as well as how to build a manageable content furnace and balance player fatigue in a sustainable way.
A BRIEF HISTORY OF IN-GAME TARGETING.
Analytics lead Fred Easy (ex Betfair, Playfish/EA) will share the evolution of his offer targeting technology from it¨s belt and braces beginnings to sophisticated value based targeting and the transition to a dynamic in-session machine learning approach.
UNDER THE HOOD: RIVAL KINGDOM'S CMS TOOLS
Game changing content is introduced to Rival Kingdoms every month, with in game events at least every week. Product Manager Mitchell Smallman (formerly Rovio, Next Games) and Steven Hsiao (competitive StarCraft player turned community manager turned Live Ops lead) will demonstrate the content management tools that allow them to keep the game fresh for players without developer support. This will include the tools for configuring competitive events, inserting new content into the game as well as how they measure performance of the changes and optimise on the fly. Learn how these tools enabled them to grow revenue for 6 consecutive months with no marketing spend.
To find out more about the developer go to www.spaceapegames.com
Из презентации вы узнаете:
! как мы пришли к Go, оставив идею использования Node.js, Scala или Rust;
! про первый сервис, который мы написали на Go и запустили в продакшен;
! про ошибки, с которыми сталкивались под нагрузкой;
! про оптимизации, которые мы сделали и еще планируем сделать;
! про тестирование и предотвращение тестирования на продакшене (в частности, websocket'ов).
Thrift vs Protocol Buffers vs Avro - Biased ComparisonIgor Anishchenko
?
Igor Anishchenko
Odessa Java TechTalks
Lohika - May, 2012
Let's take a step back and compare data serialization formats, of which there are plenty. What are the key differences between Apache Thrift, Google Protocol Buffers and Apache Avro. Which is "The Best"? Truth of the matter is, they are all very good and each has its own strong points. Hence, the answer is as much of a personal choice, as well as understanding of the historical context for each, and correctly identifying your own, individual requirements.
Victoria's Secret launched its Angels campaign in 1999 to increase sales and brand awareness. Using supermodels as spokespeople, the campaign featured a television fashion show that increased initial sales and catalogue circulation. The brand targeted 18 to 34 year old women by appealing to their desires to feel sexy and beautiful. While the risque content was attention-grabbing, it also faced criticism and the brand risks losing relevance if it does not adapt to changing consumer preferences.
This presentation explains the basics of WebSockets and how a Developer can leverage its features to enhance a Mobile User Experience and offer real timing applications
This document discusses WebSockets and their APIs. It introduces WebSockets as enabling bi-directional, full-duplex communications over TCP, in contrast to traditional HTTP interactions which are half-duplex. It then covers the WebSocket handshake process, APIs for WebSocket in JavaScript and Java, and how to create and use WebSocket endpoints programmatically and using annotations in Java.
The document discusses Websockets and compares them to HTTP. It provides an overview of Websockets including how they work, specifications, and examples of using Websockets in JavaScript, Android Java, and Java server-side code with the jquery-websocket library. Benefits highlighted include full-duplex communication, lower overhead than HTTP, and lower latency.
This presentation aggregates common approaches of real-time client-server communications provided by Web Standards. It focuses on comparison of different techniques like polling, comet, Web Sockets, Server-Sent Events.
Node.js is an asynchronous event-driven JavaScript runtime that allows JavaScript to be used on the server-side. It uses a non-blocking I/O model that makes it suitable for real-time web applications. WebSockets provide a standardized way for the browser and server to establish two-way communication. However, not all browsers support WebSockets yet. Socket.io addresses this by providing a WebSocket-like experience across all browsers through fallbacks like long-polling. It allows real-time applications to be developed more easily.
The time of static or dynamically generated sites is long gone. Non-stop interaction with users is the new normal. However, polling with Ajax requests is processor intensive and cumbersome. Websockets allow you to interact with users in real-time without increasing system load. We'll go through the basics and see all the different options, illustrated with live examples of how and when to use it, as well as when not to use it.
Polling Techniques, Ajax, protocol Switching from Http to Websocket standard ...Srikanth Reddy Pallerla
?
This document discusses WebSockets and how they provide a full-duplex communication channel over a single TCP connection that avoids some of the issues with traditional HTTP requests. WebSockets allow for real-time data transfer from server to client without polling. They utilize an initial HTTP request for handshake that upgrades the connection and then transmits message-based data similar to UDP with reliability of TCP. This reduces resource usage compared to techniques like long polling and streaming.
This document discusses using Netty for building high performance reactive servers. It provides an overview of Netty's features such as non-blocking I/O, channel pipelines, event loops and performance optimizations. Examples are given of building HTTP and TCP servers using Netty. Reasons for choosing Netty include its high performance, low garbage collection overhead, support for various protocols and full control over networking.
Building Next Generation Real-Time Web Applications using WebsocketsNaresh Chintalcheru
?
This document discusses real-time web applications and the technologies needed to enable them. It describes how HTTP is half-duplex and led to hacks like long polling to simulate real-time behavior. The WebSocket protocol provides full-duplex communications by upgrading the HTTP handshake. This allows real-time messaging over a single connection. The document also covers asynchronous programming, event-driven architectures, and frameworks like Spring that support WebSockets and asynchronous APIs.
Carol McDonald gave a presentation on Java concurrency utilities introduced in J2SE 5.0. She discussed motivation for improved concurrency tools, common concurrency issues, and key utilities like Executor framework, locks, synchronizers, and concurrent collections. The utilities make concurrent programming easier and improve performance of multithreaded Java applications.
This is my presentation from TechBeats #3 hosted by Applause about Server-Side Swift framework called Vapor.
Swift is a great language and possibility of using it also in backend is a huge benefit for any iOS developer out there. Using Vapor is a seamless experience. With this framework creating advance APIs by iOS developer is as easy as writing simple iOS app.
https://www.meetup.com/TechBeats-hosted-by-Applause/events/254910023/
Building Websocket Applications with GlassFish and GrizzlyJustin Lee
?
Learn what websockets are and how you can build websocket based applications using the GlassFish application server or embed them in your own applications using Grizzly.
The time of static or dynamically generated sites is long gone. Non-stop interaction with users is the new normal. However, polling with Ajax requests is processor intensive and cumbersome. Websockets allow you to interact with users in real-time without increasing system load. We'll go through the basics and see all the different options, illustrated with live examples of how and when to use it.
WebSockets allow for bidirectional communication over a single socket connection. Once a WebSocket connection is established between a web browser and web server, data can be transmitted both ways using send() and onmessage event handlers. The WebSocket API creates a WebSocket object that has attributes like readyState to check connection status and methods like send() to transmit data and close() to terminate the connection. A WebSocket server like mod_pywebsocket for Apache must be installed and run to test WebSocket functionality between client and server code.
The document discusses how WebSocket provides full-duplex and bi-directional communication over a single TCP connection, addressing limitations of HTTP such as being half-duplex and requiring a new connection per request. It explains how WebSocket works by upgrading the initial HTTP connection to a WebSocket connection through a handshake process. It also describes how the Java API supports WebSocket through annotations and callback methods to handle messages, connections and errors for server and client endpoints.
Explaining the benefits of using WebSockets, the difference comparing with Ajax and explaining the code we should write on both ends. The server and the client.
More information about the Java course I deliver can be found at java.course.lifemichael.com
More information about the Node.js course I deliver can be found at nodejs.course.lifemichael.com
More information about the FED course I deliver can be found at fed.course.lifemichael.com
WebSockets Everywhere: the Future Transport Protocol for Everything (Almost)Ericom Software
?
WebSockets couples the performance and flexibility of TCP with the reach of HTTP Prediction: WebSockets will replace simple TCP as preferred underlying protocol.
To see how Websockets are used in a popular HTML5-based remote access solution, by visiting the following URL: http://j.mp/1luquBQ
3. What¨s a WebSocket?
¢ Bidirectional TCP connection
¢ Initiated from an HTTP connection by
sending Upgrade header
GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw==
Sec-WebSocket-Protocol: chat, superchat
Sec-WebSocket-Version: 13
Origin: http://example.com
HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: HSmrc0sMlYU=
Sec-WebSocket-Protocol: chat
4. Why WebSockets?
¢ Server can push messages instead of being
polled
¢ Polling often leads to large percentage of
request load being worthless
¢ Client disconnection can be part of API
5. Why not WebSockets?
¢ Servers can¨t be purely stateless
¢ How does a client on server A interact with a
client on server B?
¢ What happens when a server crashes?
¢ What if a client has a spotty network
connection?
6. Mix and match
¢ Use WebSockets where remote push is a
killer app
¢ Use plain old REST for everything else
¢ Gracefully degrade from WebSockets to
REST when network connectivity is poor
¢ HTTP Kit is a perfect fit!
7. ¢ Open source C# WebSockets client
https://github.com/sta/websocket-sharp/
¢ Available on the Unity Asset Store
https://www.assetstore.unity3d.com/en/#!/content/8959
¢ With Unity 5, drop in your Assets folder and
compile away (full .NET 2.0 API only)
8. Connecting
using WebSocketSharp;
var ws = new WebSocket("ws://echo.websocket.org");
// We'll get to this
ws.OnOpen += OnOpenHandler;
ws.OnMessage += OnMessageHandler;
ws.OnClose += OnCloseHandler;
ws.OnError += OnErrorHandler;
ws.ConnectAsync();
9. private void OnOpenHandler(object sender, System.EventArgs e) {
Debug.Log("WebSocket connected!");
// Here is where you do useful stuff
}
How do I know when I¨m connected?
10. private void OnSendComplete(bool success) {
Debug.Log("Message sent successfully? " + success);
}
ws.SendAsync("This WebSockets stuff is a breeze!", OnSendComplete);
Sending a message
15. Unity threading model
¢ Single-threaded with coroutines
¢ API generally not thread-safe
¢ Anything that updates the screen must
happen on the main thread
16. websocket-sharp threading model
¢ .NET threads
¢ Anything done asynchronously happens on
a background thread
¢ Event handlers (OnOpen, OnMessage, etc.)
are invoked on background threads
17. And never the twain shall meet?
¢ This would be a (more) boring talk
¢ Enter our old Computer Science buddy, the
Finite State Machine
18. A simple state machine
using UnityEngine;
public enum State { NotRunning, Running, Connected, Ping, Pong, Done }
public delegate void Handler();
public class StateMachine : MonoBehaviour {
public void Run() { ´ }
public void Transition(State state) { ´ }
public void AddHandler(State state, Handler handler) { ´ }
public void Update() { ´ }
}
19. using System.Collections.Generic;
public class StateMachine : MonoBehaviour {
private readonly object syncLock = new object();
private readonly Queue<State> pending = new Queue<State>();
public void Transition(State state) {
lock(syncLock) {
pending.Enqueue(state);
}
}
}
Requesting transitions
20. public class StateMachine : MonoBehaviour {
private readonly Dictionary<State, Handler> handlers
= new Dictionary<State, Handler>();
public void AddHandler(State state, Handler handler) {
handlers.Add(state, handler);
}
}
Transition handlers
21. Handling transitions
public class StateMachine : MonoBehaviour {
public void Update() {
while (pending.Count > 0) {
currentState = pending.Dequeue();
Handler handler;
if (handlers.TryGetValue(currentState, out handler)) {
handler();
}
}
}
}
22. Start me up!
public class StateMachine : MonoBehaviour {
private State currentState = State.NotRunning;
public void Run() {
Transition(State.Running);
}
}
23. Putting it all together (1)
using UnityEngine;
using WebSocketSharp;
public class StatefulMain : MonoBehaviour {
public StateMachine stateMachine;
private WebSocket ws;
void Start() {
ws = new WebSocket("ws://echo.websocket.org");
ws.OnOpen += OnOpenHandler;
ws.OnMessage += OnMessageHandler;
ws.OnClose += OnCloseHandler;
24. Putting it all together (2)
stateMachine.AddHandler(State.Running, () => {
ws.ConnectAsync();
});
stateMachine.AddHandler(State.Connected, () => {
stateMachine.Transition(State.Ping);
});
stateMachine.AddHandler(State.Ping, () => {
ws.SendAsync("This WebSockets stuff is a breeze!",
OnSendComplete);
});
stateMachine.AddHandler(State.Pong, () => {
ws.CloseAsync();
});
25. private void OnOpenHandler(object sender, System.EventArgs e) {
Debug.Log("WebSocket connected!");
stateMachine.Transition(State.Connected);
}
private void OnMessageHandler(object sender, MessageEventArgs e) {
Debug.Log("WebSocket server said: " + e.Data);
stateMachine.Transition(State.Pong);
}
private void OnCloseHandler(object sender, CloseEventArgs e) {
Debug.Log("WebSocket closed with reason: " + e.Reason);
stateMachine.Transition(State.Done);
}
Putting it all together (3)
26. Putting it all together (4)
void Start() {
// WebSocket init code from previous slides
// State machine handlers from previous slides
stateMachine.Run();
}