Skip to content

A more involved example of tokio in a concurrent application

Notifications You must be signed in to change notification settings

Technius/tokio-chatserver-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tokio Chat Server Example

This is a more involved example of using tokio to write a concurrent application. This chat server demonstrates

  • how to handling states in streams and futures
  • how to use data structures that need to be shared between threads (e.g. to keep track of sessions)
  • how to "broadcast" to streams
  • how to shutdown a stream early

the server itself features

  • private messages
  • "commands"

How to try it

First, open a terminal and compile with cargo compile. Then run cargo run. Open two more terminals, and in each one, run netcat localhost 8080.

You can "log in" by typing a name and pressing ENTER. Then you can send messages by entering some string and then hitting ENTER.

It's also possible to send a "private message" to user <name> by typing in /msg <name> <message>.

License

Copyright 2019 Bryan Tan ("Technius")

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

About

A more involved example of tokio in a concurrent application

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages