Kubernetes 的应用

查看节点:

kubectl get nodes

运行一个镜像

kubectl run tomcat --image=45.248.69.241:5000/tomcat --replicas=2 --port=8080

确认Deployment

kubectl get deployment

确认pod

kubectl get pods

删除pod

 kubectl delete pods podsname

确认结果

 kubectl get pods

可以看到刚刚生成的sonarqube-1880671902-s3fdq正在结束(Terminating),随之一个新的sonarqube-1880671902-n75d2正在创建,这是正是确保replicas为1的动作

删除deployment

直接删除pod触发了replicas的确保机制,那么我们删除deployment

kubectl delete deployment sonarqube

强制删除

kubectl delete pods <pod> --grace-period=0 --force

结果确认

kubectl get pods
kubectl get deployments

kubectl create

使用kubectl run在设定很复杂的时候需要非常长的一条语句,敲半天也很容易出错,也没法保存,在碰到转义字符的时候也经常会很抓狂,所以更多场景下会使用yaml或者json文件,而使用kubectl create或者delete就可以利用这些yaml文件。 
比如,我们使用如下的方式来分别创建mysql和sonarqube的RC。

创建redis-master Pod和服务

先定义RC来创建pod,然后定义与之关联的service。
为redis-master服务新建一个名为redis-master-controller.yaml的RC定义文件,内容为:

apiVersion: v1
kind: ReplicationController
metadata:
  name: redis-master1
  labels:
    name: redis-master1
spec:
  replicas: 1
  selector:
    name: redis-master1
  template:
    metadata:
     labels:
       name: redis-master1
    spec:
      containers:
      - name: master
        image: 45.248.69.241:5000/redis-master
        ports:
        - containerPort: 6379

新建好文件之后执行如下命令:

kubectl create -f redis-master-controller.yaml

删除:将create换为delete即可。
查看刚刚新建的redis-master:

kubectl get rc

检查pod信息:

kubectl get pods

下面新建与上面建的pod相关联的service,service对应的文件redis-master-service.yaml,内容如下:

apiVersion: v1
kind: Service
metadata:
  name: redis-master1
  labels:
    name: redis-master1
spec:
  ports:
  - port: 6379
    targetPort: 6379
  selector:
    name: redis-master1

查看新建的service:

kubectl get services

2. redis-salve Pod和服务

步骤和redis-master的一样。
新建文件
vim redis-salve-controller.yaml
内容如下:

apiVersion: v1
kind: ReplicationController
metadata:
  name: redis-slave
  labels:
    name: redis-slave
spec:
  replicas: 2
  selector:
    name: redis-slave
  template:
    metadata:
     labels:
       name: redis-slave
    spec:
      containers:
      - name: slave
        image: 45.248.69.241:5000/guestbook-redis-slave
        env:
        - name: GET_HOSTS_FROM
          value: env
        ports:
        - containerPort: 6379

运行kubectl create命令:

kubectl create -f redis-salve-controller.yaml

查看RC:

kubectl get rc

查看pod:

kubectl get pods

配置文件

vim redis-slave-service.yaml
内容如下:

apiVersion: v1
kind: Service
metadata:
  name: redis-slave
  labels:
    name: redis-slave
spec:
  ports:
  - port: 6379
  selector:
    name: redis-slave

创建service:

kubectl create -f redis-slave-service.yaml

检查service:

kubectl get services

3. 创建frontend Pod和服务

文件 vim frontend-controller.yaml 内容如下:

apiVersion: v1
kind: ReplicationController
metadata:
  name: frontend
  labels:
    name: frontend
spec:
  replicas: 3
  selector:
    name: frontend
  template:
    metadata:
     labels:
       name: frontend
    spec:
      containers:
      - name: frontend
        image: 45.248.69.241:5000/guestbook-php-frontend
        env:
        - name: GET_HOSTS_FROM
          value: env
        ports:
        - containerPort: 80

执行命令kubectl create:

kubectl create -f frontend-controller.yaml

检查RC:

kubectl get rc

检查pod:

kubectl get pods

文件

vim frontend-service.yaml
内容如下:

apiVersion: v1
kind: Service
metadata:
  name: frontend
  labels:
    name: frontend
spec:
  type: NodePort
  ports:
  - port: 80
    nodePort: 30001
  selector:
    name: frontend

创建服务:

kubectl create -f frontend-service.yaml

检查service:

kubectl get services

访问网站

如我的虚拟机IP为192.168.80.123
则浏览器访问: 192.168.80.123:30001
成功的话会出现简单的留言板界面,并可进行留言commit。

解决kubectl get pods时 No resources found.问题

https://www.jianshu.com/p/8fce5522950e

vi /etc/kubernetes/apiserver

找到这一行

"KUBE_ADMISSION_CONTROL="--admission_control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ServiceAccount,ResourceQuota"

,去掉ServiceAccount,保存退出。

重新启动kube-apiserver服务即可
systemctl restart kube-apiserver.service

Kubernetes 无法删除pod实例的排查过程

https://www.58jb.com/html/155.html
Kubernetes实践(2)–hello world 示例
http://blog.csdn.net/u010472499/article/details/53142409
Kubernetes之kubectl常用命令使用指南1:创建和删除
http://blog.csdn.net/liumiaocn/article/details/73913597

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值