Bootstrap

【Kubernetes】如何将应用服务,部署到Kubernetes中???

第一步:准备Docker镜像

首先,将服务打包为Dokcer镜像。确保镜像构建正确,并包含服务运行所需的所有依赖项和配置。

(1)创建一个文件夹(目录)
mkdir ./newpath
(2)在文件来(目录)中创建Dockerfi1e文件(并编写)及其它文件
# 使用Java 8的基础镜像  
FROM java:8  
  
# 设置维护者信息  
MAINTAINER YourName <youremail@example.com>  
  
# 将本地的mei.jar文件复制到容器的/app目录下  
# 注意:确保你的Dockerfile和mei.jar文件在同一个目录下,或者mei.jar文件在Dockerfile指定的构建上下文中  
COPY mei.jar /app/  
  
# 设置工作目录为/app  
WORKDIR /app  
  
# 暴露8080端口(这取决于你的Java应用是否使用此端口,如果不是请相应修改)  
EXPOSE 8080  
  
# 定义容器启动时执行的命令  
# 使用java -jar命令来启动mei.jar文件  
# 注意:如果你的应用需要额外的JVM参数,可以在这里添加  
CMD ["java", "-jar", "mei.jar"]  
  
# 备注:这个Dockerfile假设你的Java应用是一个可执行的JAR文件,并且它会监听8080端口(或你指定的其他端口)  
# 如果你的应用配置不同(例如,使用了不同的端口或启动参数),请相应地修改Dockerfile中的EXPOSE和CMD指令

(3)使用docker build命令构建镜像
docker build -t my-app:latest

(4)使用构建的镜像启动容器

在需要运行容器:的地方,Docker pull命令拉取镜像后,运行启动容器。

docker run -p 8080:8080 -d my-app:latest

第二步:创建Kubernetes部署配置文件(Deployment.yaml)

创建配置文件Deployment.yaml,在这个配置文件中,需要定义诸如副本数量,容器镜像,资源请求和限制,环境变量等信息。

apiVersion: apps/v1 # 指定使用apps/v1版本的API  
kind: Deployment # 定义资源的类型为Deployment  
metadata:  
  name: myapp-deployment # Deployment的名称  
  labels:  
    app: myapp # 为Deployment添加标签,方便后续通过标签选择器进行关联  
spec:  
  replicas: 3 # 指定副本数量为3  
  selector:  
    matchLabels:  
      app: myapp # 通过标签选择器选择Pod,这里的标签必须与下面Pod模板中的标签一致  
  template:  
    metadata:  
      labels:  
        app: myapp # 为Pod模板添加标签  
    spec:  
      containers:  
      - name: myapp-container # 容器的名称  
        image: myapp:latest # 容器使用的镜像  
        ports:  
        - containerPort: 8080 # 容器内部监听的端口  
        env: # 环境变量列表  
        - name: MY_ENV_VAR # 环境变量名称  
          value: "some-value" # 环境变量的值  
        resources: # 资源请求和限制  
          requests: # 资源请求  
            memory: "64Mi" # 请求64MB内存  
            cpu: "250m" # 请求250m CPU(即0.25个CPU核心)  
          limits: # 资源限制  
            memory: "128Mi" # 限制最大使用128MB内存  
            cpu: "500m" # 限制最大使用500m CPU(即0.5个CPU核心)  
      # 还可以添加其他配置,如volumeMounts、securityContext等

第三步:定义服务配置(Service YAML)

如果服务能够从集群外部访问,或者在集群内部进行服务发现,需要创建服务配置文件,定义服务的类型(如 ClusterIP、NodePort、LoadBalancer 等)和端口映射。

apiVersion: v1 # 使用Kubernetes的核心v1 API  
kind: Service # 定义资源的类型为Service  
metadata:  
  name: myapp-service # Service的名称  
spec:  
  type: NodePort # 指定Service的类型为NodePort,这样可以从集群外部访问  
  selector:  
    app: myapp # 通过标签选择器选择Pod,这里的标签应与Pod模板中的标签一致  
  ports:  
    - port: 80 # Service内部的端口,即Pod中容器暴露的端口  
      targetPort: 8080 # 容器内部监听的端口,如果与port相同,可以省略  
      nodePort: 30001 # NodePort类型时指定的节点端口,范围通常为30000-32767,如果省略,则Kubernetes会自动分配  
      protocol: TCP # 端口协议,默认为TCP

第四步:应用配置

确保您已经创建了 Deployment 和 Service 的 YAML 配置文件,并将它们保存在您的本地文件系统中。例如,Deployment 配置文件可以命名为 deployment.yaml,Service 配置文件可以命名为 service.yaml。

# 使用 cd 命令切换到包含您的 YAML 配置文件的目录
cd /path/to/your/files

# 应用配置文件:
kubectl apply -f deployment.yaml
kubectl apply -f service.yaml

# 部署完毕后,查看验证资源状态
kubectl get deployments
kubectl get pods
kubectl get services/svc

第五步:监控和调试

使用 Kubernetes 提供的工具和命令,如 kubectl get pods 、 kubectl describe pod 等,来监控服务的部署状态,查看日志以进行调试和故障排除。

# 查看所有 Pods:
kubectl get pods

# 查看 Pods 的详细信息
kubectl get pods -o wide

# 按状态过滤 Pods
kubectl get pods --field-selector=status.phase=Running

# 查看 Pod 的详细信息
kubectl describe pod <pod-name>

# 查看日志
kubectl logs <pod-name>

# 实时查看 Pod 的日志
# 加上 -f 参数可以实时地查看日志,这对于观察应用的行为或调试问题特别有用。
kubectl logs -f <pod-name>

# 进入 Pod 的容器
# 如果您的容器中没有 /bin/bash,可以尝试 /bin/sh 或其他可用的 shell
# 不是所有的容器镜像都包含 shell 环境。如果容器中没有可用的 shell,
kubectl exec -it <pod-name> -- /bin/bash

# 使用 debug 模式(需要 Kubernetes >= 1.18),来创建一个临时的调试 Pod
kubectl debug 

除了 kubectl 之外,还有许多其他工具可以用于 Kubernetes 的监控和调试,例如 Prometheus、Grafana、Kibana(用于日志分析)、Weave Scope(可视化容器、Pods 和服务的实时状态)等。这些工具通常提供更丰富的功能和更好的用户体验,但也需要额外的配置和部署。

;