Hyperf使用docker-compose集群部署

从运行容器开始

docker run -v /www:/www -p 9601:9601 -p 9602:9602 -p 9603:9603 -it --entrypoint /bin/sh hyperf/hyperf:latest
# 镜像容器运行后,在容器内安装 Composer
wget https://github.com/composer/composer/releases/download/1.8.6/composer.phar
chmod u+x composer.phar
mv composer.phar /usr/local/bin/composer
# 将 Composer 镜像设置为阿里云镜像,加速国内下载速度
composer config -g repo.packagist composer https://mirrors.aliyun.com/composer

$ cd /www
# 通过 Composer 安装 hyperf/hyperf-skeleton 项目
composer create-project hyperf/hyperf-skeleton  api
composer create-project hyperf/hyperf-skeleton  org
composer create-project hyperf/hyperf-skeleton  mms

在每个项目根目录里面都安装watch,这是热加载组件

wget -O watch https://gitee.com/hanicc/hyperf-watch/raw/master/watch

使用docker-compose启动

1、在宿主机的www目录下创建一个docker-compose目录,该目录用于存放相关的docker-compose和dockerfile文件

ps:这里不一定要在www目录下,但是换了其他目录的时候执行docker—compose -f 后面要带路径

2、在docker-compose目录下分别创建三个文件夹api、org、mms,这三个文件夹存储对应项目的dockerfile,内容如下:

FROM hyperf/hyperf

WORKDIR /www
#CMD ["php","bin/hyperf.php","start"]
CMD php watch -c

因为使用的都是同个镜像,所以内容都一样

3、边写docker-compose.yml

version: '2'
networks:
  dev_yes:
services:
  api:
    build:
      context: ./api
      dockerfile: dockerfile
    ports:
      - "9601:9601"
    volumes:
      - /www/api:/www
    networks:
      - dev_yes
  mms:
    build:
      context: ./mms
      dockerfile: dockerfile
    ports:
      - "9602:9602"
    volumes:
      - /www/mms:/www
    networks:
      - dev_yes
  org:
    build:
      context: ./org
      dockerfile: dockerfile
    ports:
      - "9603:9603"
    volumes:
      - /www/org:/www
    networks:
      - dev_yes


在宿主机执行一下命令,启动服务

docker-compose -f /www/docker-compose/docker-compose.yml up

至此服务开启成功!

但是不知道为什么这里的watch热加载组件没有成功~~~

配置服务之间的通讯

api作为消费端

org和mms作为服务端

配置如下:

  • org服务端

先配置

config/autoload/server.php

'servers' => [
        [
            'name' => 'jsonrpc',
            'type' => Server::SERVER_BASE,
            'host' => '0.0.0.0',
            'port' => 9603,
            'sock_type' => SWOOLE_SOCK_TCP,
            'callbacks' => [
                SwooleEvent::ON_RECEIVE => [Hyperf\JsonRpc\TcpServer::class, 'onReceive'],
            ],
        ],
]

修改.env

APP_NAME=org

定义服务提供者和定义接口文件

JsonRpc/TestService.php

<?php

declare(strict_types=1);
namespace App\JsonRpc;
use Hyperf\RpcServer\Annotation\RpcService;

/**
 * Class TestService
 * @package App\JsonRpc
 * @RpcService(name="TestService",protocol="jsonrpc",server="jsonrpc")
 */
class TestService implements TestServiceInterface
{
    public function test(int $a , int $b) :array
    {
        return ['code'=>0,'data'=>'这是org服务提供者','params1'=>$a,'params2'=>$b];
    }
}

JsonRpc/TestServiceInterface.php

<?php
declare(strict_types=1);
namespace App\JsonRpc;


interface TestServiceInterface
{
    public function test(int $a , int $b):array ;
}
  • mms服务端

config/autoload/server.php

