diff --git a/404.html b/404.html index 6c48becb..c2095cb1 100644 --- a/404.html +++ b/404.html @@ -7,7 +7,7 @@ - + @@ -32,11 +32,11 @@ - + - + - +
diff --git a/acknowledgments/index.html b/acknowledgments/index.html index ed640a4a..566c6b62 100644 --- a/acknowledgments/index.html +++ b/acknowledgments/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/authorbio/index.html b/authorbio/index.html index a7b64677..e23f93d4 100644 --- a/authorbio/index.html +++ b/authorbio/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/chapter01/index.html b/chapter01/index.html index a543d374..3a894e07 100644 --- a/chapter01/index.html +++ b/chapter01/index.html @@ -7,7 +7,7 @@ - + @@ -37,11 +37,11 @@ - + - + - +
diff --git a/chapter02/index.html b/chapter02/index.html index abfcfe99..09ae9305 100644 --- a/chapter02/index.html +++ b/chapter02/index.html @@ -7,7 +7,7 @@ - + @@ -37,11 +37,11 @@ - + - + - + diff --git a/chapter03/index.html b/chapter03/index.html index 1d919216..2a3c973d 100644 --- a/chapter03/index.html +++ b/chapter03/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter04/index.html b/chapter04/index.html index 2ff5cc92..bd4d7a8f 100644 --- a/chapter04/index.html +++ b/chapter04/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter05/index.html b/chapter05/index.html index e3af8f07..8cd5859f 100644 --- a/chapter05/index.html +++ b/chapter05/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter06/index.html b/chapter06/index.html index 436b5044..ce00741a 100644 --- a/chapter06/index.html +++ b/chapter06/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter07/index.html b/chapter07/index.html index e40fd118..872da9c0 100644 --- a/chapter07/index.html +++ b/chapter07/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter08/index.html b/chapter08/index.html index 7cd8e506..a4afbed6 100644 --- a/chapter08/index.html +++ b/chapter08/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter09/index.html b/chapter09/index.html index f84e2b25..c588eb38 100644 --- a/chapter09/index.html +++ b/chapter09/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter10/index.html b/chapter10/index.html index f5c9edc0..a7e6f54b 100644 --- a/chapter10/index.html +++ b/chapter10/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter11/index.html b/chapter11/index.html index 21683045..dafbeef5 100644 --- a/chapter11/index.html +++ b/chapter11/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter12/index.html b/chapter12/index.html index d1bea87f..2e32b010 100644 --- a/chapter12/index.html +++ b/chapter12/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
@@ -269,16 +269,6 @@

The Internet of Things (IoT) is revolutionizing how we interact with the world, and you, as developers and engineers, are at the forefront of this revolution. You're connecting everything from smart home devices to industrial machinery in seamless, data-driven networks. MQTT (Message Queuing Telemetry Transport) is at the heart of many IoT systems, a lightweight messaging protocol designed for efficient, real-time communication between devices with limited bandwidth or power. Whether it’s a temperature sensor publishing data to a dashboard or a remote command turning on a smart light, MQTT is the backbone of these interactions, offering a robust yet simple mechanism for exchanging information.

In this chapter, we’ll dive into the specifics of using MQTT in .NET to build IoT applications that are reliable, scalable, and secure. We’ll explore MQTT’s publish/subscribe model, its key components like brokers and topics, and advanced features such as Quality of Service (QoS) levels and retained messages. With practical examples and code demonstrations that you can follow along with, you’ll learn how to set up an MQTT broker, implement clients for IoT devices, and optimize communication for real-world scenarios.

As we progress, we’ll also address critical considerations like securing MQTT connections with TLS, handling authentication and authorization, and testing your application to ensure it performs well under various conditions. These conditions could include intermittent network connectivity, high message volumes, or diverse device types. By the end of this chapter, you’ll have the tools and knowledge to confidently use MQTT in your IoT solutions, bridging the gap between connected devices and actionable insights in your .NET applications.

- -

- # - Introduction to MQTT and IoT Protocols -

-
-

In the world of IoT, where devices often operate in constrained environments with limited bandwidth and intermittent connectivity, choosing the proper communication protocol is critical. Enter MQTT, a protocol designed to make communication between devices as lightweight and efficient as possible. MQTT, with its simplicity, is the champion of IoT messaging, excelling in scenarios where reliability is paramount, whether monitoring sensors in an intelligent farm or managing commands for industrial machinery.

