tonglin0325的个人主页

IDEA的kubernetes插件使用

1.在IDEA或者pycharm中安装kubernets插件#

 

2.使用kubernetes插件#

在view的Tool windows中点击service

可以看到docker和kubernetes的管理界面

 

 可以切换context,从而在不同k8s集群之间切换

多个k8s集群的配置文件默认在

1
2
/Users/lintong/.kube/config

可以使用下面命令进行查看配置

1
kubectl config viewq 

切换k8s集群可以使用kubectx,参考:K8S多集群切换

1
2
3
4
brew install kubectx

kubectx

比如切换docker-desktop

在使用docker-desktop作为k8s集群的时候,记得在docker配置中开启k8s选项

   

3.创建ns.yaml用于创建namespace#

选择kres的k8s配置模板

 

1
2
3
4
5
apiVersion: v1
kind: Namespace
metadata:
name: dev-ns

在k8s集群中创建该yaml配置的namespace

成功创建

1
2
3
4
5
6
7
8
➜  /Users/lintong $ kubectl get ns -A
NAME STATUS AGE
default Active 3d2h
dev-ns Active 31s
kube-node-lease Active 3d2h
kube-public Active 3d2h
kube-system Active 3d2h

之后就可以切到这个namespace下

 

4.创建deployment.yaml用于创建deployment#

可以输入kd产生模板

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
apiVersion: apps/v1
kind: Deployment
metadata:
name: aa-bb-cc
namespace: dev-ns
labels:
app: aa-bb-cc
spec:
replicas: 2
template:
metadata:
name:aa-bb-cc
labels:
app: aa-bb-cc
spec:
containers:
- name: aa-bb-cc
image: xxxx/aa-bb-cc:latest
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8000
restartPolicy: Always
selector:
matchLabels:
app: aa-bb-cc

创建deployment

 

5.创建service来创建一个ip#

使用ks快捷键,其中几个port含义可以参考:k8s 辨析 port、NodePort、targetPort、containerPort 区别 

nodePort 提供了集群外部客户端访问 Service 的一种方式,nodePort 提供了集群外部客户端访问 Service 的端口,通过 nodeIP:nodePort 提供了外部流量访问k8s集群中service的入口。

比如外部用户要访问k8s集群中的一个Web应用,那么我们可以配置对应service的type=NodePortnodePort=30001。其他用户就可以通过浏览器http://node:30001访问到该web服务。

而数据库等服务可能不需要被外界访问,只需被内部服务访问即可,那么我们就不必设置service的NodePort。

**port **是暴露在cluster ip上的端口,:port提供了集群内部客户端访问service的入口,即clusterIP:port

mysql容器暴露了3306端口(参考DockerFile),集群内其他容器通过33306端口访问mysql服务,但是外部流量不能访问mysql服务,因为mysql服务没有配置NodePort

**targetPort **是pod上的端口,从port/nodePort上来的数据,经过kube-proxy流入到后端pod的targetPort上,最后进入容器。

与制作容器时暴露的端口一致(使用DockerFile中的EXPOSE),例如官方的nginx(参考DockerFile)暴露80端口。 

containerPort 是在pod控制器中定义的、pod中的容器需要暴露的端口。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
apiVersion: v1
kind: Service
metadata:
name: aa-bb-cc
namespace: dev-ns
spec:
selector:
app: aa-bb-cc
ports:
- port: 18080
targetPort: 8000
nodePort: 30009
type: NodePort

创建service

 

6.查看服务状态#

这是如果是docker-desktop集群的话,就可以使用localhost:nodePort,即 localhost:30009 来访问启动的服务了

此时也可以查看pod的日志等