keboola / job-queue-api-php-client
Job队列API客户端
10.7.0
2022-06-08 12:41 UTC
Requires
- php: ^7.4|^8.0
- ext-json: *
- guzzlehttp/guzzle: ^6.3|^7.2
- psr/log: ^1.1
- symfony/config: ^4.4|^5.2
- symfony/validator: ^4.4|^5.2 !=4.4.33 !=4.4.34 !=5.3.10 !=5.3.11
Requires (Dev)
- infection/infection: ^0.18.2|^0.21.2
- keboola/coding-standard: ^13.0
- keboola/storage-api-client: ^12.0
- php-parallel-lint/php-parallel-lint: ^1.2
- phpstan/phpstan: ^1.4
- phpunit/phpunit: ^9.5
- dev-main
- 10.7.0
- 3.2.0
- 3.1.0
- 3.0.1
- 3.0.0
- 2.4.0
- 2.3.0
- 2.2.0
- 2.1.0
- 2.0.0
- 1.0.0
- 0.5.0
- 0.4.1
- 0.4.0
- 0.3.0
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.0
- 0.0.2
- 0.0.1
- dev-jv-fix-search-endpoints-naming
- dev-kacurez-gitops-lab-gar-push-ST-1901
- dev-miro-PST-1343-b
- dev-pepa_PST-1721_searchJobs
- dev-pepa_PST-1902_defaultExecutor
- dev-pepa_PST-777_om
- dev-pepa_PST-884_logs
- dev-pepa_elactic
- dev-pepa_dockerCompose
- dev-adamvyborny-PST-1179-internal-api-elastic-poc
- dev-dependabot/composer/apps/gelf-logger-server/aws/aws-sdk-php-3.304.4
- dev-dependabot/composer/apps/public-api/aws/aws-sdk-php-3.297.3
- dev-dependabot/composer/apps/public-api/symfony/security-http-6.4.4
- dev-dependabot/composer/apps/gelf-logger-server/guzzlehttp/psr7-1.9.1
- dev-dependabot/composer/apps/input-mapping/guzzlehttp/psr7-2.4.5
- dev-erik-GCP-233-phpcs-fixup
- dev-pepa_PST-955_indexHints
- dev-pepa_SOX-253_branchTypeBackfill
- dev-pepa_SOX-253_listBranchJobs
- dev-pepa_SOX-253_newJobFactory
- dev-ujovlado-no-license
- dev-erik-PST-419-try2
- dev-pepa-hackathon
- dev-pepa_gha
- dev-internal-api-php-client-9.x
This package is auto-updated.
Last update: 2024-09-02 12:56:23 UTC
README
PHP客户端,用于Job队列API (API文档)。
使用方法
composer require keboola/job-queue-api-php-client
use Keboola\JobQueueClient\Client; use Keboola\JobQueueClient\JobData;use Psr\Log\NullLogger; $client = new Client( new NullLogger(), 'http://queue.conenection.keboola.com/', 'xxx-xxxxx-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' ); $result = $client->createJob(new JobData( 'keboola.ex-db-snowflake', '123', [], 'run' )); var_dump($result['id']);
开发
-
创建服务主体以下载所需的镜像并登录
SERVICE_PRINCIPAL_NAME=[USERNAME]-job-queue-internal-api-pull ACR_REGISTRY_ID=$(az acr show --name keboolapes --query id --output tsv --subscription c5182964-8dca-42c8-a77a-fa2a3c6946ea) SP_PASSWORD=$(az ad sp create-for-rbac --name http://$SERVICE_PRINCIPAL_NAME --scopes $ACR_REGISTRY_ID --role acrpull --query password --output tsv) SP_APP_ID=$(az ad sp show --id http://$SERVICE_PRINCIPAL_NAME --query appId --output tsv)
-
登录并检查是否可以拉取镜像
docker login keboolapes.azurecr.io --username $SP_APP_ID --password $SP_PASSWORD docker pull keboolapes.azurecr.io/job-queue-internal-api:latest docker pull keboolapes.azurecr.io/job-queue-api:latest
-
将凭据添加到k8s集群
kubectl create secret docker-registry regcred --docker-server="https://keboolapes.azurecr.io" --docker-username="$SP_APP_ID" --docker-password="$SP_PASSWORD" --namespace dev-job-queue-api-php-client kubectl patch serviceaccount default -p "{\"imagePullSecrets\":[{\"name\":\"regcred\"}]}" --namespace dev-job-queue-api-php-client
-
在
set-env.sh
文件中设置以下环境变量(使用set-env.template.sh
作为示例)test_storage_api_url
- Keboola连接URL。test_storage_api_token
- 测试项目的令牌。
-
设置Azure或AWS资源之一(或两者,但只需要一个)。
AWS设置
- 使用
provisioning/aws.json
CF模板创建用于本地开发的用户(JobQueueApiPhpClient
)。- 为创建的用户创建AWS密钥。
- 在
set-env.sh
文件中设置以下环境变量(使用set-env.template.sh
作为示例)test_aws_access_key_id
- 为JobQueueApiPhpClient
用户创建的安全凭据。test_aws_secret_access_key
- 为JobQueueApiPhpClient
用户创建的安全凭据。test_kms_region
- 上一个堆栈的Region
输出。test_kms_key_id
- 上一个堆栈的KmsKey
输出。
Azure设置
-
创建资源组
az account set --subscription "Keboola DEV PS Team CI" az group create --name testing-job-queue-api-php-client --location "East US"
-
创建服务主体
az ad sp create-for-rbac --name testing-job-queue-api-php-client
-
使用响应设置
test_azure_client_id
、test_azure_client_secret
和test_azure_tenant_id
的值在set-env.sh
文件中{ "appId": "268a6f05-xxxxxxxxxxxxxxxxxxxxxxxxxxx", //-> test_azure_client_id "displayName": "testing-job-queue-internal-api-php-client", "name": "http://testing-job-queue-internal-api-php-client", "password": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", //-> test_azure_client_secret "tenant": "9b85ee6f-xxxxxxxxxxxxxxxxxxxxxxxxxxx" //-> test_azure_tenant_id }
-
获取服务主体的ID
SERVICE_PRINCIPAL_ID=$(az ad sp list --display-name testing-job-queue-api-php-client --query "[0].objectId" --output tsv)
-
部署密钥保管库,提供来自上一条命令的租户ID、服务主体ID和组ID
./set-env.sh # set $test_azure_tenant_id env az deployment group create --resource-group testing-job-queue-api-php-client --template-file provisioning/azure.json --parameters vault_name=test-job-queue-client tenant_id=$test_azure_tenant_id service_principal_object_id=$SERVICE_PRINCIPAL_ID
-
显示密钥保管库URL
az keyvault show --name test-job-queue-client --query "properties.vaultUri" --output tsv
返回例如https://test-job-queue-client.vault.azure.net/
,使用此URL在set-env.sh
文件中设置值:- test_azure_key_vault_url
- https://test-job-queue-client.vault.azure.net/
生成环境配置
export db_password="cm9vdA==" #root export db_password_urlencoded="cm9vdA==" export test_azure_client_secret_base64=$(printf "%s" "$test_azure_client_secret"| base64 --wrap=0) export test_aws_secret_access_key_base64=$(printf "%s" "$test_aws_secret_access_key"| base64 --wrap=0) ./set-env.sh envsubst < provisioning/environments.yaml.template > provisioning/environments.yaml kubectl apply -f ./provisioning/environments.yaml kubectl apply -f ./provisioning/public-api.yaml queue_public_api_ip=`kubectl get svc --output jsonpath --template "{.items[?(@.metadata.name==\"dev-job-queue-api-service\")].status.loadBalancer.ingress[].ip}" --namespace=dev-job-queue-api-php-client` echo "queue_public_api_url: http://$(queue_public_api_ip):94"
将结果queue_public_api_ip
存储在set-env.sh
中。
运行测试
-
使用上述设置,您可以运行测试
docker compose build source ./set-env.sh && docker compose run tests
-
要使用本地代码运行测试,请使用
docker compose run tests-local composer install source ./set-env.sh && docker compose run tests-local
许可证
MIT许可,请参阅LICENSE文件。