文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

K8s部署PHP项目

2023-09-02 06:01

关注

前言

        前端时间PHP项目部署升级需要 ,需要把Laravel开发的项目部署K8s上,下面以laravel项目为例,讲解采用yaml文件方式部署项目。

一、部署步骤

1.创建Dockerfile文件

Dockerfile是一个用来构建镜像的文本文件,在容器运行时,需要把项目文件和项目运行所必须的组件安装其中。

# 基础镜像FROM php:7.4-fpm # 时区ARG TZ=Asia/Shanghai # 更换容器时区RUN cp "/usr/share/zoneinfo/$TZ" /etc/localtime && echo "$TZ" > /etc/timezone # 替换成阿里apt-get源RUN sed -i "s@http://deb.debian.org@http://mirrors.aliyun.com@g" /etc/apt/sources.list && rm -rf /var/lib/apt/lists/* && cat /etc/apt/sources.list # 调试扩展# vim net-tools rsyslog procps # 安装扩展RUN apt-get update \  && apt-get install -y libzip-dev zip libfreetype6-dev libjpeg62-turbo-dev libmcrypt-dev librdkafka-dev libpng-dev cron supervisor \  && rm -rf /var/lib/apt/lists/* \  && docker-php-ext-configure gd \  && docker-php-ext-install -j$(nproc) gd mysqli pdo_mysql zip opcache bcmath iconv # 安装kafka扩展COPY deploy/docker/php/ext/rdkafka-5.0.0.tgz /tmp/RUN pecl install /tmp/rdkafka-5.0.0.tgz && docker-php-ext-enable rdkafka # 安装redis扩展COPY deploy/docker/php/ext/redis-5.3.4.tgz /tmp/RUN pecl install /tmp/redis-5.3.4.tgz && docker-php-ext-enable redis # 创建supervisor日志目录、项目目录RUN mkdir -p /var/log/supervisor && mkdir -p /www # supervisor配置文件COPY deploy/docker/supervisor/conf.d /etc/supervisor/conf.d # 替换php配置文件COPY ./deploy/docker/php/conf.d/opcache.ini /usr/local/etc/php/COPY ./deploy/docker/php/conf.d/phpcustom.ini /usr/local/etc/php/ # CPOY定时任务COPY deploy/docker/cron/root /var/spool/cron/crontabsRUN chmod 600 /var/spool/cron/crontabs/root # 安装composerRUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer \    && ln -s $(composer config --global home) /root/composer \    && composer config -g repo.packagist composer https://packagist.phpcomposer.com # COPY项目到/www目录COPY . /www # 进入/www目录WORKDIR /www # 删除多余文件RUN rm -rf $(find /www/backend/ -maxdepth 1 ! -name "backend" ! -name "dist") && rm -rf /tmp/* # /www下文件授权用户组和用户权限;composer安装需要包(如果项目composer存在,可不执行)RUN chown -R www-data:www-data /www/storage \    && composer install \        --optimize-autoloader \        --ignore-platform-reqs \        --prefer-dist \        --no-interaction \        --no-dev # 执行entrypointCOPY deploy/docker/entrypoint.sh /usr/local/bin/entrypointRUN chmod +x /usr/local/bin/entrypoint ENTRYPOINT ["/usr/local/bin/entrypoint"]

2. 创建命名空间【namespace.yaml】

Kubernetes使用命名空间的概念帮助解决集群中在管理对象时的复杂性问题。命名空间允许将对象分组到一起,便于将它们作为一个单元进行筛选和控制;简单理解可以实现项目彼此隔离。

        kubectl create -f namespace.yaml

         kubectl get namespaces

apiVersion: v1 #版本号kind: Namespace #配置类型metadata: #元数据  name: php-service #该 Namespace 的名称

3. 创建App Env Config【app-env-config.yaml】(laravel .env 配置)

          kubectl create -f app-env-config.yaml

          kubectl get --namespace=php-service configmaps

          kubectl get --namespace=php-service configmaps app-env-config

          kubectl get --namespace=php-service configmaps app-env-config -o yaml