-

At its core, MQTT uses a publish/subscribe model, fundamentally different from traditional HTTP's request/response paradigm. This model allows devices to publish messages on specific topics without knowing who will consume them, and subscribers can listen to those topics without worrying about who is producing them. This decoupling of publishers and subscribers makes MQTT incredibly flexible and scalable, especially in IoT ecosystems where thousands of devices must communicate seamlessly.

-

While MQTT shines in many IoT scenarios, it's not the only protocol in the toolbox. Protocols like HTTP and CoAP (Constrained Application Protocol) have their strengths, depending on the use case. HTTP is ubiquitous and well-suited for infrequent interactions like fetching configuration data, while CoAP is optimized for constrained devices using RESTful communication over UDP. Compared to these, MQTT stands out for its focus on persistent, low-overhead communication, making it ideal for applications requiring real-time data delivery and low power consumption.

-

In this section, we'll explore what makes MQTT a standout choice for IoT applications and how it compares to other protocols in the field. By the end, you'll understand why MQTT's design and features have earned it a central role in powering the connected devices of today—and tomorrow.

# @@ -291,16 +281,6 @@

Another key advantage of MQTT is its low overhead. Unlike traditional HTTP-based communication, which involves verbose headers and a constant back-and-forth between clients and servers, MQTT messages are compact and efficient. This efficiency reduces power consumption for battery-operated devices and minimizes bandwidth usage, which are essential for IoT deployments in remote or constrained environments.

Beyond its technical features, MQTT's adaptability shines in real-world applications. It's used in diverse domains, from smart cities and connected cars to agricultural systems and energy management. The protocol's support for retained messages (which are stored by the broker and delivered to new subscribers), Last Will and Testament (LWT) notifications (which are pre-defined messages that are sent when a device disconnects unexpectedly), and persistent sessions ensures that IoT systems remain robust, even when devices connect and disconnect intermittently.

As we delve deeper into MQTT in this chapter, you'll see how this protocol empowers IoT systems to function seamlessly and reliably. By understanding its architecture, components, and unique features, you'll gain the foundation to implement MQTT in your .NET applications, bringing the power of connected devices to life in your projects.

- -

- # - Key MQTT Features for IoT Applications -

-
-

MQTT has earned its place as the protocol of choice for many IoT applications, not just because of its lightweight design but also because of the powerful features it offers to meet the unique demands of IoT systems. These features aren’t just technical conveniences—they’re essential tools for ensuring reliability, scalability, and efficiency in networks where devices range from resource-constrained sensors to powerful industrial controllers. Understanding these features is key to harnessing MQTT’s full potential in your .NET applications.

-

One of MQTT’s standout capabilities is its publish/subscribe architecture. This model, centered on a broker, allows devices to communicate without knowing anything about each other, creating a decoupled system that scales effortlessly. Publishers send messages to topics, while subscribers listen to those topics, receiving messages in real-time. This real-time nature of MQTT's communication system ensures the immediacy of the system, making it a natural fit for IoT.

-

Another game-changing feature is the protocol’s support for QoS levels. With three levels, MQTT gives you unprecedented control over how messages are delivered. Whether you need best-effort delivery for non-critical telemetry or exact-once guarantees for high-stakes commands, MQTT provides the flexibility to meet the needs of any IoT application. This level of control empowers you, particularly in scenarios where connectivity can be unreliable, such as remote monitoring or mobile networks.

-

Additionally, MQTT includes features like retained messages and LWT notifications that enhance the reliability and robustness of your system. Retained messages ensure that new subscribers immediately receive the latest state of a topic, eliminating the need to wait for the next update. LWT allows devices to announce their disconnection gracefully, providing vital status updates for applications that rely on continuous monitoring. Together, these features make MQTT not just a messaging protocol but a foundation for building resilient IoT ecosystems. As we explore these capabilities, you’ll see how they translate into practical advantages for your .NET-based IoT solutions.

# @@ -311,17 +291,6 @@

HTTP, the backbone of traditional web communication, is often used in IoT due to its ubiquity and familiarity. Its widespread use in the web world reassures its applicability in IoT. It fits straightforward request-response interactions, such as fetching configuration data or posting sensor readings. However, HTTP’s verbose headers and connection overhead can make it a poor choice for real-time or resource-constrained IoT systems. Compared to HTTP, MQTT’s lightweight publish/subscribe model shines, particularly when devices require continuous communication or need to minimize power and bandwidth usage.

