通过rabbitmq将商品数据同步到elasticsearch

//tp5添加商品时,将商品数据存入rabbitmq中
    public function add(){
        if($_POST){
            $post = input('post.');
            Db::startTrans();
            try{
                //添加商品
                $goods = Db::table("goods")->insertGetId([
                    'name'=>$post['name'],
                    'item_no'=>$post['item_no'],
                    'category_id'=>$post['category_id'],
                    'status'=>$post['status'],
                    'description'=>$post['description'],
                    'detail_img'=>$post['detail_img_url'],
                    'add_time'=>date('Y-m-d H:i:s',time())
                ]);
                if(empty($goods)){
                    Db::rollback();
                    return json(['code'=>1,'msg'=>'Error!']);
                }
                //上传主图
                $master_img = Db::table('goods_image')->insert([
                    'goods_id'=>$goods,
                    'img_url'=>$post['master_img_url'],
                    'is_master'=>1,
                    'status'=>$post['status'],
                    'add_time'=>date('Y-m-d H:i:s',time())
                ]);

                //将商品数据存入rabbitmq中,再放入elatsicsearch
                $cnn = new \AMQPConnection($this->config);
                if(!$cnn->connect()){ echo "连接失败"; exit();}
                $cn = new \AMQPChannel($cnn);
                $ex = new \AMQPExchange($cn);
                $q = new \AMQPQueue($cn);
                $routingKey = 'key_goods';
                $exchangeName = 'exchange_goods';
                $ex->setName($exchangeName);
                $q->setName('queue_goods');
                //设置交换机的类型
                $ex->setType(AMQP_EX_TYPE_DIRECT);
                //设置交换机的持久
                $ex->setFlags(AMQP_DURABLE);
                $q->setFlags(AMQP_DURABLE);
                //申明交换机
                $ex->declareExchange();
                $q->declareQueue();
                $q->bind($ex->getName(), $routingKey);

                $msg = [
                    'goods_id'=>$goods,
                    'name'=>$post['name'],
                    'item_no'=>$post['item_no'],
                    'category_id'=>$post['category_id'],
                    'status'=>$post['status'],
                    'description'=>$post['description'],
                ];
                $ex->publish(json_encode($msg),$routingKey,AMQP_NOPARAM,array('delivery_mode' => 2));

                Db::commit();
                return json(['code'=>0,'msg'=>'Success!']);
            }catch (\Exception $e) {
                // 回滚事务
                Db::rollback();
                return json(['code'=>1,'msg'=>$e->getMessage()]);
            }
        }
    }

<?php

//将rabbitmq中的数据取出,并存入es中

require 'vendor/autoload.php';

use Elasticsearch\ClientBuilder;

$config = [
    'host'=>'127.0.0.1',
    'vhost'=>'/',
    'port'=>5672,
    'login'=>'guest',
    'password'=>'guest'
];

//连接broker,创建一个rabbitmq连接
$cnn = new AMQPConnection($config);

//抛出异常
if(!$cnn->connect()){
    echo "连接失败";
    exit();
}

//在连接内创建一个通道
$ch = new AMQPChannel($cnn);

//创建一个交换机
$ex = new AMQPExchange($ch);

//申明路由键
$routingKey = 'key_goods';

//申明交换机名称
$exchangeName = 'exchange_goods';

//设置交换机名称
$ex->setName($exchangeName);

//设置交换机的类型
$ex->setType(AMQP_EX_TYPE_DIRECT);

//设置交换机的持久
$ex->setFlags(AMQP_DURABLE);

//申明交换机
$ex->declareExchange();

//创建一个消息队列
$q = new AMQPQueue($ch);

//设置队列名称
$q->setName('queue_goods');

//设置队列的持久
$q->setFlags(AMQP_DURABLE);

//申明消息队列
$q->declareQueue();

$q->bind($ex->getName(), $routingKey);

//接收消息并进行处理回调方法
function receive($envelope, $queue){
    $data = json_decode($envelope->getBody(),true);
    $hosts = [
        '127.0.0.1:9200'
    ];
    $client = ClientBuilder::create()->setHosts($hosts)->build();
    $params = [
        'index' => 'goods',
        'type' => 'list',
        'id' => $data['goods_id'],
        'body' => [
            'name'=>$data['name'],
            'item_no'=>$data['item_no'],
            "status"=>$data['status'],
            "description"=>$data['description']
        ]
    ];
    $response = $client->create($params);
    $queue->ack($envelope->getDeliveryTag());
}
$q->consume("receive");

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值