The IBM watsonx.data destination connector relies on an Apache Iceberg-based catalog within the watsonx.data data store instance.
Apache Iceberg is suitable for managed data storage and cataloging, but not for embedding storage or semantic similarity
queries. For embedding storage and semantic similarity queries, Unstructured recommends that you use the following destination connectors
instead:
- An IBM Cloud account. Create an IBM Cloud account if you do not already have one.
- 
An API key for the IBM Cloud account. If you do not have one already, create one as follows:
- Log in to your IBM Cloud account.
- In the top navigation bar, click Manage and then, under Security and access, click Access (IAM).
- On the sidebar, under Manage identities, click API keys.
- With the View list showing My IBM Cloud API keys, click Create.
- Enter some Name and an optional Description for the API key.
- Leave Leaked action set to Disable the leaked key and Session management set to No.
- Click Create.
- Click Copy or Download to copy or save the API key to a secure location. You won’t be able to access this API key from this screen again.
 
- 
An IBM Cloud Object Storage (COS) instance in the account, and a bucket within that instance. If you do not have them already,
create them as follows:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- Click Create resource.
- With IBM Cloud catalog selected, search for and select Object Storage.
- Complete the on-screen instructions to finish creating the COS instance.
- With the COS instance’s settings page shown, on the Buckets tab, click Create bucket.
- Complete the on-screen instructions to finish creating the bucket.
 
- 
The name, region, and public endpoint for the target bucket within the target Cloud Object Storage (COS) instance. To get these:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Storage, and then click the target COS instance.
- On the Buckets tab, click the target bucket.
- 
On the Configuration tab, note the following:
- Under Bucket details, note the Bucket name. This is the bucket’s name.
- Under Bucket details section, note the value inside of the parentheses inside Location, for example us-east. This is the bucket’s region.
- Under Endpoints, note the value of Public, for example s3.us-east.cloud-object-storage.appdomain.cloud. (Ignore the values of Private and Direct). This is the bucket’s public endpoint.
 
 
- 
An HMAC access key ID and secret access key for the target Cloud Object Storage (COS) instance. If you do not have them already,
get or create them as follows:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Storage, and then click the target COS instance.
- 
On the Service credentials tab, if there is a credential that you want to use in the list, expand the credential, and copy the following values to a secure location:
- access_key_idunder- cos_hmac_keys, which represents the HMAC access key ID.
- secret_access_keyunder- cos_hmac_keys, which represents the HMAC secret access key.
 
- If there is not a credential that you want to use, or there are no credentials at all, click New Credential.
- Enter some Name for the credential.
- For Role, select at least Writer, leave Select Service ID set to Auto Generated, switch on Include HMAC Credential, and then click Add.
- 
In the list of credentials, expand the credential, and copy the following values to a secure location:
- access_key_idunder- cos_hmac_keys, which represents the HMAC access key ID.
- secret_access_keyunder- cos_hmac_keys, which represents the HMAC secret access key.
 
 
- 
An IBM watsonx.data data store instance in the IBM Cloud account. If you do not have one already, create one as follows:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- Click Create resource.
- With IBM Cloud catalog selected, search for and select watsonx.data.
- Complete the on-screen instructions to finish creating the watsonx.data data store instance.
 
- 
An Apache Iceberg-based catalog within the watsonx.data data store instance. If you do not have one already, create one as follows:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Databases, and then click the target watsonx.data data store instance.
- Click Open web console.
- If prompted, log in to the web console.
- On the sidebar, click Infrastructure manager. If the sidebar is not visible, click the Global navigation icon to the far left of the top navigation bar.
- Click Add component.
- Under Storage, click IBM Cloud Object Storage, and then click Next.
- 
Complete the on-screen instructions to finish creating the Iceberg catalog. This includes providing the following settings:
If you select Discover COS instance, you must provide the following settings:
- The name of the target COS instance.
- The name of the target storage object (such as the target bucket) within the COS instance.
- Some display name for the component.
- 
After you provide this information, do the following:
a. Check the box labelled Associate Catalog.
 b. For Catalog type, select Apache Iceberg.
 c. Enter some Catalog name.
 d. Click Associate.
 
 - Some display name for the component.
