Change update example to use a trivial webserver instead of nginx (issue #1803).

This commit is contained in:
David Oppenheimer 2014-11-11 11:52:26 -08:00
parent 21a6e96418
commit 03ae4b54a3
8 changed files with 70 additions and 50 deletions

View File

@ -12,11 +12,8 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
FROM dockerfile/nginx FROM scratch
MAINTAINER David Oppenheimer <davidopp@google.com>
ADD default /etc/nginx/sites-available/default ADD test-webserver test-webserver
EXPOSE 80
ONBUILD ADD html /usr/share/nginx/html ENTRYPOINT ["/test-webserver"]
ONBUILD RUN chmod -R a+r /usr/share/nginx/html
CMD ["nginx"]

View File

@ -0,0 +1,13 @@
all: push
test-webserver: test-webserver.go
CGO_ENABLED=0 GOOS=linux go build -a -tags netgo -ldflags '-w' ./test-webserver.go
container: test-webserver
sudo docker build -t kubernetes/test-webserver .
push: container
sudo docker push kubernetes/test-webserver
clean:
rm -f test-webserver

View File

@ -0,0 +1,48 @@
/*
Copyright 2014 Google Inc. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// A tiny web server that serves a static file.
package main
import (
"flag"
"fmt"
"log"
"net/http"
)
var (
port = flag.Int("port", 80, "Port number.")
)
func main() {
flag.Parse()
fs := http.StripPrefix("/", http.FileServer(http.Dir("/")))
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Cache-Control", "private")
w.Header().Set("Access-Control-Allow-Origin", "*")
w.Header().Set("Access-Control-Allow-Credentials", "true")
w.Header().Set("Access-Control-Allow-Methods", "GET, POST, OPTIONS")
w.Header().Set("Access-Control-Allow-Headers", "DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type")
fs.ServeHTTP(w, r)
})
go log.Fatal(http.ListenAndServe(fmt.Sprintf(":%d", *port), nil))
select {}
}

View File

@ -27,7 +27,6 @@ fi
set -x set -x
docker build -t update-demo-base images/base
docker build -t "${DOCKER_HUB_USER}/update-demo:kitten" images/kitten docker build -t "${DOCKER_HUB_USER}/update-demo:kitten" images/kitten
docker build -t "${DOCKER_HUB_USER}/update-demo:nautilus" images/nautilus docker build -t "${DOCKER_HUB_USER}/update-demo:nautilus" images/nautilus

View File

@ -1,37 +0,0 @@
# Copyright 2014 Google Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
server {
listen 80 default_server;
listen [::]:80 default_server ipv6only=on;
root /usr/share/nginx/html;
index index.html index.htm;
# Make site accessible from http://localhost/
server_name localhost;
location / {
try_files $uri $uri/ =404;
expires 0;
add_header Cache-Control private;
if ($request_method = 'GET') {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
}
}
}

View File

@ -12,4 +12,5 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
FROM update-demo-base FROM kubernetes/test-webserver
ADD html/data.json html/kitten.jpg /

View File

@ -12,4 +12,5 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
FROM update-demo-base FROM kubernetes/test-webserver
ADD html/data.json html/nautilus.jpg /

View File

@ -102,8 +102,6 @@ function validate() {
return 0 return 0
} }
export DOCKER_HUB_USER=jbeda
# Launch a container # Launch a container
${KUBE_ROOT}/examples/update-demo/2-create-replication-controller.sh ${KUBE_ROOT}/examples/update-demo/2-create-replication-controller.sh