云计算-容器云-编排部署 Hyperf 框架

打印 上一主题 下一主题

主题 1887|帖子 1887|积分 5661

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Hyperf编排部署

    1、 Hyperf概述 只管现在基于PHP语言开发的框架处于一个百家争鸣的期间,但仍旧未能看到一个优雅的设计与超高性能的共存的完美框架,亦没有看到一个真正为PHP微服务铺路的框架,此为Hyperf及其团队成员的初志。
    Hyperf是一个高性能、高灵活性的渐进式PHP协程框架,内置协程服务器及大量常用的组件,性能较传统基于PHP-FPM的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于PSR标准实现和强盛的依赖注入设计,保证了绝大部门组件或类都是可替换与可复用的。
    Hyperspeed + Flexibility = Hyperf,从名字上就可以看出超高速和灵活性是Hyperf的基因。对于超高速,Hyperf基于Swoole和Swow协程,并在框架设计上进行大量的优化以确保超高性能的输出。对于灵活性,Hyperf强盛的依赖注入组件,组件均基于PSR标准的左券和由Hyperf界说的左券实现,达到框架内的绝大部门的组件或类都是可替换的。
    环境准备

        
  1. [root@k8s-master-node1 ~]# tar -zxvf Hyperf.tar.gz
  2. [root@k8s-master-node1 ~]# cd hyperf/
  3. [root@k8s-master-node1 hyperf]# docker load -i centos_7.9.2009.tar
  4. [root@k8s-master-node1 hyperf]# vim local.repo
  5. [yum]
  6. name=yum
  7. baseurl=file:///root/yum
  8. gpgcheck=0
  9. enabled=1  
