Created
December 5, 2016 23:21
-
-
Save tcotav/46c243f5c4b4178d6e5d0a1da498f553 to your computer and use it in GitHub Desktop.
kube-apiserver.manifest with audit logging turned on AND writing to a volume in /var/log
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| # Set amount of memory available for apiserver based on number of nodes. | |
| # TODO: Once we start setting proper requests and limits for apiserver | |
| # we should reuse the same logic here instead of current heuristic. | |
| # test_args has to be kept at the end, so they'll overwrite any prior configuration | |
| { | |
| "apiVersion": "v1", | |
| "kind": "Pod", | |
| "metadata": { | |
| "name":"kube-apiserver", | |
| "namespace": "kube-system", | |
| "labels": { | |
| "tier": "control-plane", | |
| "component": "kube-apiserver" | |
| } | |
| }, | |
| "spec":{ | |
| "hostNetwork": true, | |
| "containers":[ | |
| { | |
| "name": "kube-apiserver", | |
| "image": "gcr.io/google_containers/kube-apiserver:92281f8c841048a50cd5d2da0dcc8422", | |
| "resources": { | |
| "requests": { | |
| "cpu": "250m" | |
| } | |
| }, | |
| "command": [ | |
| "/bin/sh", | |
| "-c", | |
| "/usr/local/bin/kube-apiserver --address=127.0.0.1 --storage-backend= --etcd-servers=http://127.0.0.1:2379 --etcd-servers-overrides=/events#http://127.0.0.1:4002 --cloud-provider=aws --admission-control=NamespaceLifecycle,LimitRanger,ServiceAccount,PersistentVolumeLabel,DefaultStorageClass,ResourceQuota --target-ram-mb=120 --service-cluster-ip-range=10.0.0.0/16 --client-ca-file=/srv/kubernetes/ca.crt --basic-auth-file=/srv/kubernetes/basic_auth.csv --tls-cert-file=/srv/kubernetes/server.cert --tls-private-key-file=/srv/kubernetes/server.key --secure-port=443 --token-auth-file=/srv/kubernetes/known_tokens.csv --v=2 --audit-log-path=/var/log/kube-audit/audit.log --audit-log-maxage=30 --audit-log-maxsize=300 --authorization-mode=ABAC --authorization-policy-file=/srv/kubernetes/abac-authz-policy.jsonl --allow-privileged=True 1>>/var/log/kube-apiserver.log 2>&1" | |
| ], | |
| "livenessProbe": { | |
| "httpGet": { | |
| "host": "127.0.0.1", | |
| "port": 8080, | |
| "path": "/healthz" | |
| }, | |
| "initialDelaySeconds": 15, | |
| "timeoutSeconds": 15 | |
| }, | |
| "ports":[ | |
| { "name": "https", | |
| "containerPort": 443, | |
| "hostPort": 443},{ | |
| "name": "local", | |
| "containerPort": 8080, | |
| "hostPort": 8080} | |
| ], | |
| "volumeMounts": [ | |
| {"name": "usrsharessl","mountPath": "/usr/share/ssl", "readOnly": true}, {"name": "usrssl","mountPath": "/usr/ssl", "readOnly": true}, {"name": "usrlibssl","mountPath": "/usr/lib/ssl", "readOnly": true}, {"name": "usrlocalopenssl","mountPath": "/usr/local/openssl", "readOnly": true}, | |
| { "name": "srvkube", | |
| "mountPath": "/srv/kubernetes", | |
| "readOnly": true}, | |
| { "name": "logfile", | |
| "mountPath": "/var/log/kube-apiserver.log", | |
| "readOnly": false}, | |
| { "name": "auditlog", | |
| "mountPath": "/var/log/kube-audit", | |
| "readOnly": false}, | |
| { "name": "etcssl", | |
| "mountPath": "/etc/ssl", | |
| "readOnly": true}, | |
| { "name": "varssl", | |
| "mountPath": "/var/ssl", | |
| "readOnly": true}, | |
| { "name": "etcopenssl", | |
| "mountPath": "/etc/openssl", | |
| "readOnly": true}, | |
| { "name": "etcpki", | |
| "mountPath": "/etc/pki", | |
| "readOnly": true}, | |
| { "name": "srvsshproxy", | |
| "mountPath": "/srv/sshproxy", | |
| "readOnly": false} | |
| ] | |
| } | |
| ], | |
| "volumes":[ | |
| {"name": "usrsharessl","hostPath": {"path": "/usr/share/ssl"}}, {"name": "usrssl","hostPath": {"path": "/usr/ssl"}}, {"name": "usrlibssl","hostPath": {"path": "/usr/lib/ssl"}}, {"name": "usrlocalopenssl","hostPath": {"path": "/usr/local/openssl"}}, | |
| { "name": "srvkube", | |
| "hostPath": { | |
| "path": "/srv/kubernetes"} | |
| }, | |
| { "name": "logfile", | |
| "hostPath": { | |
| "path": "/var/log/kube-apiserver.log"} | |
| }, | |
| { "name": "auditlog", | |
| "hostPath": { | |
| "path": "/var/log/kube-audit"} | |
| }, | |
| { "name": "etcssl", | |
| "hostPath": { | |
| "path": "/etc/ssl"} | |
| }, | |
| { "name": "varssl", | |
| "hostPath": { | |
| "path": "/var/ssl"} | |
| }, | |
| { "name": "etcopenssl", | |
| "hostPath": { | |
| "path": "/etc/openssl"} | |
| }, | |
| { "name": "etcpki", | |
| "hostPath": { | |
| "path": "/etc/pki"} | |
| }, | |
| { "name": "srvsshproxy", | |
| "hostPath": { | |
| "path": "/srv/sshproxy"} | |
| } | |
| ] | |
| }} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment