Skip to content

Hyperf-Glory/socket-io

Repository files navigation

服务器马上到期,demo预览不了。后续会补上.谢谢各位的star

请暂时不要用于生产环境

项目还在开发优化中

Socket-IO

再次升级,此版本采用hyperf2.x+Vue+Element搭建的分布式Socket-io系统,利用rpc作为注册,鉴权服务,rpc发布到注册中心.利用dao-cloud+docker多容器部署目前已初步搭建完成,待完成系统业务会继续优化,写份教程供大家学习. 此次系统的业务逻辑借鉴lumen-im 的逻辑用hyperf重写,第一版本求稳定运行上线.第二版本会重新整理业务架构,代码更加优化。更加符合PHP规范化.

Php Version Swoole Version sl-im License

简介

socket-io 是基于 Hyperf 微服务协程框架(Swoole)和 Vue + ElementUI 网页聊天系统 所开发出来的聊天室。

体验地址

Socket-IO

功能

1.0

  • 基于Swoole Socket-io服务做消息即时推送
  • 支持私聊及群聊
  • 支持聊天消息类型有文本、代码块、图片及其它类型文件,并支持文件下载
  • 支持聊天消息撤回、删除或批量删除、转发消息(逐条转发、合并转发)
  • 支持docker部署(后续写搭建教程)
  • Rpc服务注册登录鉴权
  • Nsq分布式消息中间件
  • Mysql提供数据存储功能
  • Redis存储聊天关系映射

问题

Json-Rpc 业务架构比较混乱和Service层架构冲突。下个版本着重优化,把HTTP和Rpc部分业务分到Service层. 代码规范不符合现代化.有重复的代码使用.socket-io服务单独重构独立成为分布式服务 也许它存在很多问题,但是也请大家多一份耐心,毕竟一个人的开发精力有限。项目我会一直维持下去。 也希望证明php也是可以做分布式的。恢复php荣光,我辈义不容辞.

2.0

  • 重新架构
  • 代码更符合PHP标准化

Requirement

单机部署方式

Composer

composer install

env配置

APP_NAME=skeleton APP_ENV=dev DB_DRIVER=mysql DB_HOST=localhost DB_PORT=3306 DB_DATABASE=hyperf DB_USERNAME=root DB_PASSWORD= DB_CHARSET=utf8mb4 DB_COLLATION=utf8mb4_unicode_ci DB_PREFIX= REDIS_HOST=localhost REDIS_AUTH=(null) REDIS_PORT=6379 REDIS_DB=0 CLOUD_REDIS=default WEBSOCKET_SERVER_IPS = {"ws1":"127.0.0.1","ws2":"127.0.0.2"} AMQP_HOST=localhost //rabbitmq地址 NSQ_HOST=localhost //nsq地址 CONSUL_HOST=localhost:8500 //consul地址 NSQD_HOST=127.0.0.1:4151 //nsqd地址 //邮箱配置 MAIL_HOST= MAIL_PORT= MAIL_USERNAME= MAIL_PASSWORD= MAIL_FROM= MAIL_NAME= //静态资源地址 IMAGE_URL=http://127.0.0.1:9500 //七牛配置 QINIU_ACCESS_KEY= QINIU_SECRET_KEY= QINIU_BUCKET= QINBIU_DOMAIN= 

nginx配置

# 至少需要一个 Hyperf 节点,多个配置多行 upstream hyperf_chat_http { # Hyperf-Chat HTTP Server 的 IP 及 端口 server 127.0.0.1:9500; server 127.0.0.1:1500; } upstream hyperf_chat_ws { # 设置负载均衡模式为 IP Hash 算法模式,这样不同的客户端每次请求都会与同一节点进行交互 ip_hash; # Hyperf Chat Server 的 IP 及 端口 server 127.0.0.1:9502; server 127.0.0.1:1502; } server { listen 443 ssl; index index.html index.htm; server_name xxx.cn; error_log /home/wwwlogs/xxxerr.log; root /home/wwwroot/hyperf-chat/public; ssl_certificate /etc/ssl/xxx.crt; # 指定私钥文件路径 ssl_certificate_key /etc/ssl/xxx.key; ssl_protocols TLSv1.2 TLSv1.1 TLSv1; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; ssl_prefer_server_ciphers on; ssl_session_timeout 5m; index index.php index.html index.htm; location / { # 将客户端的 Host 和 IP 信息一并转发到对应节点 proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 转发Cookie,设置 SameSite proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict"; # 执行代理访问真实服务器 proxy_pass http://hyperf_chat_http; } location /socket.io { # WebSocket Header proxy_http_version 1.1; proxy_set_header Upgrade websocket; proxy_set_header Connection "Upgrade"; # 将客户端的 Host 和 IP 信息一并转发到对应节点 proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; # 客户端与服务端无交互 60s 后自动断开连接,请根据实际业务场景设置 proxy_read_timeout 60s ; # 执行代理访问真实服务器 proxy_pass http://hyperf_chat_ws; } } server { # 80端口是http正常访问的接口 listen 80; server_name xxx.cn; # 在这里,我做了https全加密处理,在访问http的时候自动跳转到https rewrite ^(.*) https://$host$1 permanent; } 

Start

  • 挂起
composer dump-autoload -o php bin/hyperf.php start

打赏(你的支持是我最大的动力)

联系方式

  • WeChat:naicha_1994
  • QQ:847050412
  • QQ群:658446650

socket-io欢迎star

socket-io

License

LICENSE

About

基于Hyperf微服务协程框架开发的sokcet-io分布式系统

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 2

  •  
  •  

Languages