# Iris web framework <img align="right" width="170px" src="https://iris-go.com/images/logo.svg" title="logo created by @merry.dii" /> [](https://travis-ci.org/kataras/iris)<!-- [](https://github.com/kataras/iris/releases)--> [](http://goreportcard.com/report/kataras/iris)<!--[](https://github.com/kataras/iris/issues?q=is%3Aissue+is%3Aclosed)--> [](https://kataras.rocket.chat/channel/iris) [](https://github.com/kataras/iris/tree/master/_examples) [](https://github.com/kataras/iris/releases) Iris is a fast, simple yet fully featured and very efficient web framework for Go. Iris provides a beautifully expressive and easy to use foundation for your next website or API. Finally, a real expressjs equivalent for the Go Programming Language. Learn what [others say about Iris](#support) and [star](https://github.com/kataras/iris/stargazers) this github repository to stay [up to date](https://facebook.com/iris.framework). ## Backers Thank you to all our backers! [Become a backer](https://opencollective.com/iris#backer) <a href="https://opencollective.com/iris#backers" target="_blank"><img src="https://opencollective.com/iris/backers.svg?width=890"></a> ## Installation The only requirement is the [Go Programming Language](https://golang.org/dl/) ```sh $ go get -u github.com/kataras/iris ``` Iris takes advantage of the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature. You get truly reproducible builds, as this method guards against upstream renames and deletes. [](_benchmarks/README_UNIX.md) _Updated at: [Tuesday, 21 November 2017](_benchmarks/README_UNIX.md)_ <details> <summary>Benchmarks from third-party source over the rest web frameworks</summary>  </details> ## Support - [HISTORY](HISTORY.md#mo-01-jenuary-2018--v1000) file is your best friend, it contains information about the latest features and changes - Did you happen to find a bug? Post it at [github issues](https://github.com/kataras/iris/issues) - Do you have any questions or need to speak with someone experienced to solve a problem at real-time? Join us to the [community chat](https://chat.iris-go.com) - Complete our form-based user experience report by clicking [here](https://docs.google.com/forms/d/e/1FAIpQLSdCxZXPANg_xHWil4kVAdhmh7EBBHQZ_4_xSZVDL-oCC_z5pA/viewform?usp=sf_link) - Do you like the framework? Tweet something about it! The People have spoken: <a href="https://twitter.com/gelnior/status/769100480706379776"> <img src="https://comments.iris-go.com/comment27_mini.png" width="350px"> </a> <a href="https://twitter.com/MeAlex07/status/822799954188075008"> <img src="https://comments.iris-go.com/comment28_mini.png" width="350px"> </a> <a href="https://twitter.com/_mgale/status/818591490305761280"> <img src="https://comments.iris-go.com/comment29_mini.png" width="350px"> </a> <a href="https://twitter.com/VeayoX/status/813273328550973440"> <img src="https://comments.iris-go.com/comment30_mini.png" width="350px"> </a> <a href="https://twitter.com/pvsukale/status/745328224876408832"> <img src="https://comments.iris-go.com/comment31_mini.png" width="350px"> </a> <a href="https://twitter.com/blainsmith/status/745338092211560453"> <img src="https://comments.iris-go.com/comment32_mini.png" width="350px"> </a> <a href="https://twitter.com/tjbyte/status/758287014210867200"> <img src="https://comments.iris-go.com/comment33_mini.png" width="350px"> </a> <a href="https://twitter.com/tangzero/status/751050577220698112"> <img src="https://comments.iris-go.com/comment34_mini.png" width="350px"> </a> <a href="https://twitter.com/tjbyte/status/758287244947972096"> <img src="https://comments.iris-go.com/comment33_2_mini.png" width="350px"> </a> <a href="https://twitter.com/ferarias/status/902468752364773376"> <img src="https://comments.iris-go.com/comment41.png" width="350px"> </a> <br/><br/> For more information about contributing to the Iris project please check the [CONTRIBUTING.md](CONTRIBUTING.md) file. [List of all Contributors](https://github.com/kataras/iris/graphs/contributors) ## Learn First of all, the most correct way to begin with a web framework is to learn the basics of the programming language and the standard `http` capabilities, if your web application is a very simple personal project without performance and maintainability requirements you may want to proceed just with the standard packages. After that follow the guidelines: - Navigate through **100+1** **[examples](_examples)** and some [iris starter kits](#iris-starter-kits) we crafted for you - Read the [godocs](https://godoc.org/github.com/kataras/iris) for any details - Prepare a cup of coffee or tea, whatever pleasures you the most, and read some [articles](#articles) we found for you ### Iris starter kits <!-- table form | Description | Link | | -----------|-------------| | Hasura hub starter project with a ready to deploy golang helloworld webapp with IRIS! | https://hasura.io/hub/project/hasura/hello-golang-iris | | A basic web app built in Iris for Go |https://github.com/gauravtiwari/go_iris_app | | A mini social-network created with the awesome Iris๐๐ | https://github.com/iris-contrib/Iris-Mini-Social-Network | | Iris isomorphic react/hot reloadable/redux/css-modules starter kit | https://github.com/iris-contrib/iris-starter-kit | | Demo project with react using typescript and Iris | https://github.com/ionutvilie/react-ts | | Self-hosted Localization Management Platform built with Iris and Angular | https://github.com/iris-contrib/parrot | | Iris + Docker and Kubernetes | https://github.com/iris-contrib/cloud-native-go | | Quickstart for Iris with Nanobox | https://guides.nanobox.io/golang/iris/from-scratch | --> 1. [A basic web app built in Iris for Go](https://github.com/gauravtiwari/go_iris_app) 2. [A mini social-network created with the awesome Iris๐๐](https://github.com/iris-contrib/Iris-Mini-Social-Network) 3. [Iris isomorphic react/hot reloadable/redux/css-modules starter kit](https://github.com/iris-contrib/iris-starter-kit) 4. [Demo project with react using typescript and Iris](https://github.com/ionutvilie/react-ts) 5. [Self-hosted Localization Management Platform built with Iris and Angular](https://github.com/iris-contrib/parrot) 6. [Iris + Docker and Kubernetes](https://github.com/iris-contrib/cloud-native-go) 7. [Quickstart for Iris with Nanobox](https://guides.nanobox.io/golang/iris/from-scratch) 8. [A Hasura starter project with a ready to deploy Golang hello-world web app with IRIS](https://hasura.io/hub/project/hasura/hello-golang-iris) > Did you build something similar? Let us [know](https://github.com/kataras/iris/pulls)! ### Middleware Iris has a great collection of handlers[[1]](middleware/)[[2]](https://github.com/iris-contrib/middleware) that you can use side by side with your web apps. However you are not limited to them - you are free to use any third-party middleware that is compatible with the [net/http](https://golang.org/pkg/net/http/) package, [_examples/convert-handlers](_examples/convert-handlers) will show you the way. Iris, unlike others, is 100% compatible with the standards and that's why the majority of the big companies that adapt Go to their workflow, like a very famous US Television Network, trust Iris; it's always up-to-date and it will be aligned with the std `net/http` package which is modernized by the Go Author on each new release of the Go Programming Language forever. ### Articles * [A Hasura starter project with a ready to deploy Golang hello-world web app with IRIS](bit.ly/2lmKaAZ) * [Top 6 web frameworks for Go as of 2017](https://blog.usejournal.com/top-6-web-frameworks-for-go-as-of-2017-23270e059c4b) * [Iris Go Framework + MongoDB](https://medium.com/go-language/iris-go-framework-mongodb-552e349eab9c) * [How to build a file upload form using DropzoneJS and Go](https://hackernoon.com/how-to-build-a-file-upload-form-using-dropzonejs-and-go-8fb9f258a991) * [How to display existing files on server using DropzoneJS and Go](https://hackernoon.com/how-to-display-existing-files-on-server-using-dropzonejs-and-go-53e24b57ba19) * [Iris, a modular web framework](https://medium.com/@corebreaker/iris-web-cd684b4685c7) * [Go vs .NET Core in terms of HTTP performance](https://medium.com/@kataras/go-vs-net-core-in-terms-of-http-performance-7535a61b67b8) * [Iris Go vs .NET Core Kestrel in terms of HTTP performance](https://hackernoon.com/iris-go-vs-net-core-kestrel-in-terms-of-http-performance-806195dc93d5) * [How to Turn an Android Device into a Web Server](https://twitter.com/ThePracticalDev/status/892022594031017988) * [Deploying a Iris Golang app in hasura](https://medium.com/@HasuraHQ/deploy-an-iris-golang-app-with-backend-apis-in-minutes-25a559bf530b) * [A URL Shortener Service using Go, Iris and Bolt](https://medium.com/@kataras/a-url-shortener-service-using-go-iris-and-bolt-4182f0b00ae7) ### Get hired There are many companies and start-ups looking for Go web developers with Iris experience as requirement, we are searching for you every day and we post those information via our [facebook page](https://www.facebook.com/iris.framework), like the page to get notified, we have already posted some of them. ### Sponsors Thank you to all our sponsors! (please ask your company to also support this open source project by [becoming a sponsor](https://opencollective.com/iris#sponsor)) <a href="https://opencollective.com/iris/sponsor/0/website" target="_blank"><img src="https://opencollective.com/iris/sponsor/0/avatar.svg"></a> <a href="https://opencollective.com/iris/sponsor/1/website" target="_blank"><img src="https://opencollective.com/iris/sponsor/1/avatar.svg"></a> ## License Iris is licensed under the [3-Clause BSD License](LICENSE). Iris is 100% free and open-source software. For any questions regarding the license please send [e-mail](mailto:kataras2006@hotmail.com?subject=Iris%20License).