- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的任务一般
我需要听一个 Postgres 表更改(CRUD),例如通过像 DBeaver 这样的数据库管理器,并将更新的行 ID 传递给 Laravel 驱动的 API 端点。
我有的
Postgres 部分
在 Postgres 中,我创建了一个表、一个表的触发器和一个在 postgres 端处理事件的函数
CREATE TABLE PUBLIC.TBLEXAMPLE
(
KEY1 CHARACTER VARYING(10) NOT NULL,
KEY2 CHARACTER VARYING(14) NOT NULL,
VALUE1 CHARACTER VARYING(20),
VALUE2 CHARACTER VARYING(20) NOT NULL,
CONSTRAINT TBLEXAMPLE_PKEY PRIMARY KEY (KEY1, KEY2)
);
CREATE OR REPLACE FUNCTION PUBLIC.NOTIFY() RETURNS trigger AS
$BODY$
BEGIN
PERFORM pg_notify('myevent', row_to_json(NEW)::text);
RETURN new;
END;
$BODY$
LANGUAGE 'plpgsql' VOLATILE COST 100;
CREATE TRIGGER TBLEXAMPLE_AFTER
AFTER insert or update or delete
ON PUBLIC.TBLEXAMPLE
FOR EACH ROW
EXECUTE PROCEDURE PUBLIC.NOTIFY();
PHP部分
<?php
$db = new PDO(
"pgsql:dbname=database host=localhost port=5432", 'postgres', 'password', [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
]
);
$db->exec('LISTEN myevent');
echo 'Starting';
while(true) {
while ($result = $db->pgsqlGetNotify(PDO::FETCH_ASSOC, 30000)) {
echo print_r($result, true) . PHP_EOL;
}
}
这是它的外观
I know clever words like "worker", "queue", I use
php artisan queue:work
in my API (A user requests an endpoint which adds jobs to the queue). But in this case the role of the user should be performed by the php script logic above.My suggestion. I probably must develop something like
php artisan listen2posrgres
with the logic from above and run it similar tophp artisan queue:work
throughout supervisor. Can this work?
最佳答案
正如一些评论指出的那样,您可以为此编写一个自定义的 Artisan 命令。运行该命令开始“监听”触发事件。
在 PostgreSQL 中,你可以创建一个触发器,它就像 Laravel 中的订阅者一样——观察表的变化,它收集诸如表名和 Action 之类的数据,并通过 pg_notify
将其传递给 Laravel。如果 Laravel 已经定义了到这个数据库的连接。您可以使用 JSON 处理对要传递给 Laravel 的数据进行编码,然后将其解析为编码为字符串的 JSON。
下面是一个简单的例子,用于观察订单或用户表的 UPDATE、INSERT 或 DELETE。
触发器
create function notify_event() returns trigger
language plpgsql
as
$$
DECLARE
notification json;
BEGIN
-- PostgreSQL auto-defined variables:
-- TG_OP ~ action such as INSERT, DELETE, UPDATE
-- TG_TABLE_NAME
-- Contruct the notification as a JSON string.
notification = json_build_object(
'table',TG_TABLE_NAME,
'action', TG_OP);
-- Execute pg_notify(channel, notification)
PERFORM pg_notify('events', notification::text);
-- Result is ignored since this is an AFTER trigger
RETURN NULL;
END;
$$;
alter function notify_event() owner to YOUR_DATABASE_NAME_HERE;
工匠指挥部
<?php
namespace App\Console\Commands;
use App\Events\OrderCreated;
use App\Events\OrderDeleted;
use App\Events\OrderUpdated;
use App\Events\UserCreated;
use App\Events\UserDeleted;
use App\Events\UserUpdated;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\DB;
/**
* Class SubscribeToTriggers
*
* @package App\Console\Commands
*/
class SubscribeToTriggers extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'psql:subscribe-to-triggers {--t|table=* : Tables to synchronize.}';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Listen for changes on database and update the platform accordingly';
/**
* Tables to synchronize.
*
* @var array
*/
protected $tables;
/**
* @var
*/
private $subscribers;
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
$this->tables = [];
$this->subscribe();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$timeout = (int) $this->option('timeout');
if ($table = $this->option('table')) {
if (is_array($table)) {
$this->tables = $table;
} else {
$this->tables[] = $table;
}
}
try {
$dbo = DB::connection('DATABASE_NAME_HERE')->getPdo();
$dbo->exec('LISTEN "events"');
while (true) {
$event = $dbo->pgsqlGetNotify(\PDO::FETCH_ASSOC, $timeout * 1000);
if ($this->output->isDebug()) {
$this->getOutput()->write($event);
$this->getOutput()->write(PHP_EOL);
}
$payload = json_decode($event['payload']);
$table = $payload->table;
$action = $payload->action;
$original = $payload->original;
$data = $payload->data;
$observer = null;
$subject = implode('@', [$table, strtolower($action)]);
if (array_key_exists($subject, $this->subscribers)) {
$observer = $this->subscribers[$subject];
} else if (array_key_exists($table, $this->subscribers)) {
$observer = $this->subscribers[$table];
}
if (isset($observer) && method_exists($this, $observer->handler)) {
$handler = $observer->handler;
$this->$handler($data, $action, $original);
}
}
} catch (Exception $e) {
logger($e->getMessage());
}
}
/**
* Set up observers to handle events on a table.
*
* @param $entity
* @param $handler
*/
private function listen($entity, $handler)
{
if (!isset($this->subscribers)) {
$this->subscribers = [];
}
$info = explode('@', $entity);
$table = $info[0];
$action = count($info) > 1 ? $info[1] : null;
$observer = new \stdClass();
$observer->table = $table;
$observer->action = $action;
$observer->handler = $handler;
$subject = !empty($action) ? implode('@', [$table, strtolower($action)]) : $table;
$this->subscribers[$subject] = $observer;
}
/**
* Subscribe to modification events on these tables.
*/
private function subscribe()
{
$this->listen('orders_table', 'onOrder');
$this->listen('users_table', 'onUser');
}
/**
* @param $order
* @param null $action
* @param null $original
*/
protected function onOrder($order, $action = null, $original = null)
{
$event = null;
if ($action == 'INSERT') {
$event = new OrderCreated();
} else if ($action === 'UPDATE') {
$event = new OrderUpdated();
} else if ($action == 'DELETE') {
$event = new OrderDeleted();
}
if (!is_null($event)) {
event($event);
}
}
/**
* @param $user
* @param null $action
* @param null $original
*/
protected function onUser($user, $action = null, $original = null)
{
$event = null;
if ($action == 'INSERT') {
$event = new UserCreated();
} else if ($action === 'UPDATE') {
$event = new UserUpdated();
} else if ($action == 'DELETE') {
$event = new UserDeleted();
}
if (!is_null($event)) {
event($event);
}
}
}
然后你将编写一个 Laravel 订阅者来为命令中定义的每个事件定义 EventListeners:
关于laravel - 如何在 Laravel 中收听 Postgres 监听/通知?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61263632/
我想知道这里是否有人有安装 Postgres-XL 的经验,新的开源多线程版本的 PostgreSQL。我计划将一组 1-2 TB 的数据库从常规 Postgres 9.3 迁移到 XL,并且想知道这
我想创建一个 postgres 备份脚本,但我不想使用 postgres 用户,因为我所在的 unix 系统几乎没有限制。我想要做的是在 crontab 上以 unix 系统(网络)的普通用户身份运行
我正在尝试编写一个 node-postgres 查询,它采用一个整数作为参数在间隔中使用: const query = { text: `SELECT foo
如何在不使用 gui 的情况下停止特定的 Postgres.app 集群。 我想使用 bash/Terminal.app 而不是 gui 我还应该指出,Postgres 应用程序有一个这样的菜单 如果
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
我正在使用 docker 运行 Postgres 图像。它曾经在 Windows10 和 Ubuntu 18.04 上运行没有任何问题。 在 Ubuntu 系统上重新克隆项目后,它在运行 docker
我正在使用 python(比如表 A)将批处理 csv 文件加载到 postgres。我正在使用 pandas 将数据上传到更快的 block 中。 for chunk in pd.read_csv(
所以是的,标题说明了一切,我需要以某种方式将 DB 从源服务器获取到新服务器,但更重要的是旧服务器正在崩溃 :P 有什么方法可以将它全部移动到新服务器并导入它? 旧服务器只是拒绝再运行 Postgre
这主要是出于好奇而提出的问题。我正在浏览 Postgres systemd 单元文件,以了解 systemd 可以做什么。 Postgres 有两个 systemd 单元文件。一个用于代替 syste
从我在 pg_hba.conf 中读到的内容,我推断,为了确保提示我输入 postgres 用户的密码,我应该从当前的“对等”编辑 pg_hba.conf 的前两个条目的方法'到'密码'或'md5',
我已连接到架构 apm。 尝试执行函数并出现以下错误: ERROR: user mapping not found for "postgres" 数据库连接信息说: apm on postgres@
我在 ubuntu 12.04 服务器上,我正在尝试安装 postgresql。截至目前,我已成功安装它但无法配置它。我需要创建一个角色才能继续前进,我在终端中运行了这个命令: root@hostna
我无法以“postgres”用户身份登录到“postgres”数据库。操作系统:REHL 服务器版本 6.3PostgreSQL 版本:8.4有一个数据库“jiradb”用作 JIRA 6.0.8 的
我正在尝试将现有数据库导入 postgres docker 容器。 这就是我的处理方式: docker run --name pg-docker -e POSTGRES_PASSWORD=*****
我们的 Web 应用程序在 postgres 9.3 和 Grails 2.5.3 上运行。当我们重新启动 postgres (/etc/init.d/postgresql restart) 并访问网
我想构建 postgres docker 容器来测试一些问题。我有: postgres 文件的归档文件夹(/var/lib/postgres/data/) 将文件夹放入 docker postgres
我有一个名为“stuff”的表,其中有一个名为“tags”的 json 列,用于存储标签列表,还有一个名为“id”的列,它是表中每一行的主键。我正在使用 postgres 数据库。例如,一行看起来像这
我对 sqlalchemy-psql 中的锁定机制是如何工作的感到非常困惑。我正在运行一个带有 sqlalchemy 和 postgres 的 python-flask 应用程序。由于我有多个线程处理
我(必须)使用 Postgres 8.4 数据库。在这个数据库中,我创建了一个函数: CREATE OR REPLACE FUNCTION counter (mindate timestamptz,m
我已经使用 PostgreSQL 几天了,它运行良好。我一直在通过默认的 postgres 数据库用户和另一个具有权限的用户使用它。 今天中午(在一切正常之后)它停止工作,我再也无法回到数据库中。我会
我是一名优秀的程序员,十分优秀!