Troubleshooting guide
See also:
Chaining / workflows
When chaning or invoking another function, do this by calling it via the gateway either using the external IP address of the cluster / gateway, or by the internal DNS name.
A common user-error is to try to invoke the gateway from within a function using or localhost
- this address simply points back to the container the function is running in and is invalid.
The default address for the gateway on Kubernetes is http://gateway.openfaas:8080
.
On Docker Swarm
The default address for the gateway is
Timeouts
Default timeouts are configured at the HTTP level and must be set both on the gateway and the function.
Timeouts - Your function
Default read_timeout
and write_timeout
value for functions are 5 seconds (subject to change) and can be overridden using read_timeout
and write_timeout
environment variable for each function.
You can also enforce a hard-timeout for your function with the hard_timeout
environmental variable.
For watchdog configuration see the README.
The best way to set the timeout is in the YAML file generated by the faas-cli
.
Example Go app that sleeps for (10 seconds):
handler.go
- package function
- ...
- func Handle(req []byte) string {
- time.Sleep(time.Second * 10)
- return fmt.Sprintf("Hello, Go. You said: %s", string(req))
- }
Timeouts - Gateway
For the gateway set the following environmental variables:
- read_timeout: "25s" # Maximum time to read HTTP request
- upstream_timeout: "20s" # Maximum duration of upstream function call
Timeouts - Function provider
When using a gateway version older than 0.7.8
a timeout matching the gateway should be set for the or faas-netes
controller.
- read_timeout: 25s
- write_timeout: 25s
For asynchronous invocations of functions a separate timeout can be configured at the queue-worker
level in the ack_wait
environmental variable.
Timeouts - Cloud Service Providers
There are situations where timeout values external to OpenFaaS may impact successful function execution. A typical scenario is where a cloud platform's load balancer product is fronting the cluster in which OpenFaaS is running. A common example is when using the .
By default the functions will not log out the result, but just show how long the process took to run and the length of the result in bytes.
- $ echo test this | faas invoke json-hook -g 127.0.0.1:31112
- Received JSON webook. Elements: 10
- $ kubectl logs deploy/json-hook -n openfaas-fn
- 2018/01/28 20:47:21 Writing lock-file to: /tmp/.lock
- 2018/01/28 20:47:27 Forking fprocess.
- 2018/01/28 20:47:27 Wrote 35 Bytes - Duration: 0.001844 seconds
If you want to see the result of a function in the function's logs then deploy it with the write_debug
environmental variable set to true
.
For example:
- provider:
- name: faas
- gateway: http://127.0.0.1:8080
- functions:
- json-hook:
- lang: go
- handler: ./json-hook
- image: json-hook
- environment:
- write_debug: true
Now you'll see logs like this:
- $ echo test this | faas invoke json-hook -g 127.0.0.1:31112
- Received JSON webook. Elements: 10
- $ kubectl logs deploy/json-hook -n openfaas-fn
- 2018/01/28 20:50:27 Writing lock-file to: /tmp/.lock
- 2018/01/28 20:50:35 Forking fprocess.
- 2018/01/28 20:50:35 Query
- 2018/01/28 20:50:35 Path /function/json-hook
- Received JSON webook. Elements: 10
- 2018/01/28 20:50:35 Duration: 0.001857 seconds
You can then find the logs of the function using Docker Swarm or Kubernetes as listed in the section below.
Healthcheck
Most problems reported via GitHub or Slack stem from a configuration problem or issue with a function. Here is a checklist of things you can try before digging deeper:
Checklist:
- All core services are deployed: i.e. gateway
- Check functions are deployed and started
- Check request isn't timing out at the gateway or the function level
CLI unresponsive - 127.0.0.1 vs. localhost
On certain Linux distributions the name localhost
maps to an IPv6 alias meaning that the CLI may hang. In these circumstances you have two options:
Use the
-g
or—gateway
argument with127.0.0.1:8080
or similarSet the
OPENFAAS_URL
environmental variable to127.0.0.1:8080
or similarEdit the
/etc/hosts
file on your machine and remove the IPv6 alias for localhost (this forces the use of IPv4)
If you'd like to uninstall or remove OpenFaaS from a host follow the steps below.
CLI
If you'd like to remove the CLI and you installed it with brew
, then use to remove it.
If you installed via the curl/sh
utility script:
- Run
rm -rf /usr/local/bin/faas-cli
- Delete saved gateway login details:
rm -rf ~/.openfaas
Swarm
Remove any functions you deployed:
- $ docker service ls --filter="label=function" -q | xargs docker service rm
Remove the whole stack
- $ docker stack rm func && \
- docker secret rm basic-auth-user && \
- docker secret rm basic-auth-password
Kubernetes
If deployed via Helm:
- helm delete --purge openfaas
If installed via YAML files:
- kubectl delete namespace openfaas openfaas-fn
Troubleshooting Swarm or Kubernetes
List all functions
Find a function's logs
- $ docker service logs --tail 100 FUNCTION
Find out if a function failed to start
I forgot my gateway password
If you've logged into the OpenFaaS CLI then you can retrieve the credentials from config.yaml
in ~/.openfaas/
. Use the value from the token
field such as: echo -n HASHED_VALUE | base64 -D/-d
to view the contents in plain-text. If you don't have access to bash or the base64 utility then type in docker run -ti alpine:3.9
to run a shell in Docker.
If you never logged in via the CLI then you can retrieve the contents from the cluster secret store:
Swarm
Use the jaas task-runner for Swarm (easiest option):
- $ docker run -ti -v /var/run/docker.sock:/var/run/docker.sock \
- alexellis2/jaas:1.1.0 \
- run --secret basic-auth-password \
- --image alpine:3.10 \
- --command "cat /run/secrets/basic-auth-password"
- Printing service logs
- 2018-08-28T07:50:46.431268693Z 21f596c9cd75a0fe5e335fb743995d18399e83418a37a79e719576a724efbbb6
- Or use a one-shot Docker Service:
- $ docker service rm print-password \
- ; docker service create --detach --secret basic-auth-password \
- --restart-condition=none --name=print-password \
- alpine:3.9 cat /run/secrets/basic-auth-password
- $ docker service logs print-password
- print-password.1.59bwe0bb4d99@nuc | 21f596c9cd75a0fe5e335fb743995d18399e83418a37a79e719576a724efbbb6
Troubleshoot Kubernetes
If you have deployed OpenFaaS to the recommended namespaces then functions are in the openfaas-fn
namespace and the core services are in the openfaas
namespace. The -n
flag to kubectl
sets the namespace to look at.
List OpenFaaS services
- $ kubectl get deploy -n openfaas
List all functions
- $ kubectl get deploy -n openfaas-fn
Find a function's logs
- $ kubectl logs -n openfaas-fn deploy/FUNCTION_NAME
If you have more than one replica of a function, you may want to use a log-tailing tool like .
View logs of all functions:
- kail -n openfaas-fn
View logs of all replicas of a single function:
- kail -n openfaas-fn --deploy=FUNCTION_NAME
Find out if a function failed to start
- $ kubectl describe -n openfaas-fn deploy/FUNCTION_NAME
Check logs of the core services
Check for any relevant events:
- $ kubectl get events --sort-by=.metadata.creationTimestamp -n openfaas
These instructions may differ depending on whether you are using faas-netes (default) or the OpenFaaS Operator
Get logs using faas-netes
- $ kubectl logs -n openfaas deploy/gateway -c faas-netes
- $ kubectl logs -n openfaas deploy/gateway -c gateway
Check the queue-worker
- $ kubectl logs -n openfaas-fn deploy/queue-worker
Get logs using OpenFaaS Operator
- $ kubectl logs -n openfaas deploy/gateway -c operator
- $ kubectl logs -n openfaas deploy/gateway -c gateway
I forgot my gateway password
Use the following to print the secret on the terminal:
- PASSWORD=$(kubectl get secret -n openfaas basic-auth -o jsonpath="{.data.basic-auth-password}" | base64 --decode; echo)
- echo $PASSWORD
Set OPENFAAS_URL
then log into the gateway:
- echo -n $PASSWORD | faas-cli login --username admin --password-stdin
If you installed OpenFaaS into a custom namespace then change the value to -n custom-ns
.
Watchdog
Debug your function without deploying it
Here's an example of how you can deploy a function without using an orchestrator and the API gateway. It is especially useful for testing:
- $ docker run --name debug-alpine \
- -p 8081:8080 -ti functions/alpine:3.9 sh
- # fprocess=date fwatchdog &
Now you can access the function with one of the supported HTTP methods such as GET/POST etc:
- $ curl -4 127.0.0.1:8081
Edit your function without rebuilding it
You can bind-mount code straight into your function and work with it locally, until you are ready to re-build. This is a common flow with containers, but should be used sparingly.
Within the CLI directory for instance:
Build the samples:
- $ git clone https://github.com/openfaas/faas-cli && \
- cd faas-cli
- $ faas-cli -action build -f ./samples.yml
Now work with the Python-hello sample, with the code mounted live:
- $ docker run -v `pwd`/sample/url-ping/:/root/function/ \
- --name debug-alpine -p 8081:8080 -ti alexellis/faas-url-ping sh
- $ touch ./function/__init__.py
- # fwatchdog
Now you can start editing the code in the sample/url-ping folder and it will reload live for every request.
- $ echo "def handle(req):" > sample/url-ping/handler.py
- $ echo ' print("Nothing to see here")' >> sample/url-ping/handler.py
- $ curl 127.0.0.1:8081 -d "https://www.google.com"