virtualBox部署minikube+istio

环境准备

  1. virtualBox安装

    直接官网下载后安装即可,网上也有详细教程。镜像使用的centos7。

    链接(不保证还可用):http://big.dxiazaicc.com/bigfile/100/virtualbox_v6.1.26_downcc.com.zip?auth_key=1730185635-pWBtV8LynsxPD0-0-d13becdfe4fd4b856024d0bb6ff7aee0

    镜像:

    https://mirrors.aliyun.com/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-2009.iso?spm=a2c6h.25603864.0.0.3e182d1cZ5FDr7

  2. 网络配置

    使用桥接的方式

  3. docker安装

bash 复制代码
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

查看所有仓库中docker版本yum list docker-ce --showduplicates | sort -r

选择安装18.06.1版本的yum install docker-ce-18.06.1.ce

启动start docker     enable docker    docker version
  1. docker配置换源
bash 复制代码
dig @114.114.114.114 registry-1.docker.io
查看IP
vim /etc/hosts
输入内容:IP地址 registry-1.doker.io.
bash 复制代码
vi /etc/docker/daemon.json
{
"registry-mirrors": ["https://docker.registry.cyou",
"https://docker-cf.registry.cyou",
"https://dockercf.jsdelivr.fyi",
"https://docker.jsdelivr.fyi",
"https://dockertest.jsdelivr.fyi",
"https://mirror.aliyuncs.com",
"https://dockerproxy.com",
"https://mirror.baidubce.com",
"https://docker.m.daocloud.io",
"https://docker.nju.edu.cn",
"https://docker.mirrors.sjtug.sjtu.edu.cn",
"https://docker.mirrors.ustc.edu.cn",
"https://mirror.iscas.ac.cn",
"https://docker.rainbond.cc"]
}
sudo systemctl daemon-reload
sudo systemctl restart docker
  1. kubectl安装
    下载文件到本地后直接安装
bash 复制代码
sudo install kubectl /usr/local/bin/kubectl
chmod +x kubectl
mv kubectl /usr/local/bin/kubectl

链接:

https://storage.googleapis.com/kubernetes-release/release/v1.16.0/bin/linux/amd64/kubectl

minikube安装

链接:https://objects.githubusercontent.com/github-production-release-asset-2e65be/56353740/77c29600-f756-11e9-8405-40d193dba8b7?X-Amz-Algorithm=AWS4-HMAC-SHA256\&X-Amz-Credential=releaseassetproduction%2F20241029%2Fus-east-1%2Fs3%2Faws4_request\&X-Amz-Date=20241029T084730Z\&X-Amz-Expires=300\&X-Amz-Signature=6284e06a96943dbb3b4520e1cddf8172a43874bb64d578baf50a53dd4ec67448\&X-Amz-SignedHeaders=host\&response-content-disposition=attachment%3B filename%3Dminikube-linux-amd64\&response-content-type=application%2Foctet-stream

同样,下载文件到本地后,拉到虚拟机:

bash 复制代码
chmod +x minikube
sudo install minikube /usr/local/bin/minikube 
mv minikube /usr/local/bin/minikube
bash 复制代码
minikube start --registry-mirror=https://registry.docker-cn.com --image-repository=registry.cn-hangzhou.aliyuncs.com/google_containers --vm-driver=none

启动成功的截图:

查看状态:

bash 复制代码
kubectl get node

istio安装

链接:https://objects.githubusercontent.com/github-production-release-asset-2e65be/74175805/30d61900-e3d8-11ea-8264-82ef154f0aae?X-Amz-Algorithm=AWS4-HMAC-SHA256\&X-Amz-Credential=releaseassetproduction%2F20241030%2Fus-east-1%2Fs3%2Faws4_request\&X-Amz-Date=20241030T125845Z\&X-Amz-Expires=300\&X-Amz-Signature=9c4a02b8bce2b3b9d40a0186ed8ff68be5f641472c08548e15a16ad2cc4ec9a4\&X-Amz-SignedHeaders=host\&response-content-disposition=attachment%3B filename%3Distio-1.7.0-linux-amd64.tar.gz\&response-content-type=application%2Foctet-stream

下载安装包,拉到机器上(github)

将下列环境变量添加etc/profile后source /etc/profile:

export ISTIO_HOME=/root/istio-1.11.1/bin

export PATH= I S T I O H O M E : ISTIO_HOME: ISTIOHOME:PATH

验证:

bash 复制代码
istioctl version(需启动K8S)

安装:

istioctl install --set profile=demo -y

有问题:

查看日志:

bash 复制代码
kubectl describe pod istiod-5b9d44c58b-nnkdj -n istio-system

