目录

Sample HTTP Application

The sample HTTP application implements the correct shutdown behavior for an HTTP application deployed to Cloud Foundry. It adheres to the following contract when shutting down:

  • App receives termination signal
  • App closes listener so that it stops accepting new connections
  • App finishes serving in-flight requests
  • App closes existing connections as their requests complete
  • App shuts down (or is KILLed)

This application implements the connection management itself in main.go, but similar logic can be found in the Shutdown method of the Golang HTTP server.

Configure

The app is configurable by setting the following environment variables:

  • PORT: The port on which the HTTP server will be listening. It defaults to 8080.

Response Latency

The response latency can be controlled by setting the query parameter wait to any string parseable by time.ParseDuration. The default value is 10 µs.

Deploy to Cloud Foundry

Simply run cf push from the app root directory and it should deploy successfully.

Run Locally

To run locally, follow the steps below:

go get ./...
go build .
./sample-http-app

To run the tests, first get the dependencies using go get -t ./... && go get github.com/onsi/ginkgo/ginkgo then run ginkgo in the app root directory.

关于
104.0 KB
邀请码
    Gitlink(确实开源)
  • 加入我们
  • 官网邮箱:gitlink@ccf.org.cn
  • QQ群
  • QQ群
  • 公众号
  • 公众号

版权所有:中国计算机学会技术支持:开源发展技术委员会
京ICP备13000930号-9 京公网安备 11010802032778号