复制代码
       【题目 1】容器化 MariaDB 服务[1 分]

         编写Dockerfile文件构建hyperf-mariadb:v1.0镜像,具体要求如下:(需要用到的软件包: Hyperf.tar.gz) (1)底子镜像:centos:7.9.2009; (2)完成 MariaDB 服务的安装; (3)声明端口:3306; (4)设置数据库 root 用户的密码为 root; (5)将提供的数据库文件 hyperf_admin.sql 导入数据库; (6)设置服务开机自启。 完成后构建镜像,并提交 master 节点的用户名、密码和 IP 地点到答题框。
            
  1. [root@k8s-master-node1 hyperf]# vim Dockerfile-mariadb
  2. FROM centos:7.9.2009
  3. RUN rm -rf /etc/yum.repos.d/*
  4. ADD local.repo /etc/yum.repos.d/
  5. ADD yum /root/yum
  6. RUN yum install mariadb mariadb-server -y
  7. COPY sql/hyperf_admin.sql /opt
  8. RUN mysql_install_db --user=root
  9. RUN mysqld_safe --user=root & sleep 8;\
  10.     mysqladmin -uroot password root ;\
  11.     mysql -uroot -proot -e "grant all privileges on*.*to 'root'@'%' identified by 'root';";\
  12.     mysql -uroot -proot -e "source /opt/hyperf_admin.sql;"
  13. EXPOSE 3306
  14. CMD ["mysqld_safe","--user=root"]
  15. [root@k8s-master-node1 hyperf]# docker build -t hyperf-mariadb:v1.0 -f Dockerfile-mariadb .
复制代码
       【题目 2】容器化 Redis 服务[1 分]

         编写 Dockerfile 文件构建 hyperf-redis:v1.0 镜像,具体要求如下: (需要用到的软件包: Hyperf.tar.gz) (1)底子镜像:centos:7.9.2009; (2)安装 Redis 服务; (3)关闭掩护模式; (4)声明端口:6379; (5)设置服务开机自启。 完成后构建镜像,并提交 master 节点的用户名、密码和 IP 地点到答题框。
            
  1. [root@k8s-master-node1 hyperf]# vim Dockerfile-redis
  2. FROM centos:7.9.2009
  3. RUN rm -rf /etc/yum.repos.d/*
  4. ADD local.repo /etc/yum.repos.d/
  5. ADD yum /root/yum
  6. RUN yum install redis -y
  7. RUN sed -i 's/127.0.0.1/0.0.0.0/g' /etc/redis.conf
  8. RUN sed -i 's/-mode yes/-mode no/g' /etc/redis.conf
  9. EXPOSE 6379
  10. CMD ["/usr/bin/redis-server","/etc/redis.conf"]
  11. [root@k8s-master-node1 hyperf]# docker build -t hyperf-redis:v1.0 -f Dockerfile-redis .
复制代码
       【题目 3】容器化 Nginx 服务[0.5 分]

         编写 Dockerfile 文件构建 hyperf-nginx:v1.0 镜像,具体要求如下: (需要用到的软件包: Hyperf.tar.gz) (1)底子镜像:centos:7.9.2009; (2)安装 nginx 服务; (3)声明端口:80; (4)设置服务开机自启。 完成后构建镜像,并提交 master 节点的用户名、密码和 IP 地点到答题框。
            
  1. [root@k8s-master-node1 hyperf]# vim Dockerfile-nginx
  2. FROM centos:7.9.2009
  3. RUN rm -rf /etc/yum.repos.d/*
  4. ADD local.repo /etc/yum.repos.d/
  5. ADD yum /root/yum
  6. RUN yum install nginx -y
  7. EXPOSE 80
  8. CMD ["nginx","-g","daemon off;"]
  9. [root@k8s-master-node1 hyperf]# docker build -t hyperf-nginx:v1.0 -f Dockerfile-nginx .
复制代码
       【题目 4】容器化 Hyperf 服务[1 分]

         编写 Dockerfile 文件构建 hyperf-service:v1.0 镜像,具体要求如下:(需要用到的软件包: Hyperf.tar.gz) (1)底子镜像:centos:7.9.2009; (2)安装 PHP 及扩展; (3)使用源码编译安装 Swoole。 完成后构建镜像,并提交 master 节点的用户名、密码和 IP 地点到答题框。
            
  1. [root@k8s-master-node1 hyperf]# vim Dockerfile-service
  2. FROM centos:7.9.2009
  3. RUN rm -rf /etc/yum.repos.d/*
  4. ADD local.repo /etc/yum.repos.d/
  5. ADD yum /root/yum
  6. RUN yum install git autoconf gcc gcc-c++ unzip which tzdara php-* yum-utils dpkg-devel -y
  7. ADD swoole-v4.8.3.zip /tmp
  8. RUN cd /tmp && unzip swoole-v4.8.3.zip && mv swoole-v4.8.3 swoole
  9. RUN cd /tmp/swoole && phpize && ./configure --enable-openssl --enable-http2 --enable-mysqlnd && make -s -j$(nproc) && make install
  10. RUN echo "extension=swoole.so" >> /etc/php.d/20-swoole.ini
  11. [root@k8s-master-node1 hyperf]# docker build -t hyperf-service:v1.0 -f Dockerfile-service .
复制代码
       【题目 5】编排部署 Hyperf 框架[3.5 分]

         编写/root/hyperf/project/docker-compose.yaml 文件,具体要求如下: (1)容器 1 名称:hyperf-mysql;镜像:hyperf-mariadb:v1.0;端口映射:3306:3306; (2)容器 2 名称:hyperf-redis;镜像:hyperf-redis:v1.0; (3)容器 3 名称:hyperf-ui;镜像:hyperf-nginx:v1.0;端口映射:80:8081; (4)容器 4 名称:hyperf-service;镜像:hyperf-service:v1.0。 完成后编排部署 Hyperf 框架,并提交 master 节点的用户名、密码和 IP 地点到答题框。
            
  1. [root@k8s-master-node1 project]# vi docker-compose.yaml
  2. version: '3'
  3. services:
  4.   app:
  5.     container_name: hyperf-service
  6.     image: hyperf-service:v1.0
  7.     restart: always
  8.     command: "sleep 2h"
  9.   hyperf-mysql:
  10.     container_name: hyperf-mysql
  11.     image: hyperf-mariadb:v1.0
  12.     restart: always
  13.     ports:
  14.     - 3306:3306
  15.   hyperf-redis:
  16.     container_name: hyperf-redis
  17.     image: hyperf-redis:v1.0
  18.     restart: always
  19.   hyperf-ui:
  20.     container_name: hyperf-ui
  21.     image: hyperf-nginx:v1.0
  22.     restart: always
  23.     ports:
  24.     - "8081:80"
  25.     volumes:
  26.     - /root/hyperf/project/docker/conf.d:/etc/nginx/conf.d
  27.     - /root/hyperf/project/frontend:/var/www/frontend
  28. [root@k8s-master-node1 project]# docker-compose up -d
  29. [root@k8s-master-node1 project]# docker-compose ps
  30.      Name                  Command              State                    Ports                  
  31. ------------------------------------------------------------------------------------------------
  32. hyperf-mysql     mysqld_safe --user=root        Up      0.0.0.0:3306->3306/tcp,:::3306->3306/tcp
  33. hyperf-redis     redis-server /etc/redis.conf   Up      6379/tcp                                
  34. hyperf-service   sleep 2h                       Up                                             
  35. hyperf-ui        nginx -g daemon off;           Up      0.0.0.0:8081->80/tcp,:::8081->80/tcp  
复制代码
       登录 (账号/密码)daodao/a1a1a1)
         本文由博客一文多发平台 OpenWrite 发布!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

南飓风

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表