C++ 全栈知识体系C++ 全栈知识体系
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
  • 流水线构建 - CI/CD

    • CI/CD - 基础
    • CI/CD - 部署
    • CI/CD - 本地仓库CI流程
    • CI/CD - 远程仓库CI流程
  • 知识点 - Linux

    • Linux - 常用命令大全
    • Linux - 信号
    • Linux - 线程
    • Linux - 进程
    • Linux - 线程和进程同步
    • Linux - shell命令使用技巧
    • Linux - 使echo命令输出结果带颜色
  • 网站 - Nginx

    • Nginx - 学习笔记
    • Nginx - 部署静态页面网站
    • Nginx - 反向代理服务器
    • Nginx - 错误日志配置及信息详解
    • Nginx - 图片服务器配置
  • 容器化 - Docker

    • Docker - 容器技术Docker、Compose、k8s的演变
    • Docker - Dockerfile学习
    • Docker - 命令大全
    • Docker - Docker-compose学习
  • 容器编排 - Kubernetes

    • Kubernetes - 概念
    • Kubernetes - 基础应用
    • Kubernetes - 命令
    • Kubernetes - 检测探针
  • 服务网格 - Service Mesh Istio

    • Istio - 基础
    • Istio - 安装
    • Istio - 使用
    • Istio - 架构解析
    • Istio - 可观察性
    • Istio - 通过阿里云ecs部署k8s集群
  • 常用快捷键 - Shortcut

    • Shortcut - Linux
    • Shortcut - Vim
    • Shortcut - VsCode
    • Shortcut - IDEA
  • 工具使用 - Tools

    • Tools - cmake使用指南
    • Tools - cmake install详解
    • Tools - curl使用方法
    • Tools - docker使用方法
    • Tools - GCC警告选项
    • Tools - GCC和动静态库
    • Tools - gdb调试方法
    • Tools - nginx安装以及使用
    • Tools - VsCode插件

Istio - 安装

  • 参考资料
  • 尝试集群下安装
  • 在master下安装

参考资料

  • istio-handbook

以 Istio 1.5 版本为例,介绍整个安装过程:

  1. 直接在 官网下载对于版本:https://github.com/istio/istio/releases/tag/1.5.0 。
[root@iZuf61kbf845xt6tz10abgZ ~]# cd /home/istio/
[root@iZuf61kbf845xt6tz10abgZ istio]# tar -zxvf istio-1.5.0-linux.tar.gz
  1. 设置环境变量。
vi /etc/profile
加入 export PATH=$PATH:/home/istio/istio-1.5.0/bin
source /etc/profile
  1. 安装目录介绍:
目录包含内容
bin包含 istioctl 的客户端文件
install包含 Consul、GCP 和 Kubernetes 平台的 Istio 安装脚本和文件
samples包含示例应用程序
tools包含用于性能测试和在本地机器上进行测试的脚本

安装过程

尝试集群下安装

执行安装命令:

[root@iZuf61kbf845xt6tz10abgZ ~]# istioctl manifest apply --set profile=demo

结果:

[root@iZuf61kbf845xt6tz10abgZ ~]# istioctl manifest apply --set profile=demo
Detected that your cluster does not support third party JWT authentication. Falling back to less secure first party JWT. See https://istio.io/docs/ops/best-practices/security/#configure-third-party-service-account-tokens for details.
- Applying manifest for component Base...
✔ Finished applying manifest for component Base.
- Applying manifest for component Pilot...
✔ Finished applying manifest for component Pilot.
- Applying manifest for component IngressGateways...
- Applying manifest for component EgressGateways...
- Applying manifest for component AddonComponents...
✔ Finished applying manifest for component EgressGateways.
2022-04-13T23:31:06.344536Z     error   installer       error running kubectl: exit status 1
✘ Finished applying manifest for component AddonComponents.
2022-04-13T23:31:34.877288Z     error   installer       error running kubectl: exit status 1
✘ Finished applying manifest for component IngressGateways.

失败问题,找https://github.com/istio/istio/ 中issues也无法定位,看错误日志是无法连同从节点的10250端口:

Events:
  Type     Reason     Age                    From                     Message
  ----     ------     ----                   ----                     -------
  Normal   Scheduled  4m26s                  default-scheduler        Successfully assigned istio-system/istio-tracing-c7b59f68f-dzrz6 to vm-16-6-centos
  Normal   Killing    3m16s (x2 over 3m56s)  kubelet, vm-16-6-centos  Container jaeger failed liveness probe, will be restarted
  Warning  Unhealthy  3m13s (x7 over 4m23s)  kubelet, vm-16-6-centos  Readiness probe failed: HTTP probe failed with statuscode: 503
  Normal   Pulled     3m3s (x3 over 4m25s)   kubelet, vm-16-6-centos  Container image "docker.io/jaegertracing/all-in-one:1.16" already present on machine
  Normal   Created    3m3s (x3 over 4m25s)   kubelet, vm-16-6-centos  Created container jaeger
  Normal   Started    3m3s (x3 over 4m24s)   kubelet, vm-16-6-centos  Started container jaeger
  Warning  Unhealthy  2m56s (x7 over 4m16s)  kubelet, vm-16-6-centos  Liveness probe failed: HTTP probe failed with statuscode: 503
[root@iZuf61kbf845xt6tz10abgZ ~]# kubectl  logs -f --tail 200 istio-tracing-c7b59f68f-dzrz6 -n istio-system
Error from server: Get https://10.0.16.6:10250/containerLogs/istio-system/istio-tracing-c7b59f68f-dzrz6/jaeger?follow=true&tailLines=200: dial tcp 10.0.16.6:10250: i/o timeout

在master下安装

在网上查找其他方案,发现可以在不加入node的情况下,去安装istio

  1. 清理从节点,调整mater节点能部署pod
kubectl delete node  vm-16-6-centos
kubectl get no -o yaml | grep taint -A 5
kubectl taint nodes --all node-role.kubernetes.io/master
istioctl manifest apply --set profile=demo
  1. 执行后发现容器正常一段时间后又异常了,查看污点和容忍度,发现虚机的硬盘不足:
[root@iZuf61kbf845xt6tz10abgZ ~]# kubectl get no -o yaml | grep taint -A 5
    taints:
    - effect: NoSchedule
      key: node.kubernetes.io/disk-pressure
      timeAdded: "2022-04-16T00:56:21Z"
  status:
    addresses:
    
# 去掉污点
kubectl taint nodes --all node.kubernetes.io/disk-pressure:NoSchedule-
  1. 清理后,重新执行就正常了:
[root@iZuf61kbf845xt6tz10abgZ ~]# kubectl get pods -n istio-system
NAME                                   READY   STATUS    RESTARTS   AGE
grafana-78bc994d79-p5g42               1/1     Running   0          9m56s
istio-egressgateway-7c9f7d5bd6-h5swx   1/1     Running   0          10m
istio-ingressgateway-f9b47d445-n7crd   1/1     Running   0          10m
istio-tracing-c7b59f68f-kbfsk          1/1     Running   0          9m56s
istiod-5745bd5f6b-2ptpt                1/1     Running   0          10m
kiali-57fb5bb5c6-26wq8                 1/1     Running   0          9m55s
prometheus-78f785fc6b-nwpm8            2/2     Running   0          9m55s

清理istio

执行命令:

istioctl manifest generate --set profile=demo | kubectl delete -f -
Last Updated:
Contributors: klc407073648
Prev
Istio - 基础
Next
Istio - 使用