mirror of
https://github.com/nsnail/Ocelot.git
synced 2025-06-19 23:28:15 +08:00
docker build works on windows
This commit is contained in:
196
README.md
196
README.md
@ -1,98 +1,98 @@
|
||||
[<img src="https://threemammals.com/ocelot_logo.png">](https://threemammals.com/ocelot)
|
||||
|
||||
[](https://circleci.com/gh/ThreeMammals/Ocelot)
|
||||
|
||||
[](https://coveralls.io/github/ThreeMammals/Ocelot?branch=master)
|
||||
|
||||
|
||||
|
||||
# Ocelot
|
||||
|
||||
Ocelot is a .NET API Gateway. This project is aimed at people using .NET running
|
||||
a micro services / service oriented architecture
|
||||
that need a unified point of entry into their system. However it will work with anything that speaks HTTP and run on any platform that ASP.NET Core supports.
|
||||
|
||||
In particular I want easy integration with
|
||||
IdentityServer reference and bearer tokens.
|
||||
|
||||
We have been unable to find this in my current workplace
|
||||
without having to write our own Javascript middlewares
|
||||
to handle the IdentityServer reference tokens. We would
|
||||
rather use the IdentityServer code that already exists
|
||||
to do this.
|
||||
|
||||
Ocelot is a bunch of middlewares in a specific order.
|
||||
|
||||
Ocelot manipulates the HttpRequest object into a state specified by its configuration until
|
||||
it reaches a request builder middleware where it creates a HttpRequestMessage object which is
|
||||
used to make a request to a downstream service. The middleware that makes the request is
|
||||
the last thing in the Ocelot pipeline. It does not call the next middleware.
|
||||
The response from the downstream service is retrieved as the requests goes back up the Ocelot pipeline.
|
||||
There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that
|
||||
is returned to the client. That is basically it with a bunch of other features!
|
||||
|
||||
## Features
|
||||
|
||||
A quick list of Ocelot's capabilities for more information see the [documentation](https://ocelot.readthedocs.io/en/latest/).
|
||||
|
||||
* Routing
|
||||
* Request Aggregation
|
||||
* Service Discovery with Consul & Eureka
|
||||
* Service Fabric
|
||||
* Kubernetes
|
||||
* WebSockets
|
||||
* Authentication
|
||||
* Authorisation
|
||||
* Rate Limiting
|
||||
* Caching
|
||||
* Retry policies / QoS
|
||||
* Load Balancing
|
||||
* Logging / Tracing / Correlation
|
||||
* Headers / Query String / Claims Transformation
|
||||
* Custom Middleware / Delegating Handlers
|
||||
* Configuration / Administration REST API
|
||||
* Platform / Cloud Agnostic
|
||||
|
||||
## How to install
|
||||
|
||||
Ocelot is designed to work with ASP.NET Core only and it targets `netstandard2.0`. This means it can be used anywhere `.NET Standard 2.0` is supported, including `.NET Core 2.1` and `.NET Framework 4.7.2` and up. [This](https://docs.microsoft.com/en-us/dotnet/standard/net-standard) documentation may prove helpful when working out if Ocelot would be suitable for you.
|
||||
|
||||
Install Ocelot and it's dependencies using NuGet.
|
||||
|
||||
`Install-Package Ocelot`
|
||||
|
||||
Or via the .NET Core CLI:
|
||||
|
||||
`dotnet add package ocelot`
|
||||
|
||||
All versions can be found [here](https://www.nuget.org/packages/Ocelot/)
|
||||
|
||||
## Documentation
|
||||
|
||||
Please click [here](https://ocelot.readthedocs.io/en/latest/) for the Ocelot documentation. This includes lots of information and will be helpful if you want to understand the features Ocelot currently offers.
|
||||
|
||||
## Coming up
|
||||
|
||||
You can see what we are working on [here](https://github.com/ThreeMammals/Ocelot/issues).
|
||||
|
||||
## Contributing
|
||||
|
||||
We love to receive contributions from the community so please keep them coming :)
|
||||
|
||||
Pull requests, issues and commentary welcome!
|
||||
|
||||
Please complete the relevant template for issues and PRs. Sometimes it's worth getting in touch with us to discuss changes
|
||||
before doing any work incase this is something we are already doing or it might not make sense. We can also give
|
||||
advice on the easiest way to do things :)
|
||||
|
||||
Finally we mark all existing issues as help wanted, small, medium and large effort. If you want to contribute for the first time I suggest looking at a help wanted & small effort issue :)
|
||||
|
||||
## Donate
|
||||
|
||||
If you think this project is worth supporting financially please make a contribution using the button below!
|
||||
|
||||
[](https://www.paypal.me/ThreeMammals/)
|
||||
|
||||
## Things that are currently annoying me
|
||||
|
||||
[ Get more details at **codescene.io**.](https://codescene.io/projects/697/jobs/latest-successful/results)
|
||||
[<img src="https://threemammals.com/ocelot_logo.png">](https://threemammals.com/ocelot)
|
||||
|
||||
[](https://circleci.com/gh/ThreeMammals/Ocelot)
|
||||
|
||||
[](https://coveralls.io/github/ThreeMammals/Ocelot?branch=master)
|
||||
|
||||
|
||||
|
||||
# Ocelot
|
||||
|
||||
Ocelot is a .NET API Gateway. This project is aimed at people using .NET running
|
||||
a micro services / service oriented architecture
|
||||
that need a unified point of entry into their system. However it will work with anything that speaks HTTP and run on any platform that ASP.NET Core supports.
|
||||
|
||||
In particular I want easy integration with
|
||||
IdentityServer reference and bearer tokens.
|
||||
|
||||
We have been unable to find this in my current workplace
|
||||
without having to write our own Javascript middlewares
|
||||
to handle the IdentityServer reference tokens. We would
|
||||
rather use the IdentityServer code that already exists
|
||||
to do this.
|
||||
|
||||
Ocelot is a bunch of middlewares in a specific order.
|
||||
|
||||
Ocelot manipulates the HttpRequest object into a state specified by its configuration until
|
||||
it reaches a request builder middleware where it creates a HttpRequestMessage object which is
|
||||
used to make a request to a downstream service. The middleware that makes the request is
|
||||
the last thing in the Ocelot pipeline. It does not call the next middleware.
|
||||
The response from the downstream service is retrieved as the requests goes back up the Ocelot pipeline.
|
||||
There is a piece of middleware that maps the HttpResponseMessage onto the HttpResponse object and that
|
||||
is returned to the client. That is basically it with a bunch of other features!
|
||||
|
||||
## Features
|
||||
|
||||
A quick list of Ocelot's capabilities for more information see the [documentation](https://ocelot.readthedocs.io/en/latest/).
|
||||
|
||||
* Routing
|
||||
* Request Aggregation
|
||||
* Service Discovery with Consul & Eureka
|
||||
* Service Fabric
|
||||
* Kubernetes
|
||||
* WebSockets
|
||||
* Authentication
|
||||
* Authorisation
|
||||
* Rate Limiting
|
||||
* Caching
|
||||
* Retry policies / QoS
|
||||
* Load Balancing
|
||||
* Logging / Tracing / Correlation
|
||||
* Headers / Query String / Claims Transformation
|
||||
* Custom Middleware / Delegating Handlers
|
||||
* Configuration / Administration REST API
|
||||
* Platform / Cloud Agnostic
|
||||
|
||||
## How to install
|
||||
|
||||
Ocelot is designed to work with ASP.NET Core only and it targets `netstandard2.0`. This means it can be used anywhere `.NET Standard 2.0` is supported, including `.NET Core 2.1` and `.NET Framework 4.7.2` and up. [This](https://docs.microsoft.com/en-us/dotnet/standard/net-standard) documentation may prove helpful when working out if Ocelot would be suitable for you.
|
||||
|
||||
Install Ocelot and it's dependencies using NuGet.
|
||||
|
||||
`Install-Package Ocelot`
|
||||
|
||||
Or via the .NET Core CLI:
|
||||
|
||||
`dotnet add package ocelot`
|
||||
|
||||
All versions can be found [here](https://www.nuget.org/packages/Ocelot/)
|
||||
|
||||
## Documentation
|
||||
|
||||
Please click [here](https://ocelot.readthedocs.io/en/latest/) for the Ocelot documentation. This includes lots of information and will be helpful if you want to understand the features Ocelot currently offers.
|
||||
|
||||
## Coming up
|
||||
|
||||
You can see what we are working on [here](https://github.com/ThreeMammals/Ocelot/issues).
|
||||
|
||||
## Contributing
|
||||
|
||||
We love to receive contributions from the community so please keep them coming :)
|
||||
|
||||
Pull requests, issues and commentary welcome!
|
||||
|
||||
Please complete the relevant template for issues and PRs. Sometimes it's worth getting in touch with us to discuss changes
|
||||
before doing any work incase this is something we are already doing or it might not make sense. We can also give
|
||||
advice on the easiest way to do things :)
|
||||
|
||||
Finally we mark all existing issues as help wanted, small, medium and large effort. If you want to contribute for the first time I suggest looking at a help wanted & small effort issue :)
|
||||
|
||||
## Donate
|
||||
|
||||
If you think this project is worth supporting financially please make a contribution using the button below!
|
||||
|
||||
[](https://www.paypal.me/ThreeMammals/)
|
||||
|
||||
## Things that are currently annoying me
|
||||
|
||||
[ Get more details at **codescene.io**.](https://codescene.io/projects/697/jobs/latest-successful/results)
|
||||
|
Reference in New Issue
Block a user