K8s之Servicet学习笔记

service

--pod-network-cidr=10.244.0.0/16 (pod网段)

--service-cidr=10.96.0.0/12 (service网段)

[root@master maintest]# cat pod.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-nginx
spec:
  selector:
    matchLabels:
      run: my-nginx
  replicas: 2
  template:
    metadata:
      labels:
        run: my-nginx
    spec:
      containers:
      - name: my-nginx
        image: nginx
        ports:
        - containerPort: 80

service 默认type类型为ClusterIP

[root@master maintest]# cat service.yaml
apiVersion: v1
kind: Service
metadata:
  name: my-nginx
  labels:
    run: my-nginx
spec:
  ports:
  - port: 80
    protocol: TCP
  selector:
    run: my-nginx

service 代理到对应的后端pod

映射到宿主机端口

.service.spec.type

NodePort

apiVersion: v1
kind: Service
metadata:
  name: my-nginx
  labels:
    run: my-nginx
spec:
  ports:
  - port: 80
    protocol: TCP
  type: NodePort
  selector:
    run: my-nginx
[root@master maintest]# kubectl get svc -o wide
NAME         TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE   SELECTOR
kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP        69d   <none>
my-nginx     NodePort    10.106.132.151   <none>        80:30994/TCP   21h   run=my-nginx

访问node节点的ip:30994---->service ip:80---->pod ip:80

创建没有selector的service

[root@master maintest]# cat noselector.yaml
apiVersion: v1
kind: Service
metadata:
  name: my-service
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 3306

endpoint.yaml

[root@master maintest]# cat endpoint.yaml
apiVersion: v1
kind: Endpoints
metadata:
  name: my-service
subsets:
- addresses:
  - ip: 1.2.3.4
  ports:
  - port: 3306
[root@master maintest]# kubectl describe svc my-service
Name:              my-service
Namespace:         default
Labels:            <none>
Annotations:       <none>
Selector:          <none>
Type:              ClusterIP
IP Families:       <none>
IP:                10.104.205.156
IPs:               <none>
Port:              <unset>  80/TCP
TargetPort:        3306/TCP
Endpoints:         1.2.3.4:3306
Session Affinity:  None
Events:            <none>

创建type是ExternalName的service

[root@master maintest]# cat external.yaml
apiVersion: v1
kind: Service
metadata:
  name: my-service
  namespace: prod
spec:
  type: ExternalName
  externalName: my.database.example.com
上一篇:修改NPM全局模式的默认安装路径


下一篇:greenplum分布键的hash值计算分析