'servers' => [
        [
            'name' => 'jsonrpc',
            'type' => Server::SERVER_BASE,
            'host' => '0.0.0.0',
            'port' => 9602,
            'sock_type' => SWOOLE_SOCK_TCP,
            'callbacks' => [
                SwooleEvent::ON_RECEIVE => [Hyperf\JsonRpc\TcpServer::class, 'onReceive'],
            ],
        ],
]

修改.env

APP_NAME=mms

定义服务提供者和定义接口文件

JsonRpc/MmsService.php

<?php
declare(strict_types=1);
namespace App\JsonRpc;
use Hyperf\RpcServer\Annotation\RpcService;

/**
 * Class MmsServeice
 * @package App\JsonRpc
 * @RpcService(name="MmsService",protocol="jsonrpc",server="jsonrpc")
 */
class MmsService implements MmsServiceInterface
{
    public function mmsTest(string $cellPhone,int $code) :array
    {
        return ['code'=>0,'data'=>'这是mms服务端','message'=>'电话号码是'.$cellPhone.',验证码是'.$code];
    }
}

JsonRpc/MmsServiceInterface.php

<?php
declare(strict_types=1);
namespace App\JsonRpc;

interface MmsServiceInterface
{
    public function mmsTest(string $cellPhone, int $code) :array ;
}
  • api 消费端配置

config/autoload/services.php

<?php

declare(strict_types=1);
/**
 * This file is part of Hyperf.
 *
 * @link     https://www.hyperf.io
 * @document https://doc.hyperf.io
 * @contact  group@hyperf.io
 * @license  https://github.com/hyperf/hyperf/blob/master/LICENSE
 */
return [
    'consumers' => value(function (){
        $services = [
            'TestService'=>['service'=>\App\JsonRpc\TestServiceInterface::class,'host'=>'org','port'=>9603],
            'MmsService'=>['service'=>\App\JsonRpc\MmsServiceInterface::class,'host'=>'mms','port'=>9602],
        ];
        $consumers =[];
        foreach ($services as $name => $value){
            $consumers[] = [
                'name' => $name,
                'service' => $value['service'],
                'protocol' => 'jsonrpc',
                'load_balancer' => 'random',
                'nodes' => [
                    ['host' => $value['host'], 'port' => $value['port']],
                ],
            ];
        }
        return $consumers;
    })
];

定义org和mms接口文件

JsonRpc/TestServiceInterface.php

<?php
declare(strict_types=1);
namespace App\JsonRpc;


interface TestServiceInterface
{
    public function test(int $a , int $b):array ;
}

JsonRpc/MmsServiceInterface.php

<?php
declare(strict_types=1);
namespace App\JsonRpc;

interface MmsServiceInterface
{
    public function mmsTest(string $cellPhone, int $code) :array ;
}
  • 控制其中调用
<?php

declare(strict_types=1);
/**
 * This file is part of Hyperf.
 *
 * @link     https://www.hyperf.io
 * @document https://doc.hyperf.io
 * @contact  group@hyperf.io
 * @license  https://github.com/hyperf/hyperf/blob/master/LICENSE
 */
namespace App\Controller;
use App\JsonRpc\MmsServiceInterface;
use App\JsonRpc\TestServiceInterface;
use Hyperf\HttpServer\Annotation\Controller;
use Hyperf\HttpServer\Annotation\GetMapping;
use Hyperf\Utils\ApplicationContext;

/**
 * Class IndexController
 * @package App\Controller
 * @Controller(prefix="index")
 */
class IndexController extends AbstractController
{
    /**
     * @Author  xue
     * @DateTime  2020-08-25
     * @GetMapping(path="testRpc")
     */
    public function testRpc()
    {
        $orgClient = ApplicationContext::getContainer()->get(TestServiceInterface::class);
        $data1 = $orgClient->test(1,2);
        $mmsClient = ApplicationContext::getContainer()->get(MmsServiceInterface::class);
        $data2 = $mmsClient->mmsTest('13681242210',1234);
        $data[]=$data1;
        $data[]=$data2;
        return $data;
    }
}

浏览器访问index/testRpc

输出:

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

推荐阅读更多精彩内容