{"id":19842481,"url":"https://github.com/zelflod/highload_web_server","last_synced_at":"2025-10-29T21:47:44.073Z","repository":{"id":121231509,"uuid":"242130558","full_name":"zelflod/highload_web_server","owner":"zelflod","description":"Python web server","archived":false,"fork":false,"pushed_at":"2020-03-03T19:19:34.000Z","size":487,"stargazers_count":3,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-01-11T11:46:15.665Z","etag":null,"topics":["asynchronous","asyncio","event-loop","non-blocking","python","single-threaded","web-server"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/zelflod.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-02-21T12:08:10.000Z","updated_at":"2024-07-26T07:46:24.000Z","dependencies_parsed_at":"2023-05-03T17:51:33.950Z","dependency_job_id":null,"html_url":"https://github.com/zelflod/highload_web_server","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zelflod%2Fhighload_web_server","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zelflod%2Fhighload_web_server/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zelflod%2Fhighload_web_server/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/zelflod%2Fhighload_web_server/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/zelflod","download_url":"https://codeload.github.com/zelflod/highload_web_server/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":241211984,"owners_count":19927883,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["asynchronous","asyncio","event-loop","non-blocking","python","single-threaded","web-server"],"created_at":"2024-11-12T12:34:43.947Z","updated_at":"2025-10-29T21:47:39.024Z","avatar_url":"https://github.com/zelflod.png","language":"Python","readme":"## Python web server with non-blocking io\n\nВеб-сервер для отдачи статики с диска\n\nИспользуется неблокирующий ввод/вывод, кооперативная многозадачность, асинхронное программирование с помощью библиотеки AsyncIO, так как операции в веб-сервере являются IO bound (больше висят попеременно в ожидании ввода/вывода)\n\nСоздаются однопоточные процессы `worker` с циклом событий, которые слушают привязанный к `host:ip` сокет и одновременно обрабатывают соединения и запросы.\n \n### Run\n\n```\ncd /tmp\ngit clone https://github.com/zelflod/highload_web_server.git\n\ndocker build -t py_web_server https://github.com/zelflod/highload_web_server.git\ndocker run -it -p 80:80 -v /tmp/highload_web_server/httpd.conf:/etc/httpd.conf:ro -v /tmp/highload_web_server/http-test-suite:/var/www/html:ro --name py_web_server -t py_web_server\n\n# sudo docker start -a py_web_server\n```\n\n```\nsudo docker build -t py_web_server .\nsudo docker run -it -p 80:80 -v /home/nozim/Documents/Univer/VKR/highload_web_server/httpd.conf:/etc/httpd.conf:ro -v /home/nozim/Documents/Univer/VKR/highload_web_server/http-test-suite:/var/www/html:ro --name py_web_server -t py_web_server\n\n# mkfile 2048m test_2048.txt\n```\n\nТребования и методика тестирования (корректности работы) по ссылке: https://github.com/init/http-test-suite\n\n### Нагрузочное тестирование и проверка стабильности\n\n```\nwrk -t12 -c400 -d30s http://localhost/httptest/wikipedia_russia.html \n```\n##### py_web_serber with 8 CPU use\n\n![wrk_py_web_server_8_cpu](benchmark/wrk_py_web_server_8_cpu.png \"wrk_py_web_server_8_cpu\")\n\n##### py_web_serber with 2 CPU use\n\n![wrk_py_web_server_8_cpu](benchmark/wrk_py_web_server_2_cpu.png \"wrk_py_web_server_2_cpu\")\n\n##### nginx with with default (all) CPU use\n\n![wrk_nginx](benchmark/wrk_nginx.png \"wrk_nginx\")\n\n\n```\nab -n 100000 -c 100 127.0.0.1/httptest/wikipedia_russia.html\n```\n\n##### py_web_server with 8 CPU use\n\n![ab_py_web_server](benchmark/ab_py_web_server.png \"ab_py_web_server\")\n\n\n##### nginx with with default (all) CPU use\n\n![ab_nginx](benchmark/ab_nginx.png \"ab_nginx\")\n\n### Run nginx (to compare performance)\n\n```\ndocker run -it -v /tmp/highload_web_server/http-test-suite:/usr/share/nginx/html:ro -p 80:80 nginx\n```\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fzelflod%2Fhighload_web_server","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fzelflod%2Fhighload_web_server","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fzelflod%2Fhighload_web_server/lists"}