CoAP, on the other hand, is tailored for constrained devices and networks, much like MQTT. Built on the RESTful paradigm, CoAP uses UDP instead of TCP, making it faster in some scenarios but less reliable when packet delivery needs guarantees. MQTT’s use of TCP and its support for Quality of Service (QoS) levels give it a significant edge in environments where reliability is critical, such as industrial automation or medical devices.

Then there’s AMQP, a heavyweight protocol designed for enterprise messaging. While AMQP offers advanced features like transactions and message queues, it’s overkill for many IoT applications, particularly those involving simple sensors and actuators. In contrast, MQTT’s lean design focuses on doing one thing exceptionally well: providing reliable, low-overhead communication for devices that must interact seamlessly. This simplicity in design should put you at ease with its implementation. As we delve into this comparison, you’ll see why MQTT’s balance of simplicity, efficiency, and flexibility has made it the backbone of many IoT ecosystems.

- -

- # - Understanding MQTT Architecture and Components -

-
-

To truly unlock MQTT's potential in your IoT applications, it's reassuring to know that its architecture and core components are designed for simplicity. This simplicity isn't accidental; it results from a deliberate design that minimizes overhead while maximizing reliability and scalability. From the broker that orchestrates message flow to the lightweight messages, each piece of the MQTT architecture is crucial in enabling seamless communication across diverse and often resource-constrained devices.

-

At the center of every MQTT deployment is the broker, the unsung hero who manages all the messaging magic. The broker, like a post office, receives messages from publishers and delivers them to the appropriate subscribers. Unlike traditional client-server models, where each connection must be tightly coupled, the broker's publish/subscribe model decouples communication. This makes it incredibly flexible and scalable, capable of handling millions of connections without breaking a sweat.

-

Devices in the MQTT ecosystem have equally important roles as publishers or subscribers—or both. Publishers are the messengers, sending data to topics (essentially named channels), while subscribers listen to those topics to receive updates. A publisher doesn't need to know who the subscribers are or even how many there are. This decoupling allows devices to focus on their specific tasks without worrying about the complexity of managing connections.

-

Another standout feature of MQTT's architecture is its use of topics. These hierarchical paths act like routing instructions, ensuring messages reach the right audience. For instance, a sensor in a smart building might publish temperature data to a topic like building1/floor2/temperature, while a subscriber monitoring that floor's environment would listen to the same topic. Topics make it easy to organize and scale communication across complex IoT deployments.

-

Finally, MQTT's flexibility extends to its advanced features, like QoS levels, retained messages, and the LWT. These capabilities enhance reliability and resilience in the MQTT architecture. QoS levels determine the guarantee of message delivery, retained messages ensure that the last message on a topic is always available, and the LWT provides a way to notify subscribers when a device unexpectedly disconnects. These features ensure that your IoT system remains robust and operational even in the face of unreliable networks or unexpected device failures. As we explore MQTT's architecture in detail, you'll see how its elegant design principles make it a perfect fit for the demanding and diverse needs of IoT applications.

# @@ -468,55 +437,6 @@

Console.WriteLine("Message published to iot/devices/sensor1/status");

With these building blocks, you can create robust MQTT-based communication in your .NET applications. Whether handling incoming data streams from IoT sensors or sending commands to devices, MQTTnet makes it easy to implement reliable and efficient messaging. In the following sections, we’ll dive deeper into advanced features like Quality of Service, security configurations, and optimizing performance for real-world scenarios. The fun is just getting started.

- -

- # - Connecting to the Broker and Basic Testing -

-
-

After setting up your MQTT broker, the next step is connecting your .NET application and running some basic tests to ensure everything works as expected. This process involves establishing a connection, subscribing to a topic, publishing a test message, and verifying that the broker routes messages correctly. It’s a simple yet powerful way to validate your MQTT setup, providing you with the reassurance that your system is functioning as intended before diving into more advanced features.

-

You’ll need to configure your MQTT client to connect to the broker. Using the MQTTnet library is as straightforward as creating a MqttClient instance and setting the appropriate options. This simplicity should put you at ease. Here’s a quick example that connects to a broker running on localhost:

-
-
var factory = new MqttFactory();
-var client = factory.CreateMqttClient();
-
-var options = new MqttClientOptionsBuilder()
-    .WithClientId("TestClient")
-    .WithTcpServer("localhost", 1883) // Replace with your broker's address and port
-    .WithCleanSession()
-    .Build();
-
-await client.ConnectAsync(options);
-Console.WriteLine("Connected to the broker!");
-
-