- The name of the target bucket within the target Cloud Object Storage (COS) instance that you noted earlier.
- The region for the target bucket, which you noted earlier.
- 
The public endpoint for the target bucket, which you noted earlier. For this screen only, be sure to prefix the public endpoint with https://.
- The HMAC access key ID for the target COS instance, which you noted earlier.
- The HMAC secret access key for the target COS instance, which you noted earlier.
- 
After you provide this information, do the following:
a. Check the box labelled Associate Catalog.
 b. For Catalog type, select Apache Iceberg.
 c. Enter some Catalog name.
 d. Click Associate.
 
 
- On the sidebar, click Infrastructure manager. Make sure the catalog is associated with the appropriate engines. If it is not, rest your mouse on an unassociated target engine, click the Manage associations icon, check the box next to the target catalog’s name, and then click Save and restart engine. To create an engine if one is not already shown, click Add component, and follow the on-screen to add an appropriate engine from the list of available Engines (for example, an IBM Presto engine).
 
- 
The catalog name and metastore REST endpoint for the target Iceberg catalog. To get this:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Databases, and then click the target watsonx.data data store instance.
- Click Open web console.
- If prompted, log in to the web console.
- On the sidebar, click Infrastructure manager. If the sidebar is not visible, click the Global navigation icon to the far left of the top navigation bar.
- In the Catalogs section, click the target Iceberg catalog.
- On the Details tab, note the value of Name representing the catalog name, and Metastore REST endpoint representing the metastore REST endpoint. (Ignore the Metastore Thrift endpoint value.)
 
- 
A namespace (also known as a schema) and a table in the target catalog. If you do not have these already, create them as follows:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Databases, and then click the target watsonx.data data store instance.
- Click Open web console.
- If prompted, log in to the web console.
- On the sidebar, click Data manager. If the sidebar is not visible, click the Global navigation icon to the far left of the top navigation bar.
- On the Browse data tab, under Catalogs associated, click the target catalog.
- Click the ellipses, and then click Create schema.
- Enter some Name for the schema, and then click Create.
- On the sidebar, click Query workspace.
- 
In the SQL editor, enter and run a table creation statement such as the following one that uses
Presto SQL syntax, replacing <catalog-name>with the name of the target catalog and<schema-name>with the name of the target schema:Incoming elements that do not have matching column names will be dropped upon record insertion. For example, if the incoming data has an element namedsent_fromand there is no column namedsent_fromin the table, thesent_fromelement will be dropped upon record insertion. You should modify the preceding sample table creation statement to add columns for any additional elements that you want to be included upon record insertion. To increase query performance, Iceberg uses hidden partitioning to group similar rows together when writing. You can also explicitly define partitions as part of the precedingCREATE TABLEstatement.
 
- 
The name of the target namespace (also known as a schema) within the target catalog, and name of the target table within that schema. To get these:
- Log in to your IBM Cloud account.
- On the sidebar, click the Resource list icon. If the sidebar is not visible, click the Navigation Menu icon to the far left of the top navigation bar.
- In the list of resources, expand Databases, and then click the target watsonx.data data store instance.
- Click Open web console.
- If prompted, log in to the web console.
- On the sidebar, click Data manager. If the sidebar is not visible, click the Global navigation icon to the far left of the top navigation bar.
- On the Browse data tab, expand the name of the target catalog, and note the names of the target schema and target table.
 
