美文网首页
通过资源配置运行容器

通过资源配置运行容器

作者: Lucie_xxm | 来源:发表于2019-06-10 18:44 被阅读0次

概述

我们知道通过 run 命令启动容器非常麻烦,Docker 提供了 Compose 为我们解决了这个问题。那 Kubernetes 是如何解决这个问题的呢?其实很简单,使用 kubectl create 命令就可以做到和 Compose 一样的效果了,该命令可以通过配置文件快速创建一个集群资源对象。

创建 YAML 配置文件

以部署 Nginx 为例

部署 Deployment

创建一个名为 nginx-deployment.yml 的配置文件

# API 版本号
apiVersion: extensions/v1beta1
# 类型,如:Pod/ReplicationController/Deployment/Service/Ingress
kind: Deployment
# 元数据
metadata:
  # Kind 的名称
  name: nginx-app
spec:
  # 部署的实例数量
  replicas: 2
  template:
    metadata:
      labels:
        # 容器标签的名字,发布 Service 时,selector 需要和这里对应
        name: nginx
    spec:
      # 配置容器,数组类型,说明可以配置多个容器
      containers:
      # 容器名称
      - name: nginx
        # 容器镜像
        image: nginx
        # 暴露端口
        ports:
        # Pod 端口
        - containerPort: 80
# 部署
kubectl create -f nginx-deployment.yml

# 删除
kubectl delete -f nginx-deployment.yml

发布 Service

创建一个名为 nginx-service.yml 的配置文件

# API 版本号
apiVersion: v1
# 类型,如:Pod/ReplicationController/Deployment/Service/Ingress
kind: Service
# 元数据
metadata:
  # Kind 的名称
  name: nginx-http
spec:
  # 暴露端口
  ports:
    ## Service 暴露的端口
    - port: 80
      ## Pod 上的端口,这里是将 Service 暴露的端口转发到 Pod 端口上
      targetPort: 80
  # 类型
  type: LoadBalancer
  # 标签选择器
  selector:
    # 需要和上面部署的 Deployment 标签名对应
    name: nginx
# 部署
kubectl create -f nginx-service.yml

# 删除
kubectl delete -f nginx-service.yml

验证是否生效

查看 Pod 列表

kubectl get pods

# 输出如下
NAME                         READY   STATUS    RESTARTS   AGE
nginx-app-64bb598779-2pplx   1/1     Running   0          25m
nginx-app-64bb598779-824lc   1/1     Running   0          25m

查看 Deployment 列表

kubectl get deployment

# 输出如下
NAME        READY   UP-TO-DATE   AVAILABLE   AGE
nginx-app   2/2     2            2           25m

查看 Service 列表

kubectl get service

# 输出如下
NAME         TYPE           CLUSTER-IP     EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP      10.96.0.1      <none>        443/TCP        20h
nginx-http    LoadBalancer   10.98.49.142   <pending>     80:31631/TCP   14m

查看 Service 详情

kubectl describe service nginx-app

# 输出如下
Name:                     nginx-http
Namespace:                default
Labels:                   <none>
Annotations:              <none>
Selector:                 name=nginx
Type:                     LoadBalancer
IP:                       10.98.49.142
Port:                     <unset>  80/TCP
TargetPort:               80/TCP
NodePort:                 <unset>  31631/TCP
Endpoints:                10.244.141.205:80,10.244.2.4:80
Session Affinity:         None
External Traffic Policy:  Cluster
Events:                   <none>

通过浏览器访问

通过浏览器访问 http://192.168.141.150:31631/ ,出现 Nginx 欢迎页即表示成功

集成环境部署

也可以不区分配置文件,一次性部署 Deployment 和 Service,创建一个名为 nginx.yml 的配置文件,配置内容如下:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: nginx-app
spec:
  replicas: 2
  template:
    metadata:
      labels:
        name: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: nginx-http
spec:
  ports:
    - port: 80
      targetPort: 80
      # 可以指定 NodePort 端口,默认范围是:30000-32767
      # nodePort: 30080
  type: LoadBalancer
  selector:
    name: nginx
# 部署
kubectl create -f nginx.yml

# 删除
kubectl delete -f nginx.yml

附:修改默认的端口范围

Kubernetes 服务的 NodePort 默认端口范围是 30000-32767,在某些场合下,这个限制不太适用,我们可以自定义它的端口范围,操作步骤如下:

编辑 vi /etc/kubernetes/manifests/kube-apiserver.yaml 配置文件,增加配置 --service-node-port-range=2-65535

apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: null
  labels:
    component: kube-apiserver
    tier: control-plane
  name: kube-apiserver
  namespace: kube-system
spec:
  containers:
  - command:
    - kube-apiserver
    # 在这里增加配置即可
    - --service-node-port-range=2-65535
    - --advertise-address=192.168.141.150
    - --allow-privileged=true
    - --authorization-mode=Node,RBAC
    - --client-ca-file=/etc/kubernetes/pki/ca.crt
    - --enable-admission-plugins=NodeRestriction
    - --enable-bootstrap-token-auth=true
    - --etcd-cafile=/etc/kubernetes/pki/etcd/ca.crt
    - --etcd-certfile=/etc/kubernetes/pki/apiserver-etcd-client.crt
// 以下配置省略...

使用 docker ps命令找到 kube-apiserver 容器,再使用 docker restart <ApiServer 容器 ID> 即可生效。

相关文章

  • 通过资源配置运行容器

    概述 我们知道通过 run 命令启动容器非常麻烦,Docker 提供了 Compose 为我们解决了这个问题。那 ...

  • 进入Docker容器内部

    Docker容器运行起来以后,要想进入容器内部可以先通过docker ps命令查看,当前运行的容器信息 再通过 d...

  • docker快速构建开发环境

    docker 安装 容器日常管理 创建并运行 hyperf容器 创建并运行 mysql 容器 创建网络链接 通过d...

  • 小鲸鱼docker常用命令

    创建镜像 运行容器 查看容器操作 进入处于运行状态的容器 删除容器 若不能直接通过apt命令安装,则apt-get...

  • docker常用命令

    下载镜像 列出所有镜像 删除images,通过image的id来指定删除谁 运行容器 正在运行的容器 所有的的容器...

  • Docker 守护式容器

    以守护形式运行容器:首先运行: 然后通过组合键 再查看 再次回到容器 启动守护式容器-d 参数 表示启动容器时,使...

  • 3. Docker 容器命令

    1. 容器基本操作最简单的运行镜像为容器的命令如下: 运行一个容器只要通过 docker run 命令即可实现,其...

  • docker 下安装常用 image

    Ubuntu 运行容器,并且可以通过 exec 命令进入 ubuntu 容器 cent os $ docker r...

  • Dcoker常用命令

    一、查看镜像 二、查看容器 2.1查看运行容器 2.2 查看所有容器 2.3 通过名称查看容器 2.4 列出最近创...

  • docker暴露端口失败

    问题 docker 运行容器后,通过-p参数指定端口暴露(比如-p 9090:9090),运行成功,但是通过ss ...

网友评论

      本文标题:通过资源配置运行容器

      本文链接:https://www.haomeiwen.com/subject/kjetfctx.html