hyperf 配置 https 访问

  最近用hyperf写了支付系统,本地调试支付完成,打包上线部署,要解决https协议进行相应的访问,但是hyperf 官方没有找到相关的ssl配置说明。搜了一下soole还是有几个案例说明,据我的了解,swoole是不用nginx进行代理访问的,hyperf 只能是Nginx代理转发。

基本的原理是:配置一个域名 https://pay.com(nginx 配置443端口) 访问后   重定向到 内部 127.0.0.1:9501 (nginx proxy_pass 代理转发方式)  

nginx 配置

 1 server
 2 {
 3     listen 80;
 4     listen 443 ssl http2;
 5     server_name pay.**.com;#你的域名
 6     index index.php index.html index.htm default.php default.htm default.html;
 7     root /www/wwwroot/pay.bocew.com/hyperf-skeleton/public; #配置这个目录是为了访问静态资源页面,我的项目资源是放在public下;hyperf server.config 是配置了静态资源目录,一旦使用了nginx就会失效访问 404
 8     
 9     #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则
10     #error_page 404/404.html;
11     ssl_certificate    /etc/letsencrypt/live/pay.**.com/fullchain.pem; #证书 阿里云下载 
12     ssl_certificate_key    /etc/letsencrypt/live/pay.**.com/privkey.pem;#证书 我选择的是nginx 下载证书
13     ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
14     ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
15     ssl_prefer_server_ciphers on;
16     ssl_session_cache shared:SSL:10m;
17     ssl_session_timeout 10m;
18     error_page 497  https://$host$request_uri;
19 
20     #SSL-END
30     
31     #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效
32     include /www/server/panel/vhost/rewrite/pay.bocew.com.conf;
33     #REWRITE-END
34     location / {
35         proxy_pass http://127.0.0.1:9501;  #重点在这里了,127.0.0.1 也可以改成你服务器的IP,我docker  hyperf配置是9501映射端口给外网访问
36         proxy_set_header Host $host:$server_port;
37         proxy_set_header X-Real-IP $remote_addr;
38         proxy_set_header X-Real-PORT $remote_port;
39         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
40     }
41     #禁止访问的文件或目录
42     location ~ ^/(\.user.ini|\.htaccess|\.git|\.svn|\.project|LICENSE|README.md)
43     {
44         return 404;
45     }
46     
47     #一键申请SSL证书验证目录相关设置
48     location ~ \.well-known{
49         allow all;
50     }
51   
52    67 }

 

我这边本地开发环境是window10+Docker Desktop 用的docker配置依赖开发环境,以下是本地项目

 

 

 说到这里,顺便补充一下:本地项目开发好了以后,只需要进行镜像打包 成 zip格式包,然后上传到正式环境服务器,正式环境安装好docker

进行镜像包导入即可运行。

本地打包镜像

docker save -o hyperf.zip hyperf/hyperf:7.4-alpine-v3.11-swoole

线上服务器上传后执行(一定要测试docker 环境已经安装了 输入docker 会出现命令,中途省了一些具体操作,时间有限没有贴每个细节步骤了,上传方式可以使用 scp -P 22 hypef.zip root@127.0.0.1:/www/wwwroot/pay.com/  然后输入root 密码 即可上传) 

 

 

 

 

 

docker load --input hyperf.zip 执行完后就能看到一个镜像了,输入docker ps 但是是空的,执行启动命令吧,看下一个步骤

 

 

启动镜像下的容器  pay.com换成自己域名,这不是正式域名

docker run -v /www/wwwroot/pay.com/hyperf-skeleton:/hyperf-skeleton \
-p 9501:9501 -it \
--privileged -u root \
--entrypoint /bin/bash \
hyperf/hyperf:7.4-alpine-v3.11-swoole

 

 

进行容器后运行启动命令

hyperf-skeleton/bin/hyperf.php serve:watch  

下图是项目访问

 

posted @ 2022-06-20 15:57  雷江生  阅读(1027)  评论(0编辑  收藏  举报