- The name of the column in the target table that uniquely identifies each of the records in the table.
- 
To improve performance, the target table should be set to regularly remove old metadata files. To do this, run the following Python script.
(You cannot use the preceding CREATE TABLEstatement, or other SQL statements such asALTER TABLE, to set this behavior.) To get the values for the specified environment variables, see the preceding instructions.
CLI, Python
- IBM_IAM_API_KEY- An API key for the target IBM Cloud account, represented by- --iam-api-key(CLI) or- iam_api_key(Python).
- IBM_COS_ACCESS_KEY- An HMAC access key ID for the target IBM Cloud Object Storage (COS) instance, represented by- --access-key-id(CLI) or- access_key_id(Python).
- IBM_COS_SECRET_ACCESS_KEY- The associated HMAC secret access key ID for the target HMAC access key, represented by- --secret-access-key(CLI) or- secret_access_key(Python).
- IBM_ICEBERG_CATALOG_METASTORE_REST_ENDPOINT- The metastore REST endpoint value for the target Apache Iceberg catalog in the target IBM watsonx.data data store instance, represented by- --iceberg-endpoint(CLI) or- iceberg_endpoint(Python). Do not include- https://in this value.
- IBM_COS_BUCKET_PUBLIC_ENDPOINT- The target COS instance’s endpoint value, represented by- --object-storage-endpoint(CLI) or- object_storage_endpoint(Python).
- IBM_COS_BUCKET_REGION- The target COS instance’s region short ID, represented by- --object-storage-region(CLI) or- object_storage_region(Python).
- IBM_ICEBERG_CATALOG- The name of the target Iceberg catalog, represented by- --catalog(CLI) or- catalog(Python).
- IBM_ICEBERG_SCHEMA- The name of the target namespace (also known as a schema) in the target catalog, represented by- --namespace(CLI) or- namespace(Python).
- IBM_ICEBERG_TABLE- The name of the target table in the target schema, represented by- --table(CLI) or- table(Python).
- IBM_ICEBERG_TABLE_UNIQUE_RECORD_COLUMN- The name of the column that uniquely identifies each record in the target table, represented by- --record-id-key(CLI) or- record_id_key(Python). The default is- record_id.
- --max-retries-connection(CLI) or- max_retries_connection(Python) is an optional parameter that specifies the maximum number of retries when connecting to the catalog. Typically, an optimal setting is- 15. The default is- 10. If specified, it must be a number between- 2and- 100, inclusive.
- --max-retries(CLI) or- max_retries(Python) is an optional parameter that specifies the number of times to retry uploading data. Typically, an optimal setting is- 150. The default is- 50. If specified, it must be a number between- 2and- 500, inclusive.
--partition-by-api option (CLI) or partition_by_api (Python) parameter to specify where files are processed:
- 
To do local file processing, omit --partition-by-api(CLI) orpartition_by_api(Python), or explicitly specifypartition_by_api=False(Python). Local file processing does not use an Unstructured API key or API URL, so you can also omit the following, if they appear:- --api-key $UNSTRUCTURED_API_KEY(CLI) or- api_key=os.getenv("UNSTRUCTURED_API_KEY")(Python)
- --partition-endpoint $UNSTRUCTURED_API_URL(CLI) or- partition_endpoint=os.getenv("UNSTRUCTURED_API_URL")(Python)
- The environment variables UNSTRUCTURED_API_KEYandUNSTRUCTURED_API_URL
 
- 
To send files to the Unstructured Partition Endpoint for processing, specify --partition-by-api(CLI) orpartition_by_api=True(Python). Unstructured also requires an Unstructured API key and API URL, by adding the following:- --api-key $UNSTRUCTURED_API_KEY(CLI) or- api_key=os.getenv("UNSTRUCTURED_API_KEY")(Python)
- --partition-endpoint $UNSTRUCTURED_API_URL(CLI) or- partition_endpoint=os.getenv("UNSTRUCTURED_API_URL")(Python)
- The environment variables UNSTRUCTURED_API_KEYandUNSTRUCTURED_API_URL, representing your API key and API URL, respectively.
 You must specify the API URL only if you are not using the default API URL for Unstructured Ingest, which applies to Starter and Team accounts.The default API URL for Unstructured Ingest ishttps://api.unstructuredapp.io/general/v0/general, which is the API URL for the Unstructured Partition Endpoint. However, you should always use the URL that was provided to you when your Unstructured account was created. If you do not have this URL, email Unstructured Support at support@unstructured.io.If you do not have an API key, get one now.If you are using an Enterprise account, the process for generating Unstructured API keys, and the Unstructured API URL that you use, are different. For instructions, see your Unstructured account administrator, or email Unstructured Support at support@unstructured.io.