日志显示拉不到镜像,推测是网络问题,通过上文4.的docker源配置修改,先用docker拉到这些镜像后,再次启动,成功了:

查看状态:

bash 复制代码
kubectl get pods --all-namespaces

配置自动注入envoy:

bash 复制代码
kubectl label namespace default istio-injection=enabled

bookinfo测试

运行官方demo:

bash 复制代码
kubectl apply -f samples/bookinfo/platform/kube/bookinfo.yaml

启动成功:

查看状态:

bash 复制代码
kubectl get svc,po -o wide


验证:

bash 复制代码
kubectl exec "$(kubectl get pod -l app=ratings -o jsonpath='{.items[0].metadata.name}')" -c ratings -- curl -sS productpage:9080/productpage | grep -o "<title>.*</title>"

出现响应则启动成功。

  • 对外访问

关联网关:

bash 复制代码
kubectl apply -f samples/bookinfo/networking/bookinfo-gateway.yaml

查看端口映射:

bash 复制代码
kubectl get svc istio-ingressgateway -n istio-system

NAME                   TYPE           CLUSTER-IP       EXTERNAL-IP   PORT(S)                                                                      AGE
istio-ingressgateway   LoadBalancer   10.200.138.202   10.0.0.150    15021:30531/TCP,80:31380/TCP,443:31390/TCP,31400:31345/TCP,15443:30249/TCP   2m10s

如果EXTERNAL-IP设置了该值,则您的环境具有可用于入口网关的外部负载平衡器。如果EXTERNAL-IP值是(或永久),则您的环境不为入口网关提供外部负载平衡器。在这种情况下,您可以使用服务的节点端口来访问网关。

这里80对应的端口是Http服务的端口,映射的主机端口31380;

这里443对应的端口是Https服务的端口,映射的主机端口31390;

确定IP:

可以通过下面命令找个hostIP。

bash 复制代码
[root@k8s-master istio-1.4.2]# kubectl get po -l istio=ingressgateway -n istio-system -o yaml | grep hostIP: -C3
---
      state:
        running:
          startedAt: "2019-12-24T06:46:29Z"
    hostIP: 192.168.43.239
    phase: Running
    podIP: 10.244.3.136
    qosClass: Burstable
---

本机IP:192.168.43.239

在虚拟机外部通过IP+端口+uri访问服务:

启动kiali

部署:

bash 复制代码
kubectl apply -f samples/addons

查看部署状态,镜像较大,需要都running:

bash 复制代码
kubctl get pods -n istio-system

拉不到镜像的情况,在docker中手动拉取(由于源和超时时间等原因)

docker pull quay.io/kiali/kiali:v1.22

关键!!!

将kali service 的服务类型设置为 nodeport,以供外部浏览器访问:

bash 复制代码
kubectl patch svc -n istio-system kiali -p '{"spec": {"type": "NodePort"}}'

istioctl dashboard kiali --address 192.168.43.239

通过上文查看20001的映射端口,虚拟机外部浏览器通过IP+端口+uri访问:

虚拟机重启后重新部署

1、启动minikube

2、启动istio

3、启动bookinfo

4、启动kiali

bash 复制代码
kubectl delete pod kiali-89fd7f87b-tb2rp -n istio-system

参考链接:

https://baijiahao.baidu.com/s?id=1764144114247192969\&wfr=spider\&for=pc

https://www.cnblogs.com/yinzhengjie/p/18064053#3下载指定版本的istio

https://blog.csdn.net/wzy_168/article/details/103717671

相关推荐
Karoku0664 小时前
【k8s集群应用】kubeadm1.20高可用部署(3master)
运维·docker·云原生·容器·kubernetes
探索云原生9 小时前
在 K8S 中创建 Pod 是如何使用到 GPU 的: nvidia device plugin 源码分析
ai·云原生·kubernetes·go·gpu
启明真纳9 小时前
elasticache备份
运维·elasticsearch·云原生·kubernetes
会飞的土拨鼠呀12 小时前
chart文件结构
运维·云原生·kubernetes
Hello Dam16 小时前
面向微服务的Spring Cloud Gateway的集成解决方案:用户登录认证与访问控制
spring cloud·微服务·云原生·架构·gateway·登录验证·单点登录
power-辰南17 小时前
Zookeeper 底层原理解析
分布式·zookeeper·云原生
power-辰南17 小时前
Zookeeper常见面试题解析
分布式·zookeeper·云原生
Cairry.1 天前
WatchAlert - 开源多数据源告警引擎
云原生·开源·prometheus
会飞的土拨鼠呀1 天前
Kubernetes 是什么?
云原生·容器·kubernetes
向阳逐梦1 天前
开源云原生数据仓库ByConity ELT 的测试体验
数据仓库·云原生·开源