TabPy server is the server component of Tableau's Python integration. It is a Python process built on Tornado and other Python libraries.
Default settings for TabPy may be viewed in the tabpy_server/common/config.py.template file.
Change settings by:
- Adding an environment variables.
- set the environment variable as required by your Operating System. When creating environment variables, use the same name as is in the config file as an environment variable. The files tabpy_server/startup.sh and startup.bat have examples of how to set environment variables in both Linux and Windows respectively and then start the application.
- Creating a config.py file
- copy the template file from tabpy_server/common/config.py.template to tabpy_server/common/config.py and edit the settings that need changing.
The template file is not used by the application but is used for documenting which settings may be modified and what the defaults are if no config file or environment variables are set.
If you have installed a pre-built distribution from PyPy you will need to navigate to the source code contained in _site\packages and go subsequently into the tabpy-server/tabpy-server directory. From there run:
python tabpy.py
to start up a server.
If working with the source code refer to the instructions located in the Contributing Guide.
The server process exposes several REST APIs to get status and to execute Python code and query deployed methods.
Get static information about the server.
Example request:
GET /info HTTP/1.1
Host: localhost:9004
Accept: application/json
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
{"description": "",
"creation_time": "0",
"state_path": "/Users/username/my-server-state-folder",
"server_version": "dev",
"name": "my-server-name"}
description
is a string that is hardcoded in thestate.ini
file and can be edited there.creation_time
is the creation time in seconds since 1970-01-01, hardcoded in thestate.ini
file, where it can be edited.state_path
is the state file path of the server (the value of the TABPY_STATE_PATH at the time the server was started).server_version
is a string provided by the server and is defined by the variable TABPY_SERVER_VERSION. Clients can use this information for compatibility checks.
See TabPy Configuration section for more information on modifying the settings.
Using curl:
curl -X GET http://localhost:9004/info
Gets runtime status of deployed endpoints. If no endpoints are deployed in the server, the returned data is an empty JSON object.
Example request:
GET /status HTTP/1.1
Host: localhost:9004
Accept: application/json
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
{"clustering": {
"status": "LoadSuccessful",
"last_error": null,
"version": 1,
"type": "model"},
"add": {
"status": "LoadSuccessful",
"last_error": null,
"version": 1,
"type": "model"}
}
Using curl:
curl -X GET http://localhost:9004/status
Gets a list of deployed endpoints and their static information. If no endpoints are deployed in the server, the returned data is an empty JSON object.
Example request:
GET /endpoints HTTP/1.1
Host: localhost:9004
Accept: application/json
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
{"clustering":
{"description": "",
"docstring": "-- no docstring found in query function --",
"creation_time": 1469511182,
"version": 1,
"dependencies": [],
"last_modified_time": 1469511182,
"type": "model",
"target": null},
"add": {
"description": "",
"docstring": "-- no docstring found in query function --",
"creation_time": 1469505967,
"version": 1,
"dependencies": [],
"last_modified_time": 1469505967,
"type": "model",
"target": null}
}
Using curl:
curl -X GET http://localhost:9004/endpoints
Gets the description of a specific deployed endpoint. The endpoint must first be deployed in the server (see the client documentation).
Example request:
GET /endpoints/add HTTP/1.1
Host: localhost:9004
Accept: application/json
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
{"description": "", "docstring": "-- no docstring found in query function --",
"creation_time": 1469505967, "version": 1, "dependencies": [],
"last_modified_time": 1469505967, "type": "model", "target": null}
Using curl:
curl -X GET http://localhost:9004/endpoints/add
Executes a block of Python code, replacing named parameters with their provided values.
The expected POST body is a JSON dictionary with two elements:
- A key
data
with a value that contains the parameter values passed to the code. These values are key-value pairs, following a specific convention for key names (_arg1
,_arg2
, etc.). - A key
script
with a value that contains the Python code (one or more lines). Any references to the parameter names will be replaced by their values according todata
.
Example request:
POST /evaluate HTTP/1.1
Host: localhost:9004
Accept: application/json
{"data": {"_arg1": 1, "_arg2": 2}, "script": "return _arg1+_arg2"}
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
3
Using curl:
curl -X POST http://localhost:9004/evaluate \
-d '{"data": {"_arg1": 1, "_arg2": 2}, "script": "return _arg1 + _arg2"}'
It is possible to call a deployed function from within the code block, through the predefined function tabpy.query
. This function works like the client library's query
method, and returns the corresponding data structure. The function must first be deployed as an endpoint in the server (for more details see the client documentation).
The following example calls the endpoint clustering
as it was deployed in the section deploy-function:
POST /evaluate HTTP/1.1
Host: example.com
Accept: application/json
{ "data":
{ "_arg1": [6.35, 6.40, 6.65, 8.60, 8.90, 9.00, 9.10],
"_arg2": [1.95, 1.95, 2.05, 3.05, 3.05, 3.10, 3.15]
},
"script": "return tabpy.query('clustering', x=_arg1, y=_arg2)"}
The next example shows how to call evaluate
from a terminal using curl; this code queries the method add
that was deployed in the section deploy-function:
curl -X POST http://localhost:9004/evaluate \
-d '{"data": {"_arg1":1, "_arg2":2},
"script": "return tabpy.query(\"add\", x=_arg1, y=_arg2)[\"response\"]"}'
Executes a function at the specified endpoint. The function must first be deployed (see the client documentation).
This interface expects a JSON body with a data
key, specifying the values for the function, according to its original definition. In the example below, the function clustering
was defined with a signature of two parameters x
and y
, expecting arrays of numbers.
Example request:
POST /query/clustering HTTP/1.1
Host: localhost:9004
Accept: application/json
{"data": {
"x": [6.35, 6.40, 6.65, 8.60, 8.90, 9.00, 9.10],
"y": [1.95, 1.95, 2.05, 3.05, 3.05, 3.10, 3.15]}}
Example response:
HTTP/1.1 200 OK
Content-Type: application/json
{"model": "clustering", "version": 1, "response": [0, 0, 0, 1, 1, 1, 1],
"uuid": "46d3df0e-acca-4560-88f1-67c5aedeb1c4"}
Using curl:
curl -X GET http://localhost:9004/query/clustering -d \
'{"data": {"x": [6.35, 6.40, 6.65, 8.60, 8.90, 9.00, 9.10],
"y": [1.95, 1.95, 2.05, 3.05, 3.05, 3.10, 3.15]}}'