stackout / kubernetes-client
A simple yet elegant client for accessing and controlling a Kubernetes cluster.
0.16
2019-11-03 21:22 UTC
Requires
- php: >=5.4
- flow/jsonpath: ~0.4
- guzzlehttp/guzzle: ~6.0
- illuminate/support: >=5.0
- ratchet/pawl: ~0.3
Requires (Dev)
- mockery/mockery: ~1.2
- php-coveralls/php-coveralls: ~2.0
- phpunit/phpunit: ~7.0
- dev-master
- 0.16
- 0.16.0-rc12
- 0.16.0-rc11
- 0.16.0-rc10
- 0.16.0-rc8
- 0.16.0-rc7
- 0.16.0-rc6
- 0.16.0-rc5
- 0.16.0-rc4
- 0.16.0-rc3
- 0.16.0-rc2
- 0.16.0-rc1
- 0.15.0
- 0.14.3
- 0.14.2
- 0.14.1
- 0.14.0
- 0.13.0
- 0.12.1
- 0.12.0
- 0.11.0
- 0.10.0
- 0.9.1
- 0.9.0
- 0.8.1
- 0.8.0
- 0.7.0
- 0.6.0
- 0.5.1
- 0.5.0
- 0.4.2
- 0.4.1
- 0.4.0
- 0.3.0
- 0.2.5
- 0.2.4
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- 0.0.10
- 0.0.9
- 0.0.8
- 0.0.7
- 0.0.6
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- 0.0.1
- dev-revert-23-master
This package is not auto-updated.
Last update: 2026-03-17 19:01:03 UTC
README
A PHP client for managing a Kubernetes cluster.
Last tested with v1.9.6 on a production cloud hosted cluster.
Installation using Composer
$ composer require maclof/kubernetes-client
Supported API Features
v1
- Nodes
- Namespaces
- Pods
- Replica Sets
- Replication Controllers
- Services
- Secrets
- Events
- Config Maps
- Endpoints
- Persistent Volume
- Persistent Volume Claims
batch/v1
- Jobs
batch/v1beta1
- Cron Jobs
apps/v1
- Deployments
extensions/v1beta1
- Daemon Sets
- Ingresses
traefik.containo.us/v1alpha1
- IngressRouteTCPs
- IngressRoutes
- Middlewares
networking.k8s.io/v1
- Network Policies
Basic Usage
<?php
require __DIR__ . '/vendor/autoload.php';
use Maclof\Kubernetes\Client;
$client = new Client([
'master' => 'http://master.mycluster.com',
]);
// Find pods by label selector
$pods = $client->pods()->setLabelSelector([
'name' => 'test',
'version' => 'a',
])->find();
// Find pods by field selector
$pods = $client->pods()->setFieldSelector([
'metadata.name' => 'test',
])->find();
// Find first pod with label selector (same for field selector)
$pod = $client->pods()->setLabelSelector([
'name' => 'test',
])->first();
Using JSONPath
It allows you to query status data.
$jobStartTime = $client->jobs()->find()->getJsonPath('$.status.startTime')[0];
Authentication Examples
Insecure HTTP
$client = new Client([
'master' => 'http://master.mycluster.com',
]);
Using TLS Certificates (Client Certificate Validation)
$client = new Client([
'master' => 'https://master.mycluster.com',
'ca_cert' => '/etc/kubernetes/ssl/ca.crt',
'client_cert' => '/etc/kubernetes/ssl/client.crt',
'client_key' => '/etc/kubernetes/ssl/client.key',
]);
Using Basic Auth
$client = new Client([
'master' => 'https://master.mycluster.com',
'username' => 'admin',
'password' => 'abc123',
]);
Using a Service Account
$client = new Client([
'master' => 'https://master.mycluster.com',
'ca_cert' => '/var/run/secrets/kubernetes.io/serviceaccount/ca.crt',
'token' => '/var/run/secrets/kubernetes.io/serviceaccount/token',
]);
Extending a library
Custom repositories
$repositories = new RepositoryRegistry();
$repositories['things'] = MyApp\Kubernetes\Repository\ThingRepository;
$client = new Client([
'master' => 'https://master.mycluster.com','
], $repositories);
$client->things() //ThingRepository
Usage Examples
Create/Update a Replication Controller
use Maclof\Kubernetes\Models\ReplicationController;
$replicationController = new ReplicationController([
'metadata' => [
'name' => 'nginx-test',
'labels' => [
'name' => 'nginx-test',
],
],
'spec' => [
'replicas' => 1,
'template' => [
'metadata' => [
'labels' => [
'name' => 'nginx-test',
],
],
'spec' => [
'containers' => [
[
'name' => 'nginx',
'image' => 'nginx',
'ports' => [
[
'containerPort' => 80,
'protocol' => 'TCP',
],
],
],
],
],
],
],
]);
if ($client->replicationControllers()->exists($replicationController->getMetadata('name'))) {
$client->replicationControllers()->update($replicationController);
} else {
$client->replicationControllers()->create($replicationController);
}
Delete a Replication Controller
$replicationController = $client->replicationControllers()->setLabelSelector([
'name' => 'nginx-test',
])->first();
$client->replicationControllers()->delete($replicationController);
You can also specify options when performing a deletion, eg. to perform cascading delete
use Maclof\Kubernetes\Models\DeleteOptions;
$client->replicationControllers()->delete(
$replicationController,
new DeleteOptions(['propagationPolicy' => 'Background'])
);
See the API documentation for an explanation of the options:
https://kubernetes.io/docs/api-reference/v1.6/#deleteoptions-v1-meta