uSockets
hpy
uSockets | hpy | |
---|---|---|
4 | 20 | |
1,217 | 1,008 | |
1.2% | 0.7% | |
5.3 | 8.2 | |
14 days ago | about 2 months ago | |
C | Python | |
Apache License 2.0 | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
uSockets
- What's wrong with you toxic people?
- How difficult is it to build a TCP/IP stack from scratch in C?
-
socketify.py - Bringing WebSockets, Http/Https High Peformance servers for PyPy3 and Python3
Runtime versions: PyPy3 7.3.9 and Python 3.10.7 Framework versions: gunicorn 20.1.0 + uvicorn 0.19.0, socketify alpha Tested with ./http_load_test 40 127.0.0.1 8000 from uSockets Source code in bench
-
How to simulate multiple web socket connections?
Did you try the `"http_load_test" after running make? https://github.com/uNetworking/uSockets/blob/master/examples/http_load_test.c
hpy
-
RustPython
There is a merge request up to add autogen rust bindings to hpy
https://github.com/hpyproject/hpy/pull/457
-
Ruby 3.2’s YJIT is Production-Ready
Are you referencing https://github.com/hpyproject/hpy?
I do hope it takes off.
- HPy - A better C API for Python
-
Codon: A high-performance Python compiler
The HPy project [0] seems like a promising way out of this.
[0] https://hpyproject.org/
-
New record breaking for Python in TechEmPower
socketify.py breaks the record for Python no other Python WebFramework/Server as able to reach 6.2 mi requests per second before in TechEmPower Benchmarks, this puts Python at the same level of performance that Golang, Rust and C++ for web development, in fact Golang got 5.2 mi req/s in this same round. Almost every server or web framework tries to use JIT to boost the performance, but only socketify.py deliveries this level of performance, and even without JIT socketify.py is twice as fast any other web framework/server in active development, and still can be much more optimized using HPy (https://hpyproject.org/). Python will get even faster and faster in future!
-
Is it time to leave Python behind? (My personal rant)
I think Propose a better messaging for Python is the option and a lot of languages will learn it from Rust, because rust erros are the best described errors I see in my life lol. Cargo is amazing and I think we will need a better poetry/pip for sure, HPy project will modernize extensions and packages 📦 too https://hpyproject.org/
-
A Look on Python Web Performance at the end of 2022
It also show that PyPy3 will not magically boost your performance, you need to integrate in a manner that PyPy3 can optimize and delivery CPU performance, with a more complex example maybe it can help more. But why socketify is so much faster using PyPy3? The answer is CFFI, socketify did not use Cython for integration and cannot delivery the full performance on Python3, this will be solved with HPy.
-
socketify.py - Bringing WebSockets, Http/Https High Peformance servers for PyPy3 and Python3
HPy integration to better support CPython, PyPy and GraalPython
- HPy: A better C API for Python
-
Your Data Fits in RAM
Absolutely everything in CPython is a PyObject, and that can’t be changed without breaking the C API. A PyObject contains (among other things) a type pointer, a reference count, and a data field; none of these things can be changed without (again) breaking the C API.
There have definitely been attempts to modernize; the HPy project (https://hpyproject.org/), for instance, moves towards a handle-oriented API that keeps implementation details private and thus enables certain optimizations.
What are some alternatives?
libevent - Event notification library
nogil - Multithreaded Python without the GIL
graalpython - A Python 3 implementation built on GraalVM
TCP-over-UDP - An implementation of an educational tool for implementing and testing TCP over UDP in computer networks.
cinder - Cinder is Meta's internal performance-oriented production version of CPython.
src - Read-only git conversion of OpenBSD's official CVS src repository. Pull requests not accepted - send diffs to the tech@ mailing list.
py2js
socketify.py - Bringing Http/Https and WebSockets High Performance servers for PyPy3 and Python3
Pyjion - Pyjion - A JIT for Python based upon CoreCLR
libuv - Cross-platform asynchronous I/O
pgcopy - fast data loading with binary copy