This service sends task updates to FuncX clients via WebSockets.
docker build -t funcx_websocket_service:develop .
Use these values:
webService:
host: http://localhost:5000
globusClient: ...
globusKey: ...
image: funcx/web-service
tag: main
pullPolicy: Always
endpoint:
enabled: false
funcx_endpoint:
image:
tag: exception
forwarder:
enabled: true
image: funcx/forwarder
tag: main
pullPolicy: Always
redis:
master:
service:
nodePort: 30379
type: NodePort
postgresql:
service:
nodePort: 30432
type: NodePort
websocketService:
image: funcx_websocket_service
tag: develop
pullPolicy: Never
You should deploy as usual like:
helm install -f deployed_values/values.yaml funcx funcx
Port 5000 will need to be exposed for the web service, and the WebSocket server uses port 6000:
export POD_NAME=$(kubectl get pods --namespace default -l "app=funcx-funcx-web-service" -o jsonpath="{.items[0].metadata.name}") && kubectl port-forward $POD_NAME 5000:5000
export POD_NAME=$(kubectl get pods --namespace default -l "app=funcx-funcx-websocket-service" -o jsonpath="{.items[0].metadata.name}") && kubectl port-forward $POD_NAME 6000:6000
First install test requirements:
python -m pip install -r test-requirements.txt
Then run tests with pytest:
pytest funcx_websocket_service/tests
When this repository is installed as a package, it is run as follows (Running this outside of a Helm chart deployment is not recommended):
websocket-service [--debug]
--debug
- If this flag is present or the FUNCX_WEBSOCKET_SERVICE_DEBUG
environment variable is set, the debug log level is shown
FUNCX_WEBSOCKET_SERVICE_DEBUG
- If this is set to anything or the debug CLI argument above is set, the debug log level is shown
REDIS_HOST
- redis host (defaults to 127.0.0.1
)
FUNCX_REDIS_MASTER_SERVICE_HOST
- redis host set by Helm deployment (REDIS_HOST
overrides this if set)
REDIS_PORT
- redis port (defaults to 6379
)
RABBITMQ_URI
- RabbitMQ host (defaults to amqp://funcx:rabbitmq@127.0.0.1/
)
FUNCX_RABBITMQ_SERVICE_HOST
- RabbitMQ host set by Helm deployment (RABBITMQ_URI
overrides this if set)
WEB_SERVICE_URI
- funcX web service URI (defaults to http://127.0.0.1:5000
)
Run an endpoint with funcx_service_address='https://api.dev.funcx.org/v2'
, then set your endpoint_id
in the script below. This example uses a FuncXExecutor
to double 10 random numbers, then prints the results when they arrive back from the WebSocket service.
import random
from funcx import FuncXClient
from funcx.sdk.executor import FuncXExecutor
def double(x):
return x * 2
service_url = 'https://api.dev.funcx.org/v2'
# Set your endpoint_id here
endpoint_id = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
fx = FuncXExecutor(FuncXClient(funcx_service_address=service_url,
results_ws_uri='wss://api.dev.funcx.org/ws/v2/'))
futures = []
for i in range(10):
x = random.randint(0, 100)
future = fx.submit(double, x, endpoint_id=endpoint_id)
futures.append(future)
for future in futures:
print(future.result())