Once connected, let’s test the subscribe-publish flow. First, subscribe to a test topic and set up an event handler to display incoming messages. This lets you monitor messages published on the topic in real time:

-
-
client.ApplicationMessageReceivedAsync += e =>
-{
-    var topic = e.ApplicationMessage.Topic;
-    var payload = Encoding.UTF8.GetString(e.ApplicationMessage.Payload);
-    Console.WriteLine($"Message received on topic '{topic}': {payload}");
-
-    return Task.CompletedTask;
-};
-
-await client.SubscribeAsync(new MqttTopicFilterBuilder()
-    .WithTopic("test/topic")
-    .Build());
-Console.WriteLine("Subscribed to 'test/topic'");
-
-

Now, publish a test message to the same topic. This simulates a device or application sending data through the broker:

-
-
var message = new MqttApplicationMessageBuilder()
-    .WithTopic("test/topic")
-    .WithPayload("Hello from MQTT!")
-    .WithQualityOfServiceLevel(MqttQualityOfServiceLevel.AtLeastOnce)
-    .Build();
-
-await client.PublishAsync(message);
-Console.WriteLine("Message published to 'test/topic'");
-
-

Run the application, and your published message appears in the console as it’s received via the subscription. This round-trip test confirms that your broker correctly routes messages between publishers and subscribers and that your .NET application is appropriately integrated with MQTT. With this setup working, you can build more complex features like device management, data processing, and real-time dashboards. The possibilities are endless, so let’s keep going.

