sz-sdk-python-grpc
If you are beginning your journey with Senzing,
please start with Senzing Quick Start guides.
You are in the Senzing Garage where projects are "tinkered" on.
Although this GitHub repository may help you understand an approach to using Senzing,
it's not considered to be "production ready" and is not considered to be part of the Senzing product.
Heck, it may not even be appropriate for your application of Senzing!
:warning: WARNING: sz-sdk-python-grpc is still in development :warning: _
At the moment, this is "work-in-progress" with Semantic Versions of 0.n.x
.
Although it can be reviewed and commented on,
the recommendation is not to use it yet.
Synopsis
The Senzing sz-sdk-python-grpc
package provides a Python Software Development Kit
adhering to the abstract classes of sz-sdk-python-abstract
that communicates with a Senzing gRPC server.
[![License Badge]][License]
Overview
The Senzing sz-sdk-python-grpc
packages enable Python programs to call Senzing library functions
across a network to a Senzing gRPC server.
The sz-sdk-python-grpc
package implements the following sz-sdk-python-abstract interfaces:
- SzConfigAbstract
- SzConfigMgrAbstract
- SzDiagnosticAbstract
- SzEngineAbstract
- SzProductAbstract
Other implementations of the sz-sdk-python-abstract interface include:
Use
The following example shows how to start a Senzing gRPC server Docker container
and access it using the senzing_grpc
Python package.
-
Install the senzing-grpc
Python package.
Example:
python3 -m pip install --upgrade senzing-grpc
-
Run a Senzing gRPC service using Docker.
Example:
docker run \
--env SENZING_TOOLS_COMMAND=serve-grpc \
--env SENZING_TOOLS_DATABASE_URL=sqlite3://na:na@nowhere/tmp/sqlite/G2C.db \
--env SENZING_TOOLS_ENABLE_ALL=true \
--name senzing-tools-serve-grpc \
--publish 8261:8261 \
--pull always \
--rm \
senzing/senzing-tools
Note: In this example, SENZING_TOOLS_DATABASE_URL
specifies a file inside the container.
Thus the database is temporal and will be deleted when the container is killed.
-
In a separate window, start an interactive Python session.
Example:
python3
-
Paste the following into the interactive Python session.
Example:
import grpc
from senzing_grpc import SzAbstractFactory
sz_abstract_factory = SzAbstractFactory(grpc_channel=grpc.insecure_channel("localhost:8261"))
sz_product = sz_abstract_factory.create_sz_product()
print(sz_product.get_version())
More can be seen in Examples.
References
- Development
- Errors
- Examples
- Related artifacts:
- DockerHub
- sz-sdk-python-abstract package reference