Hyperf编排部署
1、 Hyperf概述
尽管现在基于PHP语言开发的框架处于一个百家争鸣的时代,但仍旧未能看到一个优雅的设计与超高性能的共存的完美框架,亦没有看到一个真正为PHP微服务铺路的框架,此为Hyperf及其团队成员的初衷。
Hyperf是一个高性能、高灵活性的渐进式PHP协程框架,内置协程服务器及大量常用的组件,性能较传统基于PHP-FPM的框架有质的提升,提供超高性能的同时,也保持着极其灵活的可扩展性,标准组件均基于PSR标准实现和强大的依赖注入设计,保证了绝大部分组件或类都是可替换与可复用的。
Hyperspeed + Flexibility = Hyperf,从名字上就可以看出超高速和灵活性是Hyperf的基因。对于超高速,Hyperf基于Swoole和Swow协程,并在框架设计上进行大量的优化以确保超高性能的输出。对于灵活性,Hyperf强大的依赖注入组件,组件均基于PSR标准的契约和由Hyperf定义的契约实现,达到框架内的绝大部分的组件或类都是可替换的。
环境准备
[root@k8s-master-node1 ~]# tar -zxvf Hyperf.tar.gz
[root@k8s-master-node1 ~]# cd hyperf/
[root@k8s-master-node1 hyperf]# docker load -i centos_7.9.2009.tar
[root@k8s-master-node1 hyperf]# vim local.repo
[yum]
name=yum
baseurl=file:///root/yum
gpgcheck=0
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 地址到答题框。
[root@k8s-master-node1 hyperf]# vim Dockerfile-mariadb
FROM centos:7.9.2009
RUN rm -rf /etc/yum.repos.d/*
ADD local.repo /etc/yum.repos.d/
ADD yum /root/yum
RUN yum install mariadb mariadb-server -y
COPY sql/hyperf_admin.sql /opt
RUN mysql_install_db --user=root
RUN mysqld_safe --user=root & sleep 8;\
mysqladmin -uroot password root ;\
mysql -uroot -proot -e "grant all privileges on*.*to 'root'@'%' identified by 'root';";\
mysql -uroot -proot -e "source /opt/hyperf_admin.sql;"
EXPOSE 3306
CMD ["mysqld_safe","--user=root"]
[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 地址到答题框。
[root@k8s-master-node1 hyperf]# vim Dockerfile-redis
FROM centos:7.9.2009
RUN rm -rf /etc/yum.repos.d/*
ADD local.repo /etc/yum.repos.d/
ADD yum /root/yum
RUN yum install redis -y
RUN sed -i 's/127.0.0.1/0.0.0.0/g' /etc/redis.conf
RUN sed -i 's/-mode yes/-mode no/g' /etc/redis.conf
EXPOSE 6379
CMD ["/usr/bin/redis-server","/etc/redis.conf"]
[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 地址到答题框。
[root@k8s-master-node1 hyperf]# vim Dockerfile-nginx
FROM centos:7.9.2009
RUN rm -rf /etc/yum.repos.d/*
ADD local.repo /etc/yum.repos.d/
ADD yum /root/yum
RUN yum install nginx -y
EXPOSE 80
CMD ["nginx","-g","daemon off;"]
[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 地址到答题框。
[root@k8s-master-node1 hyperf]# vim Dockerfile-service
FROM centos:7.9.2009
RUN rm -rf /etc/yum.repos.d/*
ADD local.repo /etc/yum.repos.d/
ADD yum /root/yum
RUN yum install git autoconf gcc gcc-c++ unzip which tzdara php-* yum-utils dpkg-devel -y
ADD swoole-v4.8.3.zip /tmp
RUN cd /tmp && unzip swoole-v4.8.3.zip && mv swoole-v4.8.3 swoole
RUN cd /tmp/swoole && phpize && ./configure --enable-openssl --enable-http2 --enable-mysqlnd && make -s -j$(nproc) && make install
RUN echo "extension=swoole.so" >> /etc/php.d/20-swoole.ini
[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 地址到答题框。
[root@k8s-master-node1 project]# vi docker-compose.yaml
version: '3'
services:
app:
container_name: hyperf-service
image: hyperf-service:v1.0
restart: always
command: "sleep 2h"
hyperf-mysql:
container_name: hyperf-mysql
image: hyperf-mariadb:v1.0
restart: always
ports:
- 3306:3306
hyperf-redis:
container_name: hyperf-redis
image: hyperf-redis:v1.0
restart: always
hyperf-ui:
container_name: hyperf-ui
image: hyperf-nginx:v1.0
restart: always
ports:
- "8081:80"
volumes:
- /root/hyperf/project/docker/conf.d:/etc/nginx/conf.d
- /root/hyperf/project/frontend:/var/www/frontend
[root@k8s-master-node1 project]# docker-compose up -d
[root@k8s-master-node1 project]# docker-compose ps
Name Command State Ports
------------------------------------------------------------------------------------------------
hyperf-mysql mysqld_safe --user=root Up 0.0.0.0:3306->3306/tcp,:::3306->3306/tcp
hyperf-redis redis-server /etc/redis.conf Up 6379/tcp
hyperf-service sleep 2h Up
hyperf-ui nginx -g daemon off; Up 0.0.0.0:8081->80/tcp,:::8081->80/tcp
登录 (账号/密码):(daodao/a1a1a1)
本文由博客一文多发平台 OpenWrite 发布!
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。