Skip to content

Application platform powers Loadbalancer, Microservices and API Gateways

License

Notifications You must be signed in to change notification settings

angular-rust/borderland

Borderland

Build Status License

This project was started from ugly fun example. But this project is not a simple HTTP load balncer. We dont need it. We need to balance our application payload. So let we use somthing like a application bus to communicate with application logic.

Also there standard practice to use external crates(modules,libraries). But lot of them suffer from overprogramming, not clear implementation of specifications and unnecessary extra functionality. So i liked the starter point of project and i would like to use less external code in that project. Because "less code" is mean less errors and faster executon, which is main goal.

Borderland logo

Full Documentation

See the Borderland Project Wiki for full documentation, examples, and operational details.

You may be looking for:

How to run?

Make sure you have cargo installed and run the command cargo run to boot up the server.

Visit locahost:8080 from your browser.

What can it do now?

  1. Say hello world - visit localhost:8888/api/v1

  2. Serve static files - visit localhost:8888/files/index.html - this will serve the index.html file from the www folder in the repo root. Place any other file inside www and they can be served similarly (using the /files prefix - this will be configurable by the user in future, just like in Apache and Nginx).

Roadmap

  • HTTP Scheme redirect to HTTPS by design
  • Moved to MIO
  • Routing
  • Session handling
  • Datastorage
  • Application Bus
  • Internal application logic

Changelog

  • Started profiling coz move to use MIO doesnt give good results
  • HTTP to HTTPS redirect by design
  • HTTPS part and threading
  • Moved to MIO event based handling
  • Detection plain HTTP by magic (similar as unix file command)
  • Headers dump
  • Small fixes to proper static content handling

Benchmark

$ab -n 5000 -kc 500 http://127.0.0.1:8000/

...

Requests per second:    14109.94 [#/sec] (mean)
Time per request:       35.436 [ms] (mean)
Time per request:       0.071 [ms] (mean, across all concurrent requests)

It's sad (((

Legal

License

This work is licensed under the MIT license. See LICENSE for details.