apiVersion: v1  #版本号kind: ConfigMap #配置类型metadata: #元数据  name: app-env-config #该 ConfigMap 的名称  namespace: php-service  #该 ConfigMap 所在命名空间data: #该 ConfigMap 数据  # App Config  APP_DEBUG: 'true'  APP_ENV: test  APP_KEY: xxx   # DB Config  DB_DATABASE: xxx  DB_HOST: xx.xx.xx.xx  DB_PASSWORD: xxx  DB_USERNAME: xxx   # JWT Config  JWT_KEY: XXX  JWT_SECRET: XXX  JWT_TOKEN_EXPIRE_TIME: '86400'    # Redis Config  REDIS_DATABASE: '0'  REDIS_HOST: xx.xx.xx.xx  REDIS_PASSWORD: xxx  REDIS_PORT: '6380'  REDIS_PREFIX: xxx

4. 创建Nginx Config【nginx-config.yaml】

           kubectl create -f nginx-config.yaml

          kubectl get --namespace=php-service configmaps

          kubectl get --namespace=php-service configmaps nginx-config -o yaml

apiVersion: v1  #版本号kind: ConfigMap #配置类型metadata: #元数据  name: nginx-config  #该 ConfigMap 的名称  namespace: php-service #该 ConfigMap 所在命名空间data: #数据  nginx_conf: |-    user  www-data;    worker_processes  1;     error_log  /var/log/nginx/error.log warn;    pid        /var/run/nginx.pid;     events {        worker_connections  1024;    }     http {        include       /etc/nginx/mime.types;        default_type  application/octet-stream;         log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                          '$status $body_bytes_sent "$http_referer" '                          '"$http_user_agent" "$http_x_forwarded_for"';         access_log  /var/log/nginx/access.log  main;         sendfile        on;        #tcp_nopush     on;         keepalive_timeout  65;         #gzip  on;         server {            listen       80;            server_name  _;            root         /var/www/html/public;            index     index.php;             #charset koi8-r;            #access_log  /var/log/nginx/log/host.access.log  main;             #error_page  404              /404.html;             # redirect server error pages to the static page /50x.html            #            error_page   500 502 503 504  /50x.html;            location = /50x.html {                root   /usr/share/nginx/html;            }             location / {              try_files $uri $uri/ /index.php?$query_string;            }             # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000             location ~ \.php$ {                include fastcgi_params;                fastcgi_param REQUEST_METHOD $request_method;                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;                fastcgi_pass 127.0.0.1:9000;            }             location /backend/  {                index  index.html;                alias  /var/www/html/backend/dist/;            }             location /statics/{                alias /var/www/html/backend/dist/statics/;            }             # deny access to .htaccess files, if Apache's document root            # concurs with nginx's one            #            #location ~ /\.ht {            #    deny  all;            #}        }     }

5. 创建Nginx Service【nginx-service.yaml】

           kubectl create -f nginx-service.yaml

           kubectl get --namespace=php-service service -o wide

           kubectl get --namespace=php-service service nginx-service -o yaml

apiVersion: v1  #版本号kind: Service #配置类型metadata: #元数据  name: nginx-service #该Service 的名称  namespace: php-service #该 Service 所在命名空间  labels: #标签    app: nginx  #为该 Service 设置 key 为 app,value 为 nginx 的标签spec: #关于该 Service 的定义,描述了 Service 如何选择 Pod,如何被访问  selector: #标签选择器    app: kayaka   #选择包含标签 app:kayaka 的Pod  type: NodePort  #Serive的类型,ClusterIP/NodePort/LoaderBalancer  ports:    - name: http  #端口的名字      protocol: TCP #协议类型 TCP/UDP      port: 80 #集群内的其他容器组可通过 80 端口访问 Service      #port: 30080 #通过任意节点的 32600 端口访问 Service,不固定自动设置      targetPort: 80 #将请求转发到匹配 Pod 的 80 端口