# diff --git a/chapter13/index.html b/chapter13/index.html index 81e3c9f7..cc10b2e6 100644 --- a/chapter13/index.html +++ b/chapter13/index.html @@ -7,7 +7,7 @@ - + @@ -37,12 +37,12 @@ - + - + - - + +
diff --git a/chapter14/index.html b/chapter14/index.html index e1d7130d..72f7fd73 100644 --- a/chapter14/index.html +++ b/chapter14/index.html @@ -7,7 +7,7 @@ - + @@ -32,11 +32,11 @@ - + - + - +
diff --git a/chapter15/index.html b/chapter15/index.html index 3a954552..25afc7cd 100644 --- a/chapter15/index.html +++ b/chapter15/index.html @@ -7,7 +7,7 @@ - + @@ -32,11 +32,11 @@ - + - + - +
diff --git a/chapter16/index.html b/chapter16/index.html index cc128e08..048c4b6a 100644 --- a/chapter16/index.html +++ b/chapter16/index.html @@ -7,7 +7,7 @@ - + @@ -32,11 +32,11 @@ - + - + - +
diff --git a/chapter17/index.html b/chapter17/index.html index 53070866..ca5a0844 100644 --- a/chapter17/index.html +++ b/chapter17/index.html @@ -7,7 +7,7 @@ - + @@ -32,11 +32,11 @@ - + - + - +
diff --git a/copyright/index.html b/copyright/index.html index d8516fe6..dac0242f 100644 --- a/copyright/index.html +++ b/copyright/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/dedication/index.html b/dedication/index.html index 2885b140..258e48d7 100644 --- a/dedication/index.html +++ b/dedication/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/epigraph/index.html b/epigraph/index.html index 9e3d0962..62dc2a9e 100644 --- a/epigraph/index.html +++ b/epigraph/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/foreward/index.html b/foreward/index.html index 0a42ab22..a6048934 100644 --- a/foreward/index.html +++ b/foreward/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/index.html b/index.html index 57e2eb99..54381772 100644 --- a/index.html +++ b/index.html @@ -7,7 +7,7 @@ - + @@ -37,11 +37,11 @@ - + - + - +
diff --git a/license/index.html b/license/index.html index cd893c96..24a82fa3 100644 --- a/license/index.html +++ b/license/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/preface/index.html b/preface/index.html index 94ad4b4c..0f8acd76 100644 --- a/preface/index.html +++ b/preface/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/resources/js/config.js b/resources/js/config.js index e3c2a793..70404a05 100644 --- a/resources/js/config.js +++ b/resources/js/config.js @@ -1 +1 @@ -var __DOCS_CONFIG__ = {"id":"ixRMuJZp1W5fHf6iM4T6c2402/WdTpcweJ/","key":"CUKqSuZu4ftAZtRZiNdAalGnIKMpARWBp83FZ7ICvB8.YuTM+H0ODpQ2FFhzMToVVMwD+QvlRhG9eINDBKYpx4lbn02BDn6h7LH4bRp/k9YK9TaB3uMfi07qJJzFKxgfbA.8263","base":"/book-network-programming-csharp/","host":"cwoodruff.github.io","version":"1.0.0","useRelativePaths":true,"documentName":"index.html","appendDocumentName":false,"trailingSlash":true,"preloadSearch":false,"cacheBustingToken":"3.6.0.785804130320","cacheBustingStrategy":"query","sidebarFilterPlaceholder":"Filter","toolbarFilterPlaceholder":"Filter","showSidebarFilter":true,"filterNotFoundMsg":"No member names found containing the query \"{query}\"","maxHistoryItems":15,"homeIcon":"","access":[{"value":"public","label":"Public"},{"value":"protected","label":"Protected"}],"toolbarLinks":[{"id":"fields","label":"Fields"},{"id":"properties","label":"Properties"},{"id":"methods","label":"Methods"},{"id":"events","label":"Events"}],"sidebar":[{"n":"/","l":"Beyond Boundaries - Networking Programming with C# 12 and .​NET 8 Book Home"},{"n":"dedication","l":"Dedication","s":""},{"n":"epigraph","l":"Epigraph","s":""},{"n":"acknowledgments","l":"Acknowledgments","s":""},{"n":"foreward","l":"Forward","s":""},{"n":"preface","l":"Preface","s":""},{"n":"translations","l":"Translations","s":""},{"n":"chapter01","l":"Chap 1 - Overview of Network Programming","s":""},{"n":"chapter02","l":"Chap 2 - Fundamentals of Networking Concepts","s":""},{"n":"chapter03","l":"Chap 3 - Introduction to Socket Programming","s":""},{"n":"chapter04","l":"Chap 4 - Asynchronous Programming with Async/Await","s":""},{"n":"chapter05","l":"Chap 5 - Multithreading in Network Applications","s":""},{"n":"chapter06","l":"Chap 6 - Error Handling and Fault Tolerance Strategies","s":""},{"n":"chapter07","l":"Chap 7 - Data Serialization Techniques","s":""},{"n":"chapter08","l":"Chap 8 - Network Performance Optimization","s":""},{"n":"chapter09","l":"Chap 9 - Working with REST AP​Is","s":""},{"n":"chapter10","l":"Chap 10 - Working with Web​Sockets","s":""},{"n":"chapter11","l":"Chap 11 - Working with Web​RTC","s":""},{"n":"updates-corrections","l":"Updates-​Corrections","s":""},{"n":"authorbio","l":"Author Bio","s":""}],"search":{"mode":0,"minChars":2,"maxResults":20,"placeholder":"Search","hotkeys":["/"],"noResultsFoundMsg":"No results","recognizeLanguages":true,"languages":[0],"preload":false},"resources":{"History_Title_Label":"History","History_ClearLink_Label":"Clear","History_NoHistory_Label":"No history items","API_AccessFilter_Label":"Access","API_ParameterSection_Label":"PARAMETERS","API_SignatureSection_Label":"SIGNATURE","API_CopyHint_Label":"Copy","API_CopyNameHint_Label":"Copy name","API_CopyLinkHint_Label":"Copy link","API_CopiedAckHint_Label":"Copied!","API_MoreOverloads_Label":"more","API_MoreDropdownItems_Label":"More","API_OptionalParameter_Label":"optional","API_DefaultParameterValue_Label":"Default value","API_InheritedFilter_Label":"Inherited","Search_Input_Placeholder":"Search","Toc_Contents_Label":"Contents","Toc_RelatedClasses_Label":"Related Classes","History_JustNowTime_Label":"just now","History_AgoTime_Label":"ago","History_YearTime_Label":"y","History_MonthTime_Label":"mo","History_DayTime_Label":"d","History_HourTime_Label":"h","History_MinuteTime_Label":"m","History_SecondTime_Label":"s"}}; +var __DOCS_CONFIG__ = {"id":"+3L00Ansq+U840wYi3xzbqrpop2404dOx9B","key":"ogj+CQGm40rwii1RbZb8aeHIeLbaKC/eZdrsC5OojfE.qJKZ84JQWjMEsWYHI2fnYy/5VkO7Yk5Fq8CHCWZOoQCVXKw9RZwGVSF2BHvbR0e9Qe4ifLagaBTslG9pV2/RnA.8302","base":"/book-network-programming-csharp/","host":"cwoodruff.github.io","version":"1.0.0","useRelativePaths":true,"documentName":"index.html","appendDocumentName":false,"trailingSlash":true,"preloadSearch":false,"cacheBustingToken":"3.6.0.785804693419","cacheBustingStrategy":"query","sidebarFilterPlaceholder":"Filter","toolbarFilterPlaceholder":"Filter","showSidebarFilter":true,"filterNotFoundMsg":"No member names found containing the query \"{query}\"","maxHistoryItems":15,"homeIcon":"","access":[{"value":"public","label":"Public"},{"value":"protected","label":"Protected"}],"toolbarLinks":[{"id":"fields","label":"Fields"},{"id":"properties","label":"Properties"},{"id":"methods","label":"Methods"},{"id":"events","label":"Events"}],"sidebar":[{"n":"/","l":"Beyond Boundaries - Networking Programming with C# 12 and .​NET 8 Book Home"},{"n":"dedication","l":"Dedication","s":""},{"n":"epigraph","l":"Epigraph","s":""},{"n":"acknowledgments","l":"Acknowledgments","s":""},{"n":"foreward","l":"Forward","s":""},{"n":"preface","l":"Preface","s":""},{"n":"translations","l":"Translations","s":""},{"n":"chapter01","l":"Chap 1 - Overview of Network Programming","s":""},{"n":"chapter02","l":"Chap 2 - Fundamentals of Networking Concepts","s":""},{"n":"chapter03","l":"Chap 3 - Introduction to Socket Programming","s":""},{"n":"chapter04","l":"Chap 4 - Asynchronous Programming with Async/Await","s":""},{"n":"chapter05","l":"Chap 5 - Multithreading in Network Applications","s":""},{"n":"chapter06","l":"Chap 6 - Error Handling and Fault Tolerance Strategies","s":""},{"n":"chapter07","l":"Chap 7 - Data Serialization Techniques","s":""},{"n":"chapter08","l":"Chap 8 - Network Performance Optimization","s":""},{"n":"chapter09","l":"Chap 9 - Working with REST AP​Is","s":""},{"n":"chapter10","l":"Chap 10 - Working with Web​Sockets","s":""},{"n":"chapter11","l":"Chap 11 - Working with Web​RTC","s":""},{"n":"updates-corrections","l":"Updates-​Corrections","s":""},{"n":"authorbio","l":"Author Bio","s":""}],"search":{"mode":0,"minChars":2,"maxResults":20,"placeholder":"Search","hotkeys":["/"],"noResultsFoundMsg":"No results","recognizeLanguages":true,"languages":[0],"preload":false},"resources":{"History_Title_Label":"History","History_ClearLink_Label":"Clear","History_NoHistory_Label":"No history items","API_AccessFilter_Label":"Access","API_ParameterSection_Label":"PARAMETERS","API_SignatureSection_Label":"SIGNATURE","API_CopyHint_Label":"Copy","API_CopyNameHint_Label":"Copy name","API_CopyLinkHint_Label":"Copy link","API_CopiedAckHint_Label":"Copied!","API_MoreOverloads_Label":"more","API_MoreDropdownItems_Label":"More","API_OptionalParameter_Label":"optional","API_DefaultParameterValue_Label":"Default value","API_InheritedFilter_Label":"Inherited","Search_Input_Placeholder":"Search","Toc_Contents_Label":"Contents","Toc_RelatedClasses_Label":"Related Classes","History_JustNowTime_Label":"just now","History_AgoTime_Label":"ago","History_YearTime_Label":"y","History_MonthTime_Label":"mo","History_DayTime_Label":"d","History_HourTime_Label":"h","History_MinuteTime_Label":"m","History_SecondTime_Label":"s"}}; diff --git a/sitemap.xml.gz b/sitemap.xml.gz index 6dc11ffe..424f4d5d 100644 Binary files a/sitemap.xml.gz and b/sitemap.xml.gz differ diff --git a/translations/index.html b/translations/index.html index 850e23d9..570a1c45 100644 --- a/translations/index.html +++ b/translations/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +
diff --git a/updates-corrections/index.html b/updates-corrections/index.html index 8cedc14b..c5320c5b 100644 --- a/updates-corrections/index.html +++ b/updates-corrections/index.html @@ -7,7 +7,7 @@ - + @@ -35,11 +35,11 @@ - + - + - +