php分布式socket-io初始版本上线啦!

请暂时不要用于生产环境

项目还在开发优化中

Socket-IO

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

Socket-IO服务聊天系统

1496800949298.jpg

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

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

pay.jpeg

联系方式

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

socket-io欢迎star

socket-io

License

LICENSE

本作品采用《CC 协议》,转载必须注明作者和本文链接
CodingHePing
讨论数量: 2

file

预览账号登录不了

3年前 评论
CodingHePing (楼主) 3年前

哥这是你写第二个im吗

3年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!