* [ANN] yahns 1.10.0 -_- sleepy app server for Ruby
[not found] <20151101-yahns-1.10.0-rele@sed>
@ 2015-11-01 9:25 4% ` Eric Wong
0 siblings, 0 replies; 4+ results
From: Eric Wong @ 2015-11-01 9:25 UTC (permalink / raw)
To: ruby-talk, yahns-public
A Free Software, multi-threaded, non-blocking network application server
designed for low _idle_ power consumption. It is primarily optimized
for applications with occasional users which see little or no traffic.
yahns currently hosts Rack/HTTP applications, but may eventually support
other application types. Unlike some existing servers, yahns is
extremely sensitive to fatal bugs in the applications it hosts.
minor updates
This release improves socket inheritance support. TCP socket
options are now applied to inherited sockets. We also emulate
the sd_listen_fds function to allow inheriting sockets from
systemd.
HTTP status strings are now generated dynamically, allowing
applications to modify Rack::Utils::HTTP_STATUS_CODES to
apply changes in the Rack response. Unfortunately, this leads
to minor (likely unnoticeable) performance regressions.
However, our code is not optimized for Ruby 2.2+, so users on
the latest released Ruby will benefit from reduced inline cache
and constant lookups as we reduced our constant footprint.
Expect further minor performance regressions if you are running
Ruby 2.2 and earlier.
For Ruby 2.2 users, overall performance should be largely
unchanged from 1.7.0 to 1.8.0
shortlog of changes since 1.7.0:
* use opt_str_freeze for Hash#delete
* test/helper: warn atomically
* generate response status strings dynamically
* reduce constants and optimize for Ruby 2.2+
* http_response: reduce bytecode size
* apply TCP socket options on inherited sockets
* test/test_rack_hijack.rb: try to increase test reliability
* emulate sd_listen_fds for systemd support
* test/test_rack_hijack: ensure proper ordering of log messages
Since I'm also the BDFL of unicorn, questions comparing the two may be
inevitable. In short, they are complete opposites in implementation.
More will be posted in the following thread, but for now there's an
incomplete overview:
http://yhbt.net/yahns-public/20151101092053.GA5328@dcvr.yhbt.net/t/
Please note the disclaimer:
yahns is extremely sensitive to fatal bugs in the apps it hosts. There
is no (and never will be) any built-in "watchdog"-type feature to kill
stuck processes/threads. Each yahns process may be handling thousands
of clients; unexpectedly killing the process will abort _all_ of those
connections. Lives may be lost!
yahns hackers are not responsible for your application/library bugs.
Use an application server which is tolerant of buggy applications
if you cannot be bothered to fix all your fatal bugs.
* git clone git://yhbt.net/yahns
* http://yahns.yhbt.net/README
* http://yahns.yhbt.net/NEWS.atom.xml
* we only accept plain-text email yahns-public@yhbt.net
* and archive all the mail we receive: http://yhbt.net/yahns-public/
* nntp://news.public-inbox.org/inbox.comp.lang.ruby.yahns
--
EW
^ permalink raw reply [relevance 4%]
* [ANN] yahns 1.9.0 -_- sleepy app server for Ruby
@ 2015-07-21 20:39 4% Eric Wong
0 siblings, 0 replies; 4+ results
From: Eric Wong @ 2015-07-21 20:39 UTC (permalink / raw)
To: ruby-talk, yahns-public
A Free Software, multi-threaded, non-blocking network application server
designed for low _idle_ power consumption. It is primarily optimized
for applications with occasional users which see little or no traffic.
yahns currently hosts Rack/HTTP applications, but may eventually support
other application types. Unlike some existing servers, yahns is
extremely sensitive to fatal bugs in the applications it hosts.
minor updates
This release improves socket inheritance support. TCP socket
options are now applied to inherited sockets. We also emulate
the sd_listen_fds function to allow inheriting sockets from
systemd.
HTTP status strings are now generated dynamically, allowing
applications to modify Rack::Utils::HTTP_STATUS_CODES to
apply changes in the Rack response. Unfortunately, this leads
to minor (likely unnoticeable) performance regressions.
However, our code is not optimized for Ruby 2.2+, so users on
the latest released Ruby will benefit from reduced inline cache
and constant lookups as we reduced our constant footprint.
Expect further minor performance regressions if you are running
Ruby 2.2 and earlier.
For Ruby 2.2 users, overall performance should be largely
unchanged from 1.7.0 to 1.8.0
shortlog of changes since 1.7.0:
* use opt_str_freeze for Hash#delete
* test/helper: warn atomically
* generate response status strings dynamically
* reduce constants and optimize for Ruby 2.2+
* http_response: reduce bytecode size
* apply TCP socket options on inherited sockets
* test/test_rack_hijack.rb: try to increase test reliability
* emulate sd_listen_fds for systemd support
* test/test_rack_hijack: ensure proper ordering of log messages
Please note the disclaimer:
yahns is extremely sensitive to fatal bugs in the apps it hosts. There
is no (and never will be) any built-in "watchdog"-type feature to kill
stuck processes/threads. Each yahns process may be handling thousands
of clients; unexpectedly killing the process will abort _all_ of those
connections. Lives may be lost!
yahns hackers are not responsible for your application/library bugs.
Use an application server which is tolerant of buggy applications
if you cannot be bothered to fix all your fatal bugs.
* git clone git://yhbt.net/yahns
* http://yahns.yhbt.net/README
* http://yahns.yhbt.net/NEWS.atom.xml
* we only accept plain-text email yahns-public@yhbt.net
* and archive all the mail we receive: http://yhbt.net/yahns-public/
--
EW
^ permalink raw reply [relevance 4%]
* [PATCH 3/3] http_response: reduce bytecode size
2015-06-30 3:01 6% [PATCH 0/3] favor newer Rubies for performance Eric Wong
@ 2015-06-30 3:01 7% ` Eric Wong
0 siblings, 0 replies; 4+ results
From: Eric Wong @ 2015-06-30 3:01 UTC (permalink / raw)
To: yahns-public; +Cc: e
This saves around 200 bytes on x86-64 and potentially improves
CPU cache performance. This does not reduce inline method
cache overhead as String#<< already has optimized dispatch
support (opt_ltlt in insns.def in Ruby 1.9+)
---
lib/yahns/http_response.rb | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/lib/yahns/http_response.rb b/lib/yahns/http_response.rb
index f50c9a1..19075bb 100644
--- a/lib/yahns/http_response.rb
+++ b/lib/yahns/http_response.rb
@@ -108,12 +108,12 @@ module Yahns::HttpResponse # :nodoc:
end
end
- def kv_str(key, value)
+ def kv_str(buf, key, value)
if value.include?("\n".freeze)
# avoiding blank, key-only cookies with /\n+/
- value.split(/\n+/).map! { |v| "#{key}: #{v}\r\n" }.join
+ value.split(/\n+/).each { |v| buf << "#{key}: #{v}\r\n" }
else
- "#{key}: #{value}\r\n"
+ buf << "#{key}: #{value}\r\n"
end
end
@@ -144,17 +144,17 @@ module Yahns::HttpResponse # :nodoc:
offset = $1.to_i
count = $2.to_i - offset + 1
end
- buf << kv_str(key, value)
+ kv_str(buf, key, value)
when %r{\AConnection\z}i
# allow Rack apps to tell us they want to drop the client
alive = false if value =~ /\bclose\b/i
when %r{\AContent-Length\z}i
flags |= MSG_MORE if have_more?(value)
- buf << kv_str(key, value)
+ kv_str(buf, key, value)
when "rack.hijack"
hijack = value
else
- buf << kv_str(key, value)
+ kv_str(buf, key, value)
end
end
buf << (alive ? "Connection: keep-alive\r\n\r\n".freeze
--
EW
^ permalink raw reply related [relevance 7%]
* [PATCH 0/3] favor newer Rubies for performance
@ 2015-06-30 3:01 6% Eric Wong
2015-06-30 3:01 7% ` [PATCH 3/3] http_response: reduce bytecode size Eric Wong
0 siblings, 1 reply; 4+ results
From: Eric Wong @ 2015-06-30 3:01 UTC (permalink / raw)
To: yahns-public; +Cc: e
* [PATCH 1/3] generate response status strings dynamically
This unfortunately introduces a minor performance regression.
However, it is unlikely to be noticeable in real-world apps.
* [PATCH 2/3] reduce constants and optimize for Ruby 2.2+
This appears to recover the performance lost in 1/3 when doing
informal benchmarks on a private app (persistent connections
enabled).
* [PATCH 3/3] http_response: reduce bytecode size
This generates less bytecode when checking with
RubyVM::InstructionSequence.compile
lib/yahns/http_client.rb | 16 +++++-----------
lib/yahns/http_response.rb | 35 ++++++++++++++++-------------------
lib/yahns/max_body.rb | 12 ++++--------
lib/yahns/proxy_http_response.rb | 16 +++++++++-------
4 files changed, 34 insertions(+), 45 deletions(-)
^ permalink raw reply [relevance 6%]
Results 1-4 of 4 | reverse | options above
-- pct% links below jump to the message on this page, permalinks otherwise --
2015-06-30 3:01 6% [PATCH 0/3] favor newer Rubies for performance Eric Wong
2015-06-30 3:01 7% ` [PATCH 3/3] http_response: reduce bytecode size Eric Wong
2015-07-21 20:39 4% [ANN] yahns 1.9.0 -_- sleepy app server for Ruby Eric Wong
[not found] <20151101-yahns-1.10.0-rele@sed>
2015-11-01 9:25 4% ` [ANN] yahns 1.10.0 " Eric Wong
Code repositories for project(s) associated with this public inbox
https://yhbt.net/yahns.git/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).