Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
forked fromsanic-org/sanic

Async Python 3.5+ web server that's written to go fast

License

NotificationsYou must be signed in to change notification settings

kkochis/sanic

 
 

Repository files navigation

Sanic | Build fast. Run fast.

Sanic | Build fast. Run fast.

Build
Py310TestPy39TestPy38TestPy37Test
Docs
UserGuideDocumentation
Package
PyPIPyPI versionPyPI WheelSupported implementationsCode style black
Support
ForumsDiscordAwesome Sanic List
Stats
DownloadsDownloadsDownloads

Sanic is aPython 3.7+ web server and web framework that's written to go fast. It allows the usage of theasync/await syntax added in Python 3.5, which makes your code non-blocking and speedy.

Sanic is also ASGI compliant, so you can deploy it with analternative ASGI webserver.

Source code on GitHub |Help and discussion board |User Guide |Chat on Discord

The project is maintained by the community, for the community.Contributions are welcome!

The goal of the project is to provide a simple way to get up and running a highly performant HTTP server that is easy to build, to expand, and ultimately to scale.

Sponsor

Check outopen collective to learn more about helping to fund Sanic.

Thanks toLinode for their contribution towards the development and community of Sanic.

Linode

Installation

pip3 install sanic

Sanic makes use ofuvloop andujson to help with performance. If you do not want to use those packages, simply add an environmental variableSANIC_NO_UVLOOP=true orSANIC_NO_UJSON=true at install time.

$export SANIC_NO_UVLOOP=true$export SANIC_NO_UJSON=true$ pip3 install --no-binary :all: sanic

Note

If you are running on a clean install of Fedora 28 or above, please make sure you have theredhat-rpm-config package installed in case if you want tousesanic withujson dependency.

Hello World Example

fromsanicimportSanicfromsanic.responseimportjsonapp=Sanic("my-hello-world-app")@app.route('/')asyncdeftest(request):returnjson({'hello':'world'})if__name__=='__main__':app.run()

Sanic can now be easily run usingsanic hello.app.

[2018-12-30 11:37:41 +0200] [13564] [INFO] Goin' Fast @ http://127.0.0.1:8000[2018-12-30 11:37:41 +0200] [13564] [INFO] Starting worker [13564]

And, we can verify it is working:curl localhost:8000 -i

HTTP/1.1 200 OKConnection: keep-aliveKeep-Alive: 5Content-Length: 17Content-Type: application/json{"hello":"world"}

Now, let's go build something fast!

Minimum Python version is 3.7. If you need Python 3.6 support, please use v20.12LTS.

Documentation

User Guide andAPI Documentation.

Changelog

Release Changelogs.

Questions and Discussion

Ask a question or join the conversation.

Contribution

We are always happy to have new contributions. We havemarked issues good for anyone looking to get started, and welcomequestions on the forums. Please take a look at ourContribution guidelines.

About

Async Python 3.5+ web server that's written to go fast

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python99.3%
  • Other0.7%

[8]ページ先頭

©2009-2025 Movatter.jp