先部署无istio的服务,方便后续改造。
k8s别名
给kubectl命令起别名kc,方便后续查询
[root@m ~]# alias kc='kubectl'
[root@m ~]# kc get ns
NAME STATUS AGE
default Active 233d
istio-system Active 6d18h
k8s-demo Active 16h
kube-node-lease Active 233d
kube-public Active 233d
kube-system Active 233d
1.idea中新建k8sApp项目
项目在本地:D:\cc_study\eclipse_workspace\k8sApp
一个简单的web项目,仅有一个接口
get /app/info
返回:Hello, I am k8s-app! version : v1。
其中version从环境变量中获取。
2.为了以后部署在k8s集群中,建立namespace: k8s-demo
[root@m application]# kubectl get ns
NAME STATUS AGE
default Active 233d
istio-system Active 6d2h
kube-node-lease Active 233d
kube-public Active 233d
kube-system Active 233d
[root@m application]# kubectl create ns k8s-demo
namespace/k8s-demo created
[root@m application]# kubectl get ns
NAME STATUS AGE
default Active 233d
istio-system Active 6d2h
k8s-demo Active 5s
kube-node-lease Active 233d
kube-public Active 233d
kube-system Active 233d
3.项目中新建deploy目录,将部署用到的yaml放入这里
Ingress -> service – > pod
k8s.app.cc.com -> k8s-app:80 --> k8s-app:8090
3.1 外部访问,增加SA,并配置本地hosts文件k8s.app.cc.com域名对应本地linux服务器
这样在访问时就不会被k8s拦截为不安全访问了
本地hosts文件:(Ip为k8s集群的节点)
3.2 为Pod生命周期提供接口
3.3 下载镜像使用secrets
此k8s示例部署文件存放目录:/root/demo/k8s-app
[root@m k8s-app]# ls
[root@m k8s-app]# pwd
/root/demo/k8s-app
[root@m k8s-app]#
linux加密命令:echo ‘abc’ | base64
l