基于宝塔面板安装部署mochat

安装前必看重要提示:

由于项目是前后端分离方式开发和部署的,所以安装演示过程中会用到三个域名:

  • 商户后台:dashboard.test
  • 聊天侧边栏:sidebar.test
  • 后端API接口:backend.test
  • 运营工具:operation.test

假设你自己的主域名是 mochat.com,那你可以分别配置为,以下域名可以自定义,下面只是举例:

  • 商户后台:scrm.mochat.com
  • 聊天侧边栏:h5.mochat.com
  • 后端API接口:api.mochat.com
  • 运营工具:op.mochat.com

#安装宝塔面板

  1. 阿里云ECS服务器,重新初始化操作系统 , 申请OSS ALiyunOS,安全组开放宝塔8888端口
  2. 安装面板,执行以下命令
~# yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh

Image text

3. 宝塔面板安装完成


Image text

#安装环境

  1. 打开宝塔面板-登录


    Image text
  2. 宝塔面板软件商店里面安装软件

    • nginx 1.18


      Image text
      Image text
      Image text
    • php74


      Image text
      Image text
    • mysql5.7


      Image text
      Image text
      Image text
    • PM2管理器 -4.2


      Image text
    • PM2管理器->模块管理->yarn 安装(绑定环境变量export PATH=$PATH:/www/server/nvm/versions/node/v14.16.0/bin)


      Image text
      Image text
  3. 安装Swoole

    • 宝塔面板->软件商店->PHP-7.4->安装扩展->Swoole4


      Image text
    • 宝塔面板->软件商店->PHP-7.4->配置文件-> 最后添加以下配置并保存

    [swoole]
            extension = swoole.so
            swoole.use_shortname = off
    
    
    Image text
  4. 安装Redis

    • 宝塔面板->软件商店->PHP-7.4->安装扩展->redis


      Image text
  5. 安装php7-wxwork-finance-sdk

    • 执行以下命令进行安装
    ~# cd /www
    /www# git clone https://github.com/pangdahua/php7-wxwork-finance-sdk.git
    /www# wget https://wwcdn.weixin.qq.com/node/wework/images/sdk_20200401.zip
    
    
    Image text
    /www# unzip sdk_20200401.zip
    
    
    Image text
    /www# cd php7-wxwork-finance-sdk
    /www/php7-wxwork-finance-sdk# /www/server/php/74/bin/phpize
    /www/php7-wxwork-finance-sdk# ./configure --with-php-config=/www/server/php/74/bin/php-config --with-wxwork-finance-sdk=/www/sdk_20200401/C_sdk
    /www/php7-wxwork-finance-sdk# make && make install
    
    
    Image text
    Image text
    • 宝塔面板->软件商店->PHP-7.4->配置文件->最后面添加以下配置并保存
    [wxwork_finance_sdk]
            extension=wxwork_finance_sdk.so
    
    
    Image text
  6. 安装fileinfo

    • 宝塔面板->软件商店->PHP-7.4->安装扩展->fileinfo


      Image text
  7. 安装ffmpeg

    • 执行以下命令进行安装
    /www# cd /www
    /www# wget https://ffmpeg.org/releases/ffmpeg-snapshot.tar.bz2
    /www# tar -jxvf ffmpeg-snapshot.tar.bz2
    
    
    Image text
    /www# yum install yasm -y
    /www# cd ffmpeg
    /www/ffmpeg# ./configure --enable-shared && make && make install
    
    
    Image text
    Image text
    ## 验证
    /www/ffmpeg# ffmpeg -version
    
    ## 提示错误
    ffmpeg: error while loading shared libraries: libavdevice.so.58: cannot open shared object file: No such file or directory
    
    ## 查找错误原因
    /www/ffmpeg# ldd ffmpeg
    
    ## 查找缺失文件
    /www/ffmpeg# find /usr -name 'libavdevice.so.58'
    
    ## 得到文件路径
    /usr/local/lib/libavdevice.so.58
    
    
    Image text
    ## 添加
    export LD_LIBRARY_PATH=/usr/local/lib/
    
    
    Image text
    ## 完成
    /www/ffmpeg# ffmpeg -version
    
    
    Image text
  8. 确认相关环境正确安装(https://mochat.wiki (opens new window)

    • 查看 PHP 版本是否正确,需 >= 7.2,建议 7.4
    php -v
    
    
    Image text
    • 查看 Swoole 版本安装是否正确,并确定 swoole.use_shortname 参数值为 Off
    php --ri swoole
    
    
    Image text
    • 查看 Reids wxwork_finance_sdk 扩展是否正确安装
    php --ri redis
    php --ri wxwork_finance_sdk
    
    
    Image text
    Image text
    • 查看FFMpeg
    ffmpeg -version
    
    
    Image text
    • 确保内存大于 1024M
    php -i | grep memory_limit
    
    

#安装项目

  1. 安装MoChat后端

    • 宝塔面板->软件商店->PHP-7.4->禁用函数->删除symlink,putenv,proc_open,pcntl系列函数


      Image text
      Image text
    • 执行以下命令安装项目

    # composer config -g repo.packagist composer https://mirrors.aliyun.com/composer
    # /usr/bin/composer self-update
    
    
    Image text
    # cd /www/wwwroot
    # git clone https://github.com/mochat-cloud/mochat.git
    # cd /www/wwwroot/mochat/api-server
    # composer install
    # cp .env.example .env
    
    
    Image text
    • 初始化项目,mysql数据库需要5.7版本及以上(5.7引入了json类型)执行以下命令:
    # php bin/hyperf.php mc:init
    # php bin/hyperf.php server:start -d
    
    
    Image text
    Image text
    Image text
    Image text

    注:如果不知道宝塔面板mysql默认安装的密码,请查看


    Image text

    注:如果没有mochat数据库,请链接数据库创建mochat数据库


    Image text
  2. 配置前端

    • PC管理后台

    #这里修改的域名一定要写成后端api接口的域名,不要写错了。

    #比如,http://api.mochat.comhttp://backend.test

    # cd /www/wwwroot/mochat/dashboard
    # cp .env.example .env
    # 这里修改的域名一定要写成后端api接口的域名,不要写错了,比如,http://api.mochat.com 或 http://backend.test   # vi .env #修改配置文件,不会vi可以用其他编辑器打开该文件
    # yarn install
    # yarn run dll
    # yarn run build (2小时15分 # Screen -S dashboard)
    
    
    Image text
    Image text
    • 侧边栏

    #这里修改的域名一定要写成后端api接口的域名,不要写错了。

    #比如,http://api.mochat.comhttp://backend.test

    # cd /www/wwwroot/mochat/sidebar
    # cp .env.example .env
    # 这里修改的域名一定要写成你自己的后端api接口的域名,不要写错了,比如,http://api.mochat.com 或 http://backend.test
    # vi .env #修改配置文件,不会vi可以用其他编辑器打开该文件
    # yarn install
    # yarn run build
    
    
    Image text
    Image text

    注:如果再次修改.env配置文件重新构建项目时报如下错误,执行以下代码

    [图片上传失败...(image-99ec85-1646289600005)]

    执行以下命令
    # chattr -i /www/wwwroot/mochat/sidebar/dist/.user.ini  
    再进行删除
    # rm -f /www/wwwroot/mochat/sidebar/dist/.user.ini 
    再次进入目录编译
    # yarn run build
    
    
    # cd /www/wwwroot/mochat/operation
    # cp .env.example .env
    # 这里修改的域名一定要写成你自己的后端api接口的域名,不要写错了,比如,http://api.mochat.com 或 http://backend.test
    # vi .env #修改配置文件,不会vi可以用其他编辑器打开该文件
    # yarn install
    # yarn run build
    
    

    注:如果再次修改.env配置文件重新构建项目时报如下错误,执行以下代码

    [图片上传失败...(image-e2d9c4-1646289600005)]

    执行以下命令
    # chattr -i /www/wwwroot/mochat/operation/dist/.user.ini  
    再进行删除
    # rm -f /www/wwwroot/mochat/operation/dist/.user.ini 
    再次进入目录编译
    # yarn run build
    
    
  3. 宝塔面板配置站点

    • 网站 ---添加站点 backend.test php版本 纯静态,数据库 不创建 反向代理 目标URL:http://127.0.0.1:9501 发送域名 $host 开启代理 如图:


      Image text
      Image text
      Image text

    配置完代理,点配置文件,增加跨域设置如下:

    location ~* \.(gif|png|jpg|css|js|woff|woff2)$
    {
        proxy_pass http://127.0.0.1:9501;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header REMOTE-HOST $remote_addr;
    
        # 设置跨域
        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Methods 'GET, POST, PUT, DELETE, PATCH, OPTIONS';
        add_header Access-Control-Allow-Headers 'Accept,Origin,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
        expires 12h;
    }
    
    
    • 网站 ---添加站点 dashboard.test php版本 纯静态,数据库 不创建 网站目录 /www/wwwroot/mochat/dashboard/dist 如图:


      Image text
    • 找到刚添加的网站,点右侧的设置,进入之后点配置文件,以如图所示的位置加上

    location / {
          root /www/wwwroot/mochat/dashboard/dist;
          index  index.html index.htm;
          try_files $uri $uri/ /index.html;
        }
    
    location /authRedirect {
            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;
            # http时使用下面的配置
            proxy_cookie_path / "/; HttpOnly; SameSite=strict";
            # https时使用下面的配置
            # proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict";
    
            proxy_pass http://127.0.0.1:9501/dashboard/officialAccount/authRedirect/;
        }
    
    
    Image text
    • 网站 ---添加站点 sidebar.test php版本 纯静态,数据库 不创建 网站目录/www/wwwroot/mochat/sidebar/dist 如图:


      Image text
    • 找到刚添加的网站,点右侧的设置,进入之后点配置文件,以如图所示的位置加上

      location / {
            root /www/wwwroot/mochat/sidebar/dist;
            index  index.html index.htm;
            try_files $uri $uri/ /index.html;
          }
      
      location ^~ /*.txt {
          proxy_pass http://127.0.0.1:9501/;
      } 
      
      
      Image text
    • 网站 ---添加站点 operation.test php版本 纯静态,数据库 不创建 网站目录/www/wwwroot/mochat/operation/dist 如图:


      Image text
      • 找到刚添加的网站,点右侧的设置,进入之后点配置文件,以如图所示的位置加上

        location / {
              root /www/wwwroot/mochat/operation/dist;
              index  index.html index.htm;
              try_files $uri $uri/ /index.html;
            }
        
        location ^~ /auth/ {
                    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;
                    # http时使用下面的配置
                    proxy_cookie_path / "/; HttpOnly; SameSite=strict";
                    # https时使用下面的配置
                    # proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict";
        
                    proxy_pass http://127.0.0.1:9501/operation/auth/;
               }
        
           location ^~ /openUserInfo/ {
                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;
                # http时使用下面的配置
                proxy_cookie_path / "/; HttpOnly; SameSite=strict";
                # https时使用下面的配置
                # proxy_cookie_path / "/; secure; HttpOnly; SameSite=strict";
        
                proxy_pass http://127.0.0.1:9501/operation/openUserInfo/;
           }
        
        
        Image text
  4. 访问

    • 后端接口访问 backend.test


      Image text
    • 管理后台 dashboard.test 如图:


      Image text
      Image text

    注意:如果后端接口访问成功,后端界面登录不成功报401的话,可能的原因是初始化管理员密码没成功,请登录mysql重置一下管理员密码

    • 首先查看.env中的默认密钥后缀配置,生成一下密码:


      Image text
    php -r "var_dump(password_hash(md5('123456' . '3S6ybWbSy&23fFeq8'), PASSWORD_BCRYPT));"
    
    
    Image text
    • 登录mysql重新设置一下管理员登录密码:
    # mysql -u用户名 -p密码 
    # mysql> use mochat
    # mysql> update mc_user set password="密码";
    # mysql> select * from mc_user \G; 
    
    
    Image text

#常见问题

  • nginx设置反向代理后,返回 502 bad gateway?

请检查后端 api-server 启动成功没有,命令如下:

ps aux | grep mochat

看看有没有对应的进程,如果没有,刚需执行如下命令启动

cd /www/wwwroot/mochat/api-server
php bin/hyperf.php server:start -d

为了服务稳定,建议使用更专业的进程管理工具来启动,详见:Supervisor 部署

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容