Go to file
gzydong 01f15a72e0 优化代码 2021-07-06 23:44:17 +08:00
app 优化代码 2021-07-06 23:44:17 +08:00
bin 初始化 2020-12-08 23:32:23 +08:00
config 优化代码 2021-06-30 19:27:49 +08:00
migrations 优化代码 2021-07-05 21:52:44 +08:00
storage 优化代码 2021-06-30 19:27:49 +08:00
test 初始化 2020-11-02 22:45:37 +08:00
.env.example 优化代码 2021-05-24 11:31:36 +08:00
.gitignore 初始化 2020-11-02 22:45:37 +08:00
.gitlab-ci.yml 初始化 2020-11-02 22:45:37 +08:00
.php_cs 初始化 2020-11-02 22:45:37 +08:00
.phpstorm.meta.php 初始化 2020-11-02 22:45:37 +08:00
Dockerfile 初始化 2020-11-02 22:45:37 +08:00
LumenIM 同步SQL.sql 优化代码 2021-07-06 23:32:14 +08:00
README.md no message 2021-01-07 16:09:44 +08:00
change.sql 修改sql 2021-03-26 22:27:00 +08:00
composer.json 优化代码 2021-05-23 16:52:01 +08:00
deploy.test.yml 初始化 2020-11-02 22:45:37 +08:00
message.php 优化代码 2021-07-05 21:52:44 +08:00
phpstan.neon 初始化 2020-11-02 22:45:37 +08:00
phpunit.xml 初始化 2020-11-02 22:45:37 +08:00
更新计划.md 优化代码 2021-07-05 23:28:14 +08:00

README.md

Lumen-IM

1、简介

这是一个使用Hyperf框架的开发的IM后端应用程序。此项目是 LumenIM-Serve 的重构版本。

Lumen-IM 是一个网页版在线即时聊天项目,前端使用 Element-ui + Vue ,后端使用 PHP+Swoole 进行开发。项目后端采用 Hyperf 框架。

  • 基于Swoole WebSocket服务做消息即时推送
  • 支持私聊及群聊
  • 支持聊天消息类型有文本、代码块、图片及其它类型文件,并支持文件下载
  • 支持聊天消息撤回、删除或批量删除、转发消息(逐条转发、合并转发)
  • 支持编写个人笔记、支持笔记分享(好友或群)

2、项目Demo

3、环境要求

  • PHP >= 7.2
  • Swoole >= 4.4
  • OpenSSL
  • JSON
  • PDO
  • Redis >= 5.0.0
  • AMQP

4、相关文档

Hyperf 框架

5、项目安装

  1. 下载源码包
  2. 安装框架依赖包执行 compsoer install 命令 [项目根目录下执行]
  3. 拷贝项目根目录下 .env.example 文件为 .env 并正确配置相关参数mysql、redis、rabbitmq
  4. 执行数据库迁移文件命令生成相关数据表 php bin/hyperf.php migrate
  5. 启动运行项目 php bin/hyperf.php start

[项目运行之前请确保 Mysql、Redis、RabbitMQ 及 Nginx 服务]

Nginx 相关配置(代理 swoole 服务)

配置 Http 服务
upstream hyperfhttp {
    # Hyperf HTTP Server 的 IP 及 端口
    server 127.0.0.1:9503;
}

server {
    # 监听端口
    listen 80;
    # 绑定的域名,填写您的域名
    server_name im-serve.xxx.com;

    location / {
        client_max_body_size    20m;
        # 将客户端的 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://hyperfhttp;
    }
}
配置 WebSocket 服务
# 至少需要一个 Hyperf 节点,多个配置多行
upstream hyperf_websocket {
    server 127.0.0.1:9504;
}

server {
    listen 80;
    server_name im-socket.xxx.com;

    location / {
        # 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_websocket;
    }
}
配置图片域名
server {
    listen 80;
    server_name  im-img.xxx.xxx;
    index  index.html;

    # 默认禁止访问
    location / {
        deny all;
    }

    # 只允许 访问 images 文件夹下的文件
    location ^~ /media/{
        # 设置目录别名(确保是项目上传文件目录)
        # 例如 upload_dir = /www/data/lumenim
        # 此时应配置 alias /www/data/lumenim/media/
        
        alias /www/data/lumenim/media/;

        # 设置缓存时间(3天)
        expires 3d;

        # 关闭访问日志
        access_log off;
    }
}

注意事项

  1. 请确保 PHP 安装 openssl、redis、amqp 扩展
  2. 请确保 Swoole 扩展开启 openssl 扩展
[root@iZuf6cs69fbc86cwpu9iv3Z vhost]# php --ri swoole
swoole
Swoole => enabled
Author => Swoole Team <team@swoole.com>
Version => 4.5.9
...
openssl => OpenSSL 1.0.2k-fips  26 Jan 2017 (请确保此处开启)
  1. 请确保 RabbitMQ 中添加了对应的vhost