{"id":43696,"date":"2023-03-07T13:22:26","date_gmt":"2022-12-15T18:46:46","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/"},"modified":"2024-04-29T17:47:06","modified_gmt":"2024-04-29T09:47:06","slug":"%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/","title":{"rendered":"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01"},"content":{"rendered":"<p>Iter8\u662f\u4e00\u4e2a\u5de5\u5177\uff0c\u901a\u8fc7\u4e0eIstio\u96c6\u6210\uff0c\u652f\u6301\u9010\u6b65\u5c06\u65b0\u7248\u672c\u90e8\u7f72\u5230\u751f\u4ea7\u73af\u5883\u4e2d\u3002\u5b83\u57fa\u4e8ePrometheus\u6307\u6807\u8fdb\u884c\u6761\u4ef6\u8bbe\u7f6e\uff0c\u5728\u6bcf\u4e2a\u8bbe\u7f6e\u7684\u8fed\u4ee3\u7ed3\u675f\u65f6\u901a\u8fc7\u6e05\u9664\u6761\u4ef6\u6765\u9010\u6b65\u589e\u52a0\u6d41\u91cf\u5206\u914d\u5230\u65b0\u7248\u672c\uff0c\u4ece\u800c\u5b9e\u73b0\u9010\u6b65\u5347\u7ea7\u5230\u65b0\u7248\u672c\u3002\u5982\u679c\u5728\u6240\u6709\u8fed\u4ee3\u4e2d\u65e0\u6cd5\u5c06\u6d41\u91cf\u5b8c\u5168\u5207\u6362\u5230\u65b0\u7248\u672c\uff0c\u5219\u53ef\u4ee5\u8f7b\u677e\u81ea\u52a8\u5316\u65e7\u7248\u672c\u7684\u56de\u6eda\uff0c\u6216\u5728\u6ee1\u8db3\u9519\u8bef\u6761\u4ef6\u65f6\u4e2d\u65ad\u548c\u56de\u6eda\u53d1\u5e03\u3002\u56e0\u6b64\uff0c\u7ed3\u5408\u4f7f\u7528Iter8\u548cIstio\u53ef\u4ee5\u66f4\u8f7b\u677e\u5730\u5b9e\u65bd\u57fa\u4e8eB\/G\u6216\u91d1\u4e1d\u96c0\u53d1\u5e03\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/1-0.png\" alt=\"alt\" \/><\/div>\n<h1>\u524d\u63d0<\/h1>\n<ul class=\"post-ul\">Openshift\u306e\u5b9f\u884c\u74b0\u5883\u306fIBM Demo\u306eLab\u74b0\u5883<\/ul>\n<h1>\u8fdb\u884citer8\u5b89\u88c5<\/h1>\n<p>\u5982\u679c\u5728OpenShift\u4e0a\u8fdb\u884c\u5b89\u88c5\uff0c\u5219\u9700\u8981\u4f7f\u7528OpenShift Service Mesh\u800c\u4e0d\u662fistio\uff08istio\u8fbe\u4e0d\u5230\u8981\u6c42\uff09\u3002<br \/>\nhttps:\/\/github.com\/iter8-tools\/docs\/blob\/v0.1.1\/doc_files\/platforms\/redhat_openshift.md<br \/>\n\u5982\u679c\u8981\u6267\u884c\u6559\u7a0b\uff0c\u5219\u9700\u8981\u5728Namespace\u548cProject\u4e2d\u6dfb\u52a0bookinfo-iter8\u3002<\/p>\n<h2>\u5b89\u88c5OpenShift Service Mesh\u3002<\/h2>\n<h3>\u5b89\u88c5Elasticsearch\u8fd0\u7b97\u7b26<\/h3>\n<p>\u7531\u4e8e\u9075\u5faa\u4e86Update channel\u4e0a\u7684\u6b65\u9aa4\u9009\u62e9\u6700\u65b0\u76844.4\u7248\u672c\u8fdb\u884c\u5b89\u88c5\u65f6\u5931\u8d25\u5e76\u5904\u4e8e\u5f85\u5904\u7406\u72b6\u6001\uff0c\u6240\u4ee5\u6211\u9009\u62e9\u4e864.3\u7248\u672c\u6210\u529f\u8fdb\u884c\u4e86\u5b89\u88c5\u3002<\/p>\n<h3>\u5b89\u88c5Jaeger\u8fd0\u7b97\u7b26<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/11-0.png\" alt=\"image.png\" \/><\/div>\n<h3>\u5b89\u88c5 Kiali \u8fd0\u7b97\u7b26\u3002<\/h3>\n<p>\u6309\u7167\u6b65\u9aa4\u8fdb\u884c\uff0c\u6ca1\u6709\u4ec0\u4e48\u7279\u522b\u7684\u95ee\u9898<\/p>\n<h3>\u5b89\u88c5\u7ea2\u5e3dOpenShift\u670d\u52a1\u7f51\u683c\u8fd0\u7b97\u7b26<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/15-0.png\" alt=\"image.png\" \/><\/div>\n<h3>\u90e8\u7f72\u7ea2\u5e3dOpenShift\u670d\u52a1\u7f51\u683c\u7684\u63a7\u5236\u5e73\u9762<\/h3>\n<h4>\u4eceWeb\u63a7\u5236\u53f0\u90e8\u7f72\u63a7\u5236\u5e73\u9762<\/h4>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/18-3.png\" alt=\"image.png\" \/><\/div>\n<h3>\u521b\u5efaRed Hat OpenShift\u670d\u52a1\u7f51\u683c\u6210\u5458\u89d2\u8272<\/h3>\n<h4>\u5728\u7f51\u9875\u63a7\u5236\u53f0\u4e0a\u521b\u5efa\u4f1a\u5458\u540d\u5355<\/h4>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/21-0.png\" alt=\"image.png\" \/><\/div>\n<pre class=\"post-pre\"><code>apiVersion: maistra.io\/v1\r\nkind: ServiceMeshMemberRoll\r\nmetadata:\r\n  name: default\r\n  namespace: istio-system\r\nspec:\r\n  members:\r\n    - bookinfo-iter8\r\n<\/code><\/pre>\n<h4>\u521b\u5efaRed Hat OpenShift\u670d\u52a1\u7f51\u683c\u7684\u6210\u5458<\/h4>\n<p>\u53ea\u6709\u5728\u9700\u8981\u6dfb\u52a0\u7ba1\u7406\u8005\u4ee5\u5916\u7684\u72ec\u7acb\u7528\u6237\u65f6\uff0c\u624d\u4f1a\u5224\u65ad\u5e76\u8df3\u8fc7\u8be5\u6b65\u9aa4\u3002<\/p>\n<h2>\u5b89\u88c5iter8\u3002<\/h2>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u4ee5\u964doc\u30b3\u30de\u30f3\u30c9\u3001kubectl\u30b3\u30de\u30f3\u30c9\u3067\u30af\u30e9\u30b9\u30bf\u30fc\u3068\u306e\u63a5\u7d9a\u304c\u5fc5\u8981\u306a\u306e\u3067Openshift\u3078\u306e\u30ed\u30b0\u30a4\u30f3\u3092\u5b9f\u65bd\u3057\u3066\u304a\u304f<\/ul>\n<\/li>\n<\/ul>\n<p>\u30ed\u30b0\u30a4\u30f3\u30b3\u30de\u30f3\u30c9\u306fOpenshift\u306e\u30b3\u30f3\u30bd\u30fc\u30eb\u304b\u3089\u53f3\u4e0a\u306e\u30e6\u30fc\u30b6\u30fc\u540d\u306e\u30c9\u30ed\u30c3\u30d7\u30c0\u30a6\u30f3\u304b\u3089\u30b3\u30d4\u30fc\u51fa\u6765\u308b<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/27-0.png\" alt=\"image.png\" \/><\/div>\n<h3>\u5b89\u88c5iter8\u5206\u6790\u670d\u52a1<\/h3>\n<p>\u88ab\u8981\u6c42\u4e0b\u8f7d Helm Chart \u7684 tar \u6587\u4ef6\uff0c\u4f46\u662f\u94fe\u63a5\u5931\u6548\u4e14\u5728 Github \u4ed3\u5e93\u4e2d\u4e5f\u4e0d\u5b58\u5728\u8be5 tar \u6587\u4ef6\u3002\u7136\u800c\uff0cHelm Chart \u672c\u8eab\u5728\u4ee5\u4e0b\u7684\u4f4d\u7f6e\u5b58\u5728\uff0c\u56e0\u6b64\u6211\u514b\u9686\u5e76\u4f7f\u7528\u4e86\u5b83\u3002<br \/>\nhttps:\/\/github.com\/iter8-tools\/iter8-analytics\/tree\/master\/install\/kubernetes\/helm\/iter8-analytics<br \/>\n\u7531\u4e8e\u8be5\u4ed3\u5e93\u4e2d\u7684 Helm \u6587\u4ef6\u4e0e\u624b\u518c\u5185\u5bb9\u4e0d\u5339\u914d\uff0c\u6240\u4ee5\u8bf7\u6309\u4ee5\u4e0b\u6b65\u9aa4\u8fdb\u884c\u64cd\u4f5c\u4ee5\u4f7f\u5176\u6b63\u5e38\u5de5\u4f5c\u3002<br \/>\n&#8211; \u83b7\u53d6 Prometheus \u7684\u5bc6\u7801\u3002<\/p>\n<pre class=\"post-pre\"><code>$ PROMETHEUS_PASSWORD=$(kubectl -n istio-system get secret htpasswd -o jsonpath='{.data.rawPassword}' | base64 --decode)\r\n\r\n$ echo $PROMETHEUS_PASSWORD\r\np8aqeFudWKLkzYW3sBGOSo46b9+r8msPNyVG1RWfwBA5HYid74PNhdnjE9Dba3WkNt+BRUmvsSBqIjVZjrYHVfRI\/VPHjgtaTyjnLK+OsT7h2ShXkOP7uakJM987zH9EQsrgd3pSYUadFyMoHUhGY7Yp7ok\/jbG5xAPL4bSYJJxNX9yxRfoT3+Du2kIDQdb65Ik0+z\/lavmymum6byzRLHI4MXJYvWtGjkdIkpQrP5I1IJ+aUur9VcV\/MN+dN3TF\/\/tWBkzWQroJnhtbXBJb+0YLxIc1EGQroYzUGPFgDTmlG+2sYhHO3PdNPT6Ge6PZFb4w3FfjdiAxfpQ5s0XS\r\n<\/code><\/pre>\n<ul class=\"post-ul\">Helm\u306b\u6e21\u3059\u305d\u306e\u4ed6\u306e\u74b0\u5883\u5909\u6570\u3092\u8a2d\u5b9a<\/ul>\n<pre class=\"post-pre\"><code>$ REPO=iter8\/iter8-analytics\r\n\r\n$ PROMETHEUS_SERVICE='https:\/\/prometheus.istio-system:9090'\r\n\r\n$ PROMETHEUS_USERNAME='internal'\r\n\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Helm\u306e\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u304b\u3089\u751f\u6210\u3055\u308c\u308byaml\u306e\u5185\u5bb9\u3092\u78ba\u8a8d\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>ConfigMap\u306econfig.yaml\u306emetricBackend\u914d\u4e0b\u306e\u4ee5\u4e0b\u306e\u9805\u76ee\u304c\u6b63\u3057\u304f\u8a2d\u5b9a\u3055\u308c\u3066\u3044\u308b\u3053\u3068<\/p>\n<div>\n<div class=\"post-table\">\u9805\u76ee\u540d\u5024url\u74b0\u5883\u5909\u6570PROMETHEUS_SERVICE\u3067\u8a2d\u5b9a\u3057\u305f\u5024(https\u3067\u3042\u308b\u3053\u3068)insecure_skip_verifytruepassword\u74b0\u5883\u5909\u6570PROMETHEUS_PASSWORD\u3067\u8a2d\u5b9a\u3057\u305f\u5024typebasicusername\u74b0\u5883\u5909\u6570PROMETHEUS_USERNAME\u3067\u8a2d\u5b9a\u3057\u305f\u5024<\/div>\n<\/div>\n<p>\u8bf7\u63d0\u4f9b\u4e00\u4e2a\u4e2d\u56fd\u4eba\u7684\u6bcd\u8bed\u7684\u7684\u9009\u9879<\/p>\n<pre class=\"post-pre\"><code>helm template install\/kubernetes\/helm\/iter8-analytics \\\r\n    --name iter8-analytics \\\r\n    --set image.repository=${REPO} \\\r\n    --set image.tag=v0.1.1 \\\r\n    --set metricsBackend.authentication.type=basic \\\r\n    --set metricsBackend.authentication.username=${PROMETHEUS_USERNAME} \\\r\n    --set metricsBackend.authentication.password=${PROMETHEUS_PASSWORD} \\\r\n    --set metricsBackend.authentication.insecure_skip_verify=true \\\r\n    --set metricsBackend.url=${PROMETHEUS_SERVICE} \\\r\n<\/code><\/pre>\n<p>\u6700\u7ec8\u7ed3\u679c\uff1a<\/p>\n<pre class=\"post-pre\"><code>$ helm template install\/kubernetes\/helm\/iter8-analytics \\\r\n&gt;     --name iter8-analytics \\\r\n&gt;     --set image.repository=${REPO} \\\r\n&gt;     --set image.tag=v0.1.1 \\\r\n&gt;     --set metricsBackend.authentication.type=basic \\\r\n&gt;     --set metricsBackend.authentication.username=${PROMETHEUS_USERNAME} \\\r\n&gt;     --set metricsBackend.authentication.password=${PROMETHEUS_PASSWORD} \\\r\n&gt;     --set metricsBackend.authentication.insecure_skip_verify=true \\\r\n&gt;     --set metricsBackend.url=${PROMETHEUS_SERVICE} \\\r\n&gt;\r\n---\r\n# Source: iter8-analytics\/templates\/namespace.yaml\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: iter8\r\n---\r\n# Source: iter8-analytics\/templates\/config.yaml\r\napiVersion: v1\r\nkind: ConfigMap\r\nmetadata:\r\n  name: iter8-analytics\r\n  namespace: iter8\r\n  labels:\r\n    app: iter8-analytics\r\ndata:\r\n  config.yaml: |\r\n    port: 8080\r\n    metricsBackend:\r\n      url: https:\/\/prometheus.istio-system:9090\r\n      auth:\r\n        ca_file:\r\n        insecure_skip_verify: true\r\n        password: p8aqeFudWKLkzYW3sBGOSo46b9+r8msPNyVG1RWfwBA5HYid74PNhdnjE9Dba3WkNt+BRUmvsSBqIjVZjrYHVfRI\/VPHjgtaTyjnLK+OsT7h2ShXkOP7uakJM987zH9EQsrgd3pSYUadFyMoHUhGY7Yp7ok\/jbG5xAPL4bSYJJxNX9yxRfoT3+Du2kIDQdb65Ik0+z\/lavmymum6byzRLHI4MXJYvWtGjkdIkpQrP5I1IJ+aUur9VcV\/MN+dN3TF\/\/tWBkzWQroJnhtbXBJb+0YLxIc1EGQroYzUGPFgDTmlG+2sYhHO3PdNPT6Ge6PZFb4w3FfjdiAxfpQ5s0XS\r\n        token:\r\n        type: basic\r\n        username: internal\r\n\r\n---\r\n# Source: iter8-analytics\/templates\/service.yaml\r\napiVersion: v1\r\nkind: Service\r\nmetadata:\r\n  name: iter8-analytics\r\n  namespace: iter8\r\n  labels:\r\n    app: iter8-analytics\r\nspec:\r\n  selector:\r\n    app: iter8-analytics\r\n  type: ClusterIP\r\n  ports:\r\n    - port: 8080\r\n      targetPort: 8080\r\n      protocol: TCP\r\n      name: http\r\n\r\n---\r\n# Source: iter8-analytics\/templates\/deployment.yaml\r\napiVersion: apps\/v1\r\nkind: Deployment\r\nmetadata:\r\n  name: iter8-analytics\r\n  namespace: iter8\r\n  labels:\r\n    name: iter8-analytics\r\nspec:\r\n  replicas: 1\r\n  selector:\r\n    matchLabels:\r\n      app: iter8-analytics\r\n  template:\r\n    metadata:\r\n      labels:\r\n        app: iter8-analytics\r\n    spec:\r\n      containers:\r\n        - name: iter8-analytics\r\n          image: \"iter8\/iter8-analytics:v0.1.1\"\r\n          imagePullPolicy: Always\r\n          env:\r\n            - name: METRICS_BACKEND_CONFIGFILE\r\n              value: \"config.yaml\"\r\n          resources:\r\n            {}\r\n\r\n          volumeMounts:\r\n            - name: config-volume\r\n              mountPath: \/python_code\/src\/config.yaml\r\n              subPath: config.yaml\r\n      volumes:\r\n        - name: config-volume\r\n          configMap:\r\n            name: iter8-analytics\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u554f\u984c\u306a\u3051\u308c\u3070\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067iter8 analytics\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/ul>\n<p>\u547d\u4ee4:<\/p>\n<pre class=\"post-pre\"><code>helm template install\/kubernetes\/helm\/iter8-analytics \\\r\n    --name iter8-analytics \\\r\n    --set image.repository=${REPO} \\\r\n    --set image.tag=v0.1.1 \\\r\n    --set metricsBackend.authentication.type=basic \\\r\n    --set metricsBackend.authentication.username=${PROMETHEUS_USERNAME} \\\r\n    --set metricsBackend.authentication.password=${PROMETHEUS_PASSWORD} \\\r\n    --set metricsBackend.authentication.insecure_skip_verify=true \\\r\n    --set metricsBackend.url=${PROMETHEUS_SERVICE} \\\r\n| kubectl -n iter8 apply -f -\r\n<\/code><\/pre>\n<p>\u7ed3\u679c\uff1a<\/p>\n<pre class=\"post-pre\"><code>$ helm template install\/kubernetes\/helm\/iter8-analytics \\\r\n&gt;     --name iter8-analytics \\\r\n&gt;     --set image.repository=${REPO} \\\r\n&gt;     --set image.tag=v0.1.1 \\\r\n&gt;     --set metricsBackend.authentication.type=basic \\\r\n&gt;     --set metricsBackend.authentication.username=${PROMETHEUS_USERNAME} \\\r\n&gt;     --set metricsBackend.authentication.password=${PROMETHEUS_PASSWORD} \\\r\n&gt;     --set metricsBackend.authentication.insecure_skip_verify=true \\\r\n&gt;     --set metricsBackend.url=${PROMETHEUS_SERVICE} \\\r\n&gt; | kubectl -n iter8 apply -f -\r\nnamespace\/iter8 created\r\nconfigmap\/iter8-analytics created\r\nservice\/iter8-analytics created\r\ndeployment.apps\/iter8-analytics created\r\n<\/code><\/pre>\n<h3>\u5b89\u88c5iter8\u63a7\u5236\u5668\u3002<\/h3>\n<ul class=\"post-ul\">iter8 controller\u3092\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/install\/iter8-controller.yaml\r\nnamespace\/iter8 unchanged\r\nconfigmap\/iter8config-metrics created\r\nconfigmap\/iter8config-notifiers created\r\nserviceaccount\/iter8-controller created\r\ncustomresourcedefinition.apiextensions.k8s.io\/experiments.iter8.tools created\r\nclusterrole.rbac.authorization.k8s.io\/iter8-controller-role created\r\nclusterrolebinding.rbac.authorization.k8s.io\/iter8-controller-rolebinding created\r\nservice\/iter8-controller created\r\ndeployment.apps\/iter8-controller created\r\n<\/code><\/pre>\n<h3>\u9a8c\u8bc1\u5b89\u88c5<\/h3>\n<ul class=\"post-ul\">\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u7d50\u679c\u306e\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get pods -n iter8\r\nNAME                                READY   STATUS    RESTARTS   AGE\r\niter8-analytics-744489dcf-nb99p     1\/1     Running   0          23m\r\niter8-controller-67dc866454-944pp   1\/1     Running   0          23m\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>$ kubectl get svc -n iter8\r\nNAME               TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)    AGE\r\niter8-analytics    ClusterIP   172.21.94.199   &lt;none&gt;        8080\/TCP   23m\r\niter8-controller   ClusterIP   172.21.19.62    &lt;none&gt;        443\/TCP    23m\r\n<\/code><\/pre>\n<h1>\u8fdb\u884c\u6559\u7a0b<\/h1>\n<h2>Part 1: \u6210\u529f\u7684\u91d1\u4e1d\u96c0\u53d1\u5e03\uff1areviews-v2 \u5230 reviews-v3<\/h2>\n<h3>\u90e8\u7f72Bookinfo\u5e94\u7528\u7a0b\u5e8f<\/h3>\n<ul class=\"post-ul\">Namespace\u306bistio-injection\u306e\u8a2d\u5b9a<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/namespace.yaml\r\nWarning: kubectl apply should be used on resource created by either kubectl create --save-config or kubectl apply\r\nnamespace\/bookinfo-iter8 configured\r\n<\/code><\/pre>\n<ul class=\"post-ul\">Bookinfo\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/bookinfo-tutorial.yaml\r\nservice\/details created\r\nserviceaccount\/bookinfo-details created\r\ndeployment.apps\/details-v1 created\r\nservice\/ratings created\r\nserviceaccount\/bookinfo-ratings created\r\ndeployment.apps\/ratings-v1 created\r\nservice\/reviews created\r\nserviceaccount\/bookinfo-reviews created\r\ndeployment.apps\/reviews-v2 created\r\nservice\/productpage created\r\nserviceaccount\/bookinfo-productpage created\r\ndeployment.apps\/productpage-v1 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">Pod\u306e\u72b6\u614b\u3092\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get pods -n bookinfo-iter8\r\nNAME                              READY   STATUS    RESTARTS   AGE\r\ndetails-v1-5b59996c6d-nsm9m       2\/2     Running   0          116s\r\nproductpage-v1-697bf98699-qvvdw   2\/2     Running   0          107s\r\nratings-v1-74b7bc7d7b-2rmhn       2\/2     Running   0          112s\r\nreviews-v2-784cd5b59b-n2bvh       2\/2     Running   0          109s\r\n<\/code><\/pre>\n<ul class=\"post-ul\">Gateway\u306e\u8a2d\u5b9a<\/ul>\n<p>\u7531\u4e8eiter8\u7684\u624b\u518c\u8bbe\u7f6e\u5b58\u5728\u95ee\u9898\uff0c\u65e0\u6cd5\u6210\u529f\u4ece\u5916\u90e8\u8bbf\u95ee\u3002\u56e0\u6b64\uff0c\u6839\u636eOpenshift Service Mesh\u624b\u518c\u4e2d\u7684\u6b65\u9aa4\u8fdb\u884c\u8bbe\u7f6e\u3002<br \/>\niter8\u7684\u8bbe\u7f6e\u4f3c\u4e4e\u4ec5\u9650\u4e8e\u5bf9hosts\u8fdb\u884c\u9650\u5b9a\uff0c\u53ea\u6709\u5f53HTTP\u8bf7\u6c42\u6807\u5934\u8bbe\u7f6e\u4e3a\u7279\u5b9ahost\u65f6\u624d\u4f1a\u54cd\u5e94\u3002\u7136\u800c\uff0c\u8fd9\u4e2a\u8bbe\u7f6e\u65e0\u6cd5\u6b63\u5e38\u5de5\u4f5c\uff0c\u5bfc\u81f4\u65e0\u6cd5\u8bbf\u95eebookinfo\u3002\u6240\u4ee5\u6211\u4eec\u5c06\u6309\u7167Openshift Service Mesh\u624b\u518c\u4e2d\u672a\u5bf9hosts\u8fdb\u884c\u9650\u5b9a\u7684\u6b65\u9aa4\u6765\u521b\u5efaGateway\u3002<\/p>\n<pre class=\"post-pre\"><code>$ oc apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/Maistra\/istio\/maistra-1.1\/samples\/bookinfo\/networking\/bookinfo-gateway.yaml\r\ngateway.networking.istio.io\/bookinfo-gateway created\r\nvirtualservice.networking.istio.io\/bookinfo created\r\n\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get gateway -n bookinfo-iter8\r\nNAME               AGE\r\nbookinfo-gateway   48s\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code>$ kubectl get vs -n bookinfo-iter8\r\nNAME       GATEWAYS             HOSTS   AGE\r\nbookinfo   [bookinfo-gateway]   [*]     59s\r\n<\/code><\/pre>\n<ul class=\"post-ul\">Gateway\u306eURL\u78ba\u8a8d<\/ul>\n<p>\u5728\u4e2d\u56fd\uff0c\u4e5f\u53ef\u4ee5\u6309\u7167 Openshift Service Mesh \u7684\u624b\u518c\u4e2d\u6240\u63d0\u53ca\u7684\u6b65\u9aa4\u8fdb\u884c\u786e\u8ba4\u3002<\/p>\n<pre class=\"post-pre\"><code>$ export GATEWAY_URL=$(oc -n istio-system get route istio-ingressgateway -o jsonpath='{.spec.host}')          \r\n\r\n$ echo $GATEWAY_URL\r\nistio-ingressgateway-istio-system.dte-ocp4-frbl36-915b3b336cabec458a7c7ec2aa7c625f-0000.us-south.containers.appdomain.cloud\r\n<\/code><\/pre>\n<h3>\u8bbf\u95eeBookinfo\u5e94\u7528\u7a0b\u5e8f<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/71-0.png\" alt=\"image.png\" \/><\/div>\n<pre class=\"post-pre\"><code># curl -Is \"http:\/\/${GATEWAY_URL}\/productpage\"\r\nHTTP\/1.1 200 OK\r\ncontent-type: text\/html; charset=utf-8\r\ncontent-length: 5183\r\nserver: istio-envoy\r\ndate: Wed, 24 Jun 2020 05:14:07 GMT\r\nx-envoy-upstream-service-time: 89\r\nSet-Cookie: cd10b69e39387eb7ec9ac241201ab1ab=ac85f91a351fed838e2d7b9c262839e2; path=\/; HttpOnly\r\nCache-control: private\r\n<\/code><\/pre>\n<h3>3. \u5bf9\u5e94\u7528\u7a0b\u5e8f\u8fdb\u884c\u8d1f\u8f7d\u751f\u6210<\/h3>\n<p>\u6307\u4ee4\uff1a<\/p>\n<pre class=\"post-pre\"><code>watch -n 0.1 curl -Is http:\/\/${GATEWAY_URL}\/productpage\r\n<\/code><\/pre>\n<p>\u7ed3\u679c\u4e3a\uff1a<\/p>\n<pre class=\"post-pre\"><code>Every 0.1s: curl -Is http:\/\/istio-ingressgateway-istio-system.dte-ocp4-frbl36...  4acc5cf83fe6: Wed Jun 24 05:15:46 2020\r\nHTTP\/1.1 200 OK\r\ncontent-type: text\/html; charset=utf-8\r\ncontent-length: 5183\r\nserver: istio-envoy\r\ndate: Wed, 24 Jun 2020 05:15:46 GMT\r\nx-envoy-upstream-service-time: 49\r\nSet-Cookie: cd10b69e39387eb7ec9ac241201ab1ab=ac85f91a351fed838e2d7b9c262839e2; path=\/; HttpOnly\r\nCache-control: private\r\n<\/code><\/pre>\n<p>\u5982\u679c\u5c4f\u5e55\u4e0a\u663e\u793a\u6b64\u753b\u9762\uff0c\u5219\u6bcf0.1\u79d2\u4f1a\u5bf9Bookinfo\u8fdb\u884c\u8bbf\u95ee\u5e76\u589e\u52a0\u8d1f\u8f7d\u3002<\/p>\n<h3>\u8bbe\u7f6e\u8bc4\u8bba\u670d\u52a1\u7684\u91d1\u4e1d\u96c0\u53d1\u5e03<\/h3>\n<ul class=\"post-ul\">v2 \u304b\u3089 v3\u3078\u306e\u30ab\u30ca\u30ea\u30a2\u30fb\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u4f5c\u6210<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/canary_reviews-v2_to_reviews-v3.yaml\r\nexperiment.iter8.tools\/reviews-v3-rollout created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u78ba\u8a8d<\/ul>\n<\/li>\n<\/ul>\n<p>\u3053\u306e\u6bb5\u968e\u3067\u306fv3\u306e\u30b5\u30fc\u30d3\u30b9\u304c\u7121\u3044\u306e\u3067Missing Candidate\u306b\u306a\u308b<\/p>\n<pre class=\"post-pre\"><code>$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE   STATUS                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Pause   TargetsNotFound: Missing Candidate   reviews-v2   100          reviews-v3   0\r\n<\/code><\/pre>\n<ul class=\"post-ul\">v3\u306e\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3068\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/reviews-v3.yaml\r\ndeployment.apps\/reviews-v3 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">30\u79d2\u3054\u3068\u306bIteration\u304c\u5b9f\u884c\u3055\u308c\u3066\u3001Iteration\u306e\u6700\u5f8c\u306b\u6210\u529f\u57fa\u6e96\u3092\u6e80\u305f\u3057\u3066\u3044\u308c\u307020%\u305a\u3064v3\u306b\u30c8\u30e9\u30d5\u30a3\u30c3\u30af\u304c\u5207\u308a\u66ff\u308f\u308b\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u6210\u529f\u57fa\u6e96\u306f\u5e73\u5747\u30ec\u30a4\u30c6\u30f3\u30b7\u30fc\u304c0.2\u79d2\u4ee5\u4e0b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u6700\u5f8c\u306eIteration\u306e\u7d42\u308f\u308a\u306b\u6210\u529f\u57fa\u6e96\u304c\u6e80\u305f\u3055\u308c\u3066\u3044\u308b\u5834\u5408\u306bv2(0%)\u304b\u3089v3(100%)\u306b\u79fb\u884c\u3059\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 1 Started   reviews-v2   80           reviews-v3   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 2 Started   reviews-v2   80           reviews-v3   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 3 Started   reviews-v2   60           reviews-v3   40\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 4 Started   reviews-v2   40           reviews-v3   60\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 5 Started   reviews-v2   20           reviews-v3   80\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 6 Started   reviews-v2   20           reviews-v3   80\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                 BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Progressing   IterationUpdate: Iteration 7 Started   reviews-v2   20           reviews-v3   80\r\n\r\nAzureAD+YASUYUKIKUBOTA@DESKTOP-76V3US4 MINGW64 \/d\/git\/iter8-analytics (master)\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE       STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\n<\/code><\/pre>\n<h3>6. \u68c0\u67e5Grafana\u4eea\u8868\u677f<\/h3>\n<p>\u5f88\u9057\u61be\uff0c\u5c3d\u7ba1\u5c1d\u8bd5\u8bbf\u95eeGrafana\u7684\u4eea\u8868\u677f\uff0c\u4f46\u65e0\u6cd5\u627e\u5230\u4eea\u8868\u677f\u5e76\u663e\u793a\u51fa\u6765\u3002<\/p>\n<h2>\u7b2c\u4e8c\u90e8\u5206\uff1a\u9ad8\u5ef6\u8fdf\u91d1\u4e1d\u96c0\u53d1\u5e03\uff1areviews-v3\u5230reviews-v4<\/h2>\n<h3>1. \u91d1\u4e1d\u96c0\u6eda\u52a8\u914d\u7f6e<\/h3>\n<ul class=\"post-ul\">v3 \u304b\u3089 v4\u3078\u306e\u30ab\u30ca\u30ea\u30a2\u30fb\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u4f5c\u6210<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/canary_reviews-v3_to_reviews-v4.yaml\r\nexperiment.iter8.tools\/reviews-v4-rollout created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE       STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Pause       TargetsNotFound: Missing Candidate                   reviews-v3   100          reviews-v4   0\r\n<\/code><\/pre>\n<ul class=\"post-ul\">v4\u306e\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3068\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/reviews-v4.yaml\r\ndeployment.apps\/reviews-v4 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u5404Iteration\u306e\u7d42\u308f\u308a\u306b\u6210\u529f\u57fa\u6e96\u3092\u9054\u6210\u3057\u306a\u3044\u305f\u3081\u306b\u521d\u56de\u306e80%\u304b\u3089\u4ee5\u964d\u3059\u308b\u3053\u3068\u306a\u304f\u6700\u59276\u56de\u306eIteration\u3092\u7d42\u3048\u5931\u6557\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>Grafana\u306e\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u304c\u898b\u3089\u308c\u306a\u3044\u306e\u3067\u5fae\u5999\u3060\u304c\u30de\u30cb\u30e5\u30a2\u30eb\u3092\u898b\u308b\u9650\u308av4\u306f\u5e73\u5747\u30ec\u30a4\u30c6\u30f3\u30b7\u30fc\u304c5\u79d2\u306b\u5f35\u308a\u4ed8\u3044\u3066\u3044\u308b\u306e\u30675\u79d2\u7acb\u3063\u305f\u3089\u5fdc\u7b54\u3092\u8fd4\u3059\u30a2\u30d7\u30ea\u306a\u306e\u3060\u308d\u3046<\/p>\n<pre class=\"post-pre\"><code>$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Progressing   IterationUpdate: Iteration 1 Started                 reviews-v3   80           reviews-v4   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Progressing   IterationUpdate: Iteration 1 Started                 reviews-v3   80           reviews-v4   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Progressing   IterationUpdate: Iteration 3 Started                 reviews-v3   80           reviews-v4   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Progressing   IterationUpdate: Iteration 5 Started                 reviews-v3   80           reviews-v4   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                               BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met   reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Progressing   IterationUpdate: Iteration 6 Started                 reviews-v3   80           reviews-v4   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE       STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed   ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\n<\/code><\/pre>\n<h2>\u90e8\u5206\u4e09\uff1a\u5f15\u53d1\u9519\u8bef\u7684\u91d1\u4e1d\u96c0\u53d1\u5e03\uff1areviews-v3 \u81f3 reviews-v5<\/h2>\n<h3>1. \u91d1\u4e1d\u96c0\u63a8\u51fa\u914d\u7f6e<\/h3>\n<ul class=\"post-ul\">v3 \u304b\u3089 v5\u3078\u306e\u30ab\u30ca\u30ea\u30a2\u30fb\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u4f5c\u6210<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/canary_reviews-v3_to_reviews-v5.yaml\r\nexperiment.iter8.tools\/reviews-v5-rollout created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">v5\u306e\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3068\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/reviews-v5.yaml\r\ndeployment.apps\/reviews-v5 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u4eca\u56de\u306f\u6210\u529f\u57fa\u6e96\u306b\u30a8\u30e9\u30fc\u7387\u306e\u8a2d\u5b9a\u304c\u8ffd\u52a0\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u9014\u4e2d\u3067\u7d42\u4e86\u3059\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30a8\u30e9\u30fc\u7387\u306f2%\u4ee5\u5185\u3067\u9014\u4e2d\u3067\u3082\u7d42\u4e86\u3059\u308b\u8a2d\u5b9a\u306b\u306a\u3063\u3066\u3044\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>\u30de\u30cb\u30e5\u30a2\u30eb\u3092\u898b\u308b\u9650\u308av5\u306f\u5e38\u306b\u30a8\u30e9\u30fc\u3092\u8fd4\u3059\u30a2\u30d7\u30ea\u306a\u306e\u3060\u308d\u3046<\/p>\n<pre class=\"post-pre\"><code>AzureAD+YASUYUKIKUBOTA@DESKTOP-76V3US4 MINGW64 \/d\/git\/iter8-analytics (master)\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Progressing   IterationUpdate: Iteration 1 Started                  reviews-v3   80           reviews-v5   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Progressing   IterationUpdate: Iteration 2 Started                  reviews-v3   80           reviews-v5   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE       STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed   ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed   ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\n<\/code><\/pre>\n<h2>\u7b2c\u56db\u90e8\u5206\uff1a\u4f7f\u7528\u81ea\u5b9a\u4e49\u6307\u6807<\/h2>\n<ul class=\"post-ul\">\u73fe\u5728\u4f7f\u7528\u3067\u304d\u308b\u30e1\u30c8\u30ea\u30c3\u30af\u306e\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get configmap iter8config-metrics -n iter8 -oyaml\r\napiVersion: v1\r\ndata:\r\n  metrics: |-\r\n    - name: iter8_latency\r\n      is_counter: False\r\n      absent_value: \"None\"\r\n      sample_size_query_template: iter8_sample_size\r\n    - name: iter8_error_count\r\n      is_counter: True\r\n      absent_value: 0\r\n      sample_size_query_template: iter8_sample_size\r\n    - name: iter8_error_rate\r\n      is_counter: False\r\n      absent_value: 0\r\n      sample_size_query_template: iter8_sample_size\r\n  query_templates: |-\r\n    iter8_sample_size: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\n    iter8_latency: \"(sum(increase(istio_request_duration_seconds_sum{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)) \/ (sum(increase(istio_request_duration_seconds_count{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels))\"\r\n    iter8_error_count: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\n    iter8_error_rate: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels) \/ sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\nkind: ConfigMap\r\nmetadata:\r\n  annotations:\r\n    kubectl.kubernetes.io\/last-applied-configuration: |\r\n      {\"apiVersion\":\"v1\",\"data\":{\"metrics\":\"- name: iter8_latency\\n  is_counter: False\\n  absent_value: \\\"None\\\"\\n  sample_size_query_template: iter8_sample_size\\n- name: iter8_error_count\\n  is_counter: True\\n  absent_value: 0\\n  sample_size_query_template: iter8_sample_size\\n- name: iter8_error_rate\\n  is_counter: False\\n  absent_value: 0\\n  sample_size_query_template: iter8_sample_size\",\"query_templates\":\"iter8_sample_size: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\\niter8_latency: \\\"(sum(increase(istio_request_duration_seconds_sum{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)) \/ (sum(increase(istio_request_duration_seconds_count{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels))\\\"\\niter8_error_count: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\\niter8_error_rate: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels) \/ sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\"},\"kind\":\"ConfigMap\",\"metadata\":{\"annotations\":{},\"name\":\"iter8config-metrics\",\"namespace\":\"iter8\"}}\r\n  creationTimestamp: \"2020-06-24T04:28:52Z\"\r\n  name: iter8config-metrics\r\n  namespace: iter8\r\n  resourceVersion: \"197349\"\r\n  selfLink: \/api\/v1\/namespaces\/iter8\/configmaps\/iter8config-metrics\r\n  uid: 09b64765-5f89-43bb-b490-56aabc310d5a\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u30ab\u30b9\u30bf\u30e0\u30fb\u30e1\u30c8\u30ea\u30c3\u30af\u306e\u8ffd\u52a0<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/iter8_metrics_extended.yaml\r\nconfigmap\/iter8config-metrics configured\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u78ba\u8a8d<\/ul>\n<\/li>\n<\/ul>\n<p>\u30e1\u30c8\u30ea\u30c3\u30af\u540d\u306biter8_90_perc_latency\u304c\u8ffd\u52a0\u3055\u308c\u305f<\/p>\n<pre class=\"post-pre\"><code>$ kubectl get configmap iter8config-metrics -n iter8 -oyaml\r\napiVersion: v1\r\ndata:\r\n  metrics: |-\r\n    - name: iter8_latency\r\n      is_counter: False\r\n      absent_value: \"None\"\r\n      sample_size_query_template: iter8_sample_size\r\n    - name: iter8_error_count\r\n      is_counter: True\r\n      sample_size_query_template: iter8_sample_size\r\n    - name: iter8_error_rate\r\n      is_counter: False\r\n      sample_size_query_template: iter8_sample_size\r\n    - name: iter8_90_perc_latency\r\n      is_counter: False\r\n      absent_value: \"None\"\r\n      sample_size_query_template: iter8_sample_size\r\n  query_templates: |-\r\n    iter8_sample_size: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\n    iter8_latency: \"(sum(increase(istio_request_duration_seconds_sum{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)) \/ (sum(increase(istio_request_duration_seconds_count{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels))\"\r\n    iter8_error_count: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\n    iter8_error_rate: \"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels) \/ sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\"\r\n    iter8_90_perc_latency: \"histogram_quantile(0.90, sum(increase(istio_request_duration_seconds_bucket{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels, le))\"\r\nkind: ConfigMap\r\nmetadata:\r\n  annotations:\r\n    kubectl.kubernetes.io\/last-applied-configuration: |\r\n      {\"apiVersion\":\"v1\",\"data\":{\"metrics\":\"- name: iter8_latency\\n  is_counter: False\\n  absent_value: \\\"None\\\"\\n  sample_size_query_template: iter8_sample_size\\n- name: iter8_error_count\\n  is_counter: True\\n  sample_size_query_template: iter8_sample_size\\n- name: iter8_error_rate\\n  is_counter: False\\n  sample_size_query_template: iter8_sample_size\\n- name: iter8_90_perc_latency\\n  is_counter: False\\n  absent_value: \\\"None\\\"\\n  sample_size_query_template: iter8_sample_size\",\"query_templates\":\"iter8_sample_size: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\\niter8_latency: \\\"(sum(increase(istio_request_duration_seconds_sum{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)) \/ (sum(increase(istio_request_duration_seconds_count{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels))\\\"\\niter8_error_count: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\\niter8_error_rate: \\\"sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',response_code=~'5..',reporter='source'}[$interval]$offset_str)) by ($entity_labels) \/ sum(increase(istio_requests_total{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels)\\\"\\niter8_90_perc_latency: \\\"histogram_quantile(0.90, sum(increase(istio_request_duration_seconds_bucket{source_workload_namespace!='knative-serving',reporter='source'}[$interval]$offset_str)) by ($entity_labels, le))\\\"\"},\"kind\":\"ConfigMap\",\"metadata\":{\"annotations\":{},\"name\":\"iter8config-metrics\",\"namespace\":\"iter8\"}}\r\n  creationTimestamp: \"2020-06-24T04:28:52Z\"\r\n  name: iter8config-metrics\r\n  namespace: iter8\r\n  resourceVersion: \"251241\"\r\n  selfLink: \/api\/v1\/namespaces\/iter8\/configmaps\/iter8config-metrics\r\n  uid: 09b64765-5f89-43bb-b490-56aabc310d5a\r\n<\/code><\/pre>\n<h3>1. \u91d1\u4e1d\u96c0\u7070\u5ea6\u53d1\u5e03\u914d\u7f6e<\/h3>\n<ul class=\"post-ul\">v3 \u304b\u3089 v6\u3078\u306e\u30ab\u30ca\u30ea\u30a2\u30fb\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u4f5c\u6210<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/canary_reviews-v3_to_reviews-v6.yaml\r\nexperiment.iter8.tools\/reviews-v6-rollout created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">v6\u306e\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3068\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/reviews-v6.yaml\r\ndeployment.apps\/reviews-v6 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u30ab\u30b9\u30bf\u30e0\u30fb\u30e1\u30c8\u30ea\u30c3\u30af\u3067\u3082\u554f\u984c\u306a\u304fv6\u3078\u79fb\u884c\u3057\u305f<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiments -n bookinfo-iter8                                                                   NAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed     ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\nreviews-v6-rollout   Progressing   IterationUpdate: Iteration 1 Started                  reviews-v3   80           reviews-v6   20\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed     ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\nreviews-v6-rollout   Progressing   IterationUpdate: Iteration 3 Started                  reviews-v3   60           reviews-v6   40\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed     ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\nreviews-v6-rollout   Progressing   IterationUpdate: Iteration 4 Started                  reviews-v3   40           reviews-v6   60\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE         STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed     ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed     ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed     ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\nreviews-v6-rollout   Progressing   IterationUpdate: Iteration 5 Started                  reviews-v3   20           reviews-v6   80\r\n\r\n$ kubectl get experiments -n bookinfo-iter8\r\nNAME                 PHASE       STATUS                                                BASELINE     PERCENTAGE   CANDIDATE    PERCENTAGE\r\nreviews-v3-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met    reviews-v2   0            reviews-v3   100\r\nreviews-v4-rollout   Completed   ExperimentFailed: Not All Success Criteria Were Met   reviews-v3   100          reviews-v4   0\r\nreviews-v5-rollout   Completed   ExperimentFailed: Abort                               reviews-v3   100          reviews-v5   0\r\nreviews-v6-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met    reviews-v3   0            reviews-v6   100\r\n<\/code><\/pre>\n<h2>\u7b2c\u4e94\u90e8\u5206\uff1a\u7528\u6237\u9762\u5411\u670d\u52a1\u7684\u91d1\u4e1d\u96c0\u53d1\u5e03<\/h2>\n<h3>\u4e3a\u4ea7\u54c1\u9875\u9762\u670d\u52a1\u914d\u7f6e\u91d1\u4e1d\u96c0\u5f0f\u53d1\u5e03<\/h3>\n<p>\u53ea\u9700\u4e00\u4e2a\u9009\u9879\uff1a\u5bf9\u4e8e\u5916\u90e8\u516c\u5f00\u7684\u670d\u52a1\uff0c\u53ef\u4ee5\u901a\u8fc7\u6307\u5b9aVirtualService\u7684\u540d\u79f0\uff0citer8\u4f1a\u81ea\u52a8\u4e3aVirtualService\u8bbe\u7f6e\u6d41\u91cf\u5207\u6362\u3002<\/p>\n<ul class=\"post-ul\">productpage\u306ev1 \u304b\u3089 v2\u3078\u306e\u30ab\u30ca\u30ea\u30a2\u30fb\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u4f5c\u6210\u3059\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/canary_productpage-v1_to_productpage-v2.yaml\r\nexperiment.iter8.tools\/productpage-v2-rollout created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u78ba\u8a8d<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiment productpage-v2-rollout -n bookinfo-iter8\r\nNAME                     PHASE   STATUS                               BASELINE         PERCENTAGE   CANDIDATE        PERCENTAGE\r\nproductpage-v2-rollout   Pause   TargetsNotFound: Missing Candidate   productpage-v1   100          productpage-v2   0\r\n<\/code><\/pre>\n<ul class=\"post-ul\">productpage\u306ev2\u306e\u30b5\u30fc\u30d3\u30b9\u3092\u4f5c\u6210\u3059\u308b\u3068\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl apply -n bookinfo-iter8 -f https:\/\/raw.githubusercontent.com\/iter8-tools\/iter8-controller\/v0.1.1\/doc\/tutorials\/istio\/bookinfo\/productpage-v2.yaml\r\ndeployment.apps\/productpage-v2 created\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u304c\u958b\u59cb\u3055\u308c\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiment productpage-v2-rollout -n bookinfo-iter8\r\nNAME                     PHASE         STATUS                                 BASELINE         PERCENTAGE   CANDIDATE        PERCENTAGE\r\nproductpage-v2-rollout   Progressing   IterationUpdate: Iteration 1 Started   productpage-v1   80           productpage-v2   20\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u958b\u59cb\u3055\u308c\u308b\u3068VirtualService\u306e\u5185\u5bb9\u304citer8\u306b\u3088\u308a\u66f8\u304d\u63db\u3048\u3089\u308c\u3066\u3044\u308b\u3053\u3068\u304c\u5206\u304b\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>baseline\u304c80%\u3001candidate\u304c20%\u306b\u306a\u3063\u3066\u3044\u308b<\/p>\n<pre class=\"post-pre\"><code>$ kubectl get vs bookinfo -n bookinfo-iter8 -o yaml\r\napiVersion: networking.istio.io\/v1alpha3\r\nkind: VirtualService\r\nmetadata:\r\n  annotations:\r\n    kubectl.kubernetes.io\/last-applied-configuration: |\r\n      {\"apiVersion\":\"networking.istio.io\/v1alpha3\",\"kind\":\"VirtualService\",\"metadata\":{\"annotations\":{},\"name\":\"bookinfo\",\"namespace\":\"bookinfo-iter8\"},\"spec\":{\"gateways\":[\"bookinfo-gateway\"],\"hosts\":[\"*\"],\"http\":[{\"match\":[{\"uri\":{\"exact\":\"\/productpage\"}},{\"uri\":{\"prefix\":\"\/static\"}},{\"uri\":{\"exact\":\"\/login\"}},{\"uri\":{\"exact\":\"\/logout\"}},{\"uri\":{\"prefix\":\"\/api\/v1\/products\"}}],\"route\":[{\"destination\":{\"host\":\"productpage\",\"port\":{\"number\":9080}}}]}]}}\r\n  creationTimestamp: \"2020-06-24T05:01:54Z\"\r\n  generation: 4\r\n  labels:\r\n    iter8-tools\/experiment: productpage-v2-rollout\r\n    iter8-tools\/host: productpage\r\n    iter8-tools\/role: progressing\r\n  name: bookinfo\r\n  namespace: bookinfo-iter8\r\n  resourceVersion: \"261486\"\r\n  selfLink: \/apis\/networking.istio.io\/v1alpha3\/namespaces\/bookinfo-iter8\/virtualservices\/bookinfo\r\n  uid: 6b9d2df9-a08b-464f-a6a5-5d462bb963ef\r\nspec:\r\n  gateways:\r\n  - bookinfo-gateway\r\n  hosts:\r\n  - '*'\r\n  http:\r\n  - match:\r\n    - uri:\r\n        exact: \/productpage\r\n    - uri:\r\n        prefix: \/static\r\n    - uri:\r\n        exact: \/login\r\n    - uri:\r\n        exact: \/logout\r\n    - uri:\r\n        prefix: \/api\/v1\/products\r\n    route:\r\n    - destination:\r\n        host: productpage\r\n        port:\r\n          number: 9080\r\n        subset: baseline\r\n      weight: 80\r\n    - destination:\r\n        host: productpage\r\n        port:\r\n          number: 9080\r\n        subset: candidate\r\n      weight: 20\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u306e\u72b6\u614b\u3092\u518d\u3073\u78ba\u8a8d\u3059\u308b\u306840%\/60%\u306b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiment productpage-v2-rollout -n bookinfo-iter8\r\nNAME                     PHASE         STATUS                                 BASELINE         PERCENTAGE   CANDIDATE        PERCENTAGE\r\nproductpage-v2-rollout   Progressing   IterationUpdate: Iteration 5 Started   productpage-v1   40           productpage-v2   60\r\n<\/code><\/pre>\n<ul class=\"post-ul\">VirtualSevice\u308240%\/60%\u306b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get vs bookinfo -n bookinfo-iter8 -o yaml\r\napiVersion: networking.istio.io\/v1alpha3\r\nkind: VirtualService\r\nmetadata:\r\n  annotations:\r\n    kubectl.kubernetes.io\/last-applied-configuration: |\r\n      {\"apiVersion\":\"networking.istio.io\/v1alpha3\",\"kind\":\"VirtualService\",\"metadata\":{\"annotations\":{},\"name\":\"bookinfo\",\"namespace\":\"bookinfo-iter8\"},\"spec\":{\"gateways\":[\"bookinfo-gateway\"],\"hosts\":[\"*\"],\"http\":[{\"match\":[{\"uri\":{\"exact\":\"\/productpage\"}},{\"uri\":{\"prefix\":\"\/static\"}},{\"uri\":{\"exact\":\"\/login\"}},{\"uri\":{\"exact\":\"\/logout\"}},{\"uri\":{\"prefix\":\"\/api\/v1\/products\"}}],\"route\":[{\"destination\":{\"host\":\"productpage\",\"port\":{\"number\":9080}}}]}]}}\r\n  creationTimestamp: \"2020-06-24T05:01:54Z\"\r\n  generation: 6\r\n  labels:\r\n    iter8-tools\/experiment: productpage-v2-rollout\r\n    iter8-tools\/host: productpage\r\n    iter8-tools\/role: progressing\r\n  name: bookinfo\r\n  namespace: bookinfo-iter8\r\n  resourceVersion: \"262507\"\r\n  selfLink: \/apis\/networking.istio.io\/v1alpha3\/namespaces\/bookinfo-iter8\/virtualservices\/bookinfo\r\n  uid: 6b9d2df9-a08b-464f-a6a5-5d462bb963ef\r\nspec:\r\n  gateways:\r\n  - bookinfo-gateway\r\n  hosts:\r\n  - '*'\r\n  http:\r\n  - match:\r\n    - uri:\r\n        exact: \/productpage\r\n    - uri:\r\n        prefix: \/static\r\n    - uri:\r\n        exact: \/login\r\n    - uri:\r\n        exact: \/logout\r\n    - uri:\r\n        prefix: \/api\/v1\/products\r\n    route:\r\n    - destination:\r\n        host: productpage\r\n        port:\r\n          number: 9080\r\n        subset: baseline\r\n      weight: 40\r\n    - destination:\r\n        host: productpage\r\n        port:\r\n          number: 9080\r\n        subset: candidate\r\n      weight: 60\r\n<\/code><\/pre>\n<ul class=\"post-ul\">\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u5b8c\u4e86<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get experiment productpage-v2-rollout -n bookinfo-iter8\r\nNAME                     PHASE       STATUS                                               BASELINE         PERCENTAGE   CANDIDATE        PERCENTAGE\r\nproductpage-v2-rollout   Completed   ExperimentSucceeded: All Success Criteria Were Met   productpage-v1   0            productpage-v2   100\r\n<\/code><\/pre>\n<ul class=\"post-ul\">VirtualSevice\u306f\u3082\u3068\u306e\u8a2d\u5b9a\u306b\u623b\u308b<\/ul>\n<pre class=\"post-pre\"><code>$ kubectl get vs bookinfo -n bookinfo-iter8 -o yaml\r\napiVersion: networking.istio.io\/v1alpha3\r\nkind: VirtualService\r\nmetadata:\r\n  annotations:\r\n    kubectl.kubernetes.io\/last-applied-configuration: |\r\n      {\"apiVersion\":\"networking.istio.io\/v1alpha3\",\"kind\":\"VirtualService\",\"metadata\":{\"annotations\":{},\"name\":\"bookinfo\",\"namespace\":\"bookinfo-iter8\"},\"spec\":{\"gateways\":[\"bookinfo-gateway\"],\"hosts\":[\"*\"],\"http\":[{\"match\":[{\"uri\":{\"exact\":\"\/productpage\"}},{\"uri\":{\"prefix\":\"\/static\"}},{\"uri\":{\"exact\":\"\/login\"}},{\"uri\":{\"exact\":\"\/logout\"}},{\"uri\":{\"prefix\":\"\/api\/v1\/products\"}}],\"route\":[{\"destination\":{\"host\":\"productpage\",\"port\":{\"number\":9080}}}]}]}}\r\n  creationTimestamp: \"2020-06-24T05:01:54Z\"\r\n  generation: 8\r\n  labels:\r\n    iter8-tools\/host: productpage\r\n    iter8-tools\/role: stable\r\n  name: bookinfo\r\n  namespace: bookinfo-iter8\r\n  resourceVersion: \"263010\"\r\n  selfLink: \/apis\/networking.istio.io\/v1alpha3\/namespaces\/bookinfo-iter8\/virtualservices\/bookinfo\r\n  uid: 6b9d2df9-a08b-464f-a6a5-5d462bb963ef\r\nspec:\r\n  gateways:\r\n  - bookinfo-gateway\r\n  hosts:\r\n  - '*'\r\n  http:\r\n  - match:\r\n    - uri:\r\n        exact: \/productpage\r\n    - uri:\r\n        prefix: \/static\r\n    - uri:\r\n        exact: \/login\r\n    - uri:\r\n        exact: \/logout\r\n    - uri:\r\n        prefix: \/api\/v1\/products\r\n    route:\r\n    - destination:\r\n        host: productpage\r\n        port:\r\n          number: 9080\r\n        subset: stable\r\n      weight: 100\r\n<\/code><\/pre>\n<h1>\u6240\u611f\u7684\u610f\u601d\u662f\u5bf9\u67d0\u4e8b\u6216\u67d0\u4eba\u4ea7\u751f\u7684\u611f\u53d7\u6216\u5370\u8c61\u3002<\/h1>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Good<\/ul>\n<\/li>\n<\/ul>\n<p>\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u975e\u6a5f\u80fd\u8981\u4ef6\u306b\u95a2\u3059\u308b\u78ba\u8a8d\u306b\u306f\u4f7f\u3048\u305d\u3046<br \/>\n\u30ed\u30fc\u30eb\u30a2\u30a6\u30c8\u3092\u9014\u4e2d\u3067\u5931\u6557\u306b\u3059\u308b\u3053\u3068\u3067\u30ed\u30fc\u30eb\u30d0\u30c3\u30af\u3059\u308b\u3053\u3068\u3082\u51fa\u6765\u308b<br \/>\n\u4eca\u56de\u306e\u30c1\u30e5\u30fc\u30c8\u30ea\u30a2\u30eb\u3067\u306f\u5358\u306b\u540c\u4e00\u306e\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u8ca0\u8377\u3092\u304b\u3051\u3066\u3044\u305f\u304c\u3001\u305d\u308c\u306b\u52a0\u3048\u3066\u6a5f\u80fd\u30c6\u30b9\u30c8\u3082\u5b9f\u884c\u3059\u308b\u3088\u3046\u306b\u3059\u308c\u3070\u3001\u6a5f\u80fd\u30c6\u30b9\u30c8\uff0b\u975e\u6a5f\u80fd\u30c6\u30b9\u30c8\u3092\u540c\u6642\u306b\u5b9f\u65bd\u3059\u308b\u30d1\u30a4\u30d7\u30e9\u30a4\u30f3\u304c\u7c21\u5358\u306b\u3067\u304d\u305d\u3046<\/p>\n<p>Bad<\/p>\n<p>ROKS\u306e\u74b0\u5883\u3060\u3068Grafana\u306e\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u304c\u9023\u643a\u304c\u3067\u304d\u306a\u304b\u3063\u305f<br \/>\n\u5225\u306e\u74b0\u5883\u306a\u3089\u9023\u643a\u3067\u304d\u308b\u306e\u304b\u306f\u8a66\u3057\u3066\u3044\u306a\u3044\u306e\u3067\u4e0d\u660e<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Iter8\u662f\u4e00\u4e2a\u5de5\u5177\uff0c\u901a\u8fc7\u4e0eIstio\u96c6\u6210\uff0c\u652f\u6301\u9010\u6b65\u5c06\u65b0\u7248\u672c\u90e8\u7f72\u5230\u751f\u4ea7\u73af\u5883\u4e2d\u3002\u5b83\u57fa\u4e8ePrometheus\u6307\u6807\u8fdb [&hellip;]<\/p>\n","protected":false},"author":4,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-43696","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u8981\u8bd5\u7528metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728openshift\u4e0a\uff01\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01\" \/>\n<meta property=\"og:description\" content=\"Iter8\u662f\u4e00\u4e2a\u5de5\u5177\uff0c\u901a\u8fc7\u4e0eIstio\u96c6\u6210\uff0c\u652f\u6301\u9010\u6b65\u5c06\u65b0\u7248\u672c\u90e8\u7f72\u5230\u751f\u4ea7\u73af\u5883\u4e2d\u3002\u5b83\u57fa\u4e8ePrometheus\u6307\u6807\u8fdb [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u8981\u8bd5\u7528metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728openshift\u4e0a\uff01\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2022-12-15T18:46:46+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-29T09:47:06+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/1-0.png\" \/>\n<meta name=\"author\" content=\"\u79d1, \u96c5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u79d1, \u96c5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"19 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/\",\"name\":\"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2022-12-15T18:46:46+00:00\",\"dateModified\":\"2024-04-29T09:47:06+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a\",\"name\":\"\u79d1, \u96c5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"caption\":\"\u79d1, \u96c5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u8981\u8bd5\u7528metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728openshift\u4e0a\uff01\/","og_locale":"zh_CN","og_type":"article","og_title":"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01","og_description":"Iter8\u662f\u4e00\u4e2a\u5de5\u5177\uff0c\u901a\u8fc7\u4e0eIstio\u96c6\u6210\uff0c\u652f\u6301\u9010\u6b65\u5c06\u65b0\u7248\u672c\u90e8\u7f72\u5230\u751f\u4ea7\u73af\u5883\u4e2d\u3002\u5b83\u57fa\u4e8ePrometheus\u6307\u6807\u8fdb [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u8981\u8bd5\u7528metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728openshift\u4e0a\uff01\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2022-12-15T18:46:46+00:00","article_modified_time":"2024-04-29T09:47:06+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d546e37434c4406cd2e0f\/1-0.png"}],"author":"\u79d1, \u96c5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u79d1, \u96c5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"19 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/","name":"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2022-12-15T18:46:46+00:00","dateModified":"2024-04-29T09:47:06+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u6211\u8981\u8bd5\u7528Metrics\u57fa\u4e8e\u7684\u53d1\u5e03\u652f\u6301\u5de5\u5177iter8\u5728Openshift\u4e0a\uff01"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a","name":"\u79d1, \u96c5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","caption":"\u79d1, \u96c5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e8%a6%81%e8%af%95%e7%94%a8metrics%e5%9f%ba%e4%ba%8e%e7%9a%84%e5%8f%91%e5%b8%83%e6%94%af%e6%8c%81%e5%b7%a5%e5%85%b7iter8%e5%9c%a8openshift%e4%b8%8a%ef%bc%81\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43696","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/4"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=43696"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43696\/revisions"}],"predecessor-version":[{"id":86721,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/43696\/revisions\/86721"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=43696"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=43696"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=43696"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}