6. 创建App Deployment【app-deployment.yaml】(主要采用 POD-容器组(php-fpm和nginx)的方式)

          kubectl apply -f app-deployment.yaml

          kubectl get --namespace=php-service deployments -o wide

          kubectl get --namespace=php-service deployments kayaka -o wide

          kubectl get --namespace=php-service deployments kayaka -o yaml   

apiVersion: apps/v1  #与k8s集群版本有关,使用 kubectl api-versions 即可查看当前集群支持的版本kind: Deployment  #配置类型,这里使用的是 Deploymentmetadata: #元数据,即 Deployment 的一些基本属性和信息  name: kayaka  #该Deployment 的名称  namespace: php-service  #Pod所属的命名空间  labels: #标签,可以灵活定位一个或多个资源,其中key和value均可自定义,可以定义多组    app: kayaka #为该Deployment设置key为app,value为nginx的标签spec: #该Deployment的描述,可以理解为你期待该Deployment在k8s中如何使用  selector: #标签选择器,与上面的标签共同作用,目前不需要理解    matchLabels: #选择包含标签app:kayaka的资源      app: kayaka  replicas: 2 #使用该Deployment创建几个应用程序实例  strategy: #更新策略    type: RollingUpdate #Recreate 重新创建  RollingUpdate 滚动升级  template: #选择或创建的Pod的模板    metadata: #Pod的元数据      labels: #Pod的标签,上面的selector即选择包含标签app:kayaka的Pod        app: kayaka    spec: #期望Pod实现的功能(即在pod中部署)      containers: #生成container,与docker中的container是同一种        - name: kayaka #container的名称          image: harbor.dobest.com/tfctest/kayaka:1.0.0 #镜像地址          imagePullPolicy: Always #镜像拉取策略 Always 总是拉去、IfNotPresent 优先使用本地、Never 仅使用本地          ports: #容器端口            - containerPort: 9000          #env:          #- name: REDIS_HOST          #value: redis-service          envFrom: #ENV 配置来源(无法热更新)            - configMapRef:                name: app-env-config          volumeMounts: #挂载到容器内部的存储卷配置            - name: nginx-www #引用pod定义的共享存储卷的名称,需用volumes[]部分定义的的卷名              mountPath: /var/www/html #存储卷在容器内mount的绝对路径              readOnly: false #是否为只读模式          lifecycle: #container 的生命周期            postStart: #容器开始启动执行事件              exec:                command: [ "/bin/sh","-c","cp -r /www/* /var/www/html && chown -R www-data:www-data /var/www/html/storage" ]        - name: nginx          image: nginx:1.7.9          ports:            - containerPort: 80          volumeMounts:            - mountPath: /var/www/html              name: nginx-www            - mountPath: /etc/nginx/nginx.conf              subPath: nginx.conf              name: nginx-config      volumes: #该pod上定义共享存储卷列表        - name: nginx-www #共享存储卷名称 (volumes类型有很多种)          emptyDir: { } #类型为emtyDir的存储卷,与Pod同生命周期的一个临时目录。为空值        - name: nginx-config  #共享存储卷名称(volumes类型有很多种)          configMap: #类型为configMap的存储卷,挂载预定义的configMap对象到容器内部            name: nginx-config            items:              - key: nginx_conf                path: nginx.conf

7. 创建Ingress【ingress.yaml】路由

          kubectl apply -f ingress.yaml

          kubectl get --namespace=php-service ingress -o wide

          kubectl get --namespace=php-service ingress ingress

          kubectl get --namespace=php-service ingress ingress -o yaml   

apiVersion: extensions/v1beta1  #版本号kind: Ingress #配置类型metadata: #元数据  name: ingress #该 Ingress 的名称  namespace: php-service  #该 Ingress 所在命名空间  labels: #标签    app: ingressspec: #该 Ingress 的描述  rules: # 规则    - host: test-kyk.sanguosha.com # 域名      http:        paths: # 路径          - backend:              serviceName: nginx-service #服务名称              servicePort: 80 #服务端口            path: /

注意事项

来源地址:https://blog.csdn.net/qq_34272964/article/details/128322139

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