**editor config**: ```javascript ClassicEditor .create( editorElement, { ckfinder: { uploadUrl: '/ckfinder/upload.php' } } ) .then( ... ) .catch( ... ); ``` `uploadUrl` response format: ```json { "uploaded ": true, "error": { "message": "no error" }, "url": "https://example.com/upload/images/213432434.png" } ``` ```json { "uploaded ": false, "error": { "message": "file extension not allow" }, "url": "" ...
 发布日期: 2018-11-23    分类: Javascript    浏览量: 52   0条评论  
利用RabbitMQ来做一个RPC的客户端和服务端。 输出斐波那契数列为例子。 rpc_server.php: ```php ...
 发布日期: 2018-11-15    分类: 其他    浏览量: 95   3条评论  
Routing那一文是日志系统还是有不足的地方,如果我们想既基于选择和发送消息的来源来接收日志呢? 比如像Linux的`syslog`一样,可以基于消息的级别(info/warn..),产生消息的来源(auth/cron)来记录日志。 要实行这样的功能,就需要`topic`类型的exchange了。 `topic`类型的exchange,`routing_key`参数值不能随便设置,需要是一个点(`.`)分隔的词列表,词可以随意设置,一般是使用有意义的内容。比如`stock.usd.nyse`,数据长度是最大是255个字符。 `binding key`也是同样的格式,可以有两个特殊的字符: - `*`:匹配单个词。 - `#`:匹配0个或多个词。 比如`*.orange.*`、`lazy.#`,这里的词指的是点分隔的完整字符。 生产者: ```php ...
 发布日期: 2018-11-15    分类: 其他    浏览量: 69   0条评论  
接着上篇发布-订阅的日志记录,如果只订阅消息的子集,比如,只记录错误日志到硬盘,全部的消息打印出来,那么就需要用到这里要讲的内容了。 `exchang`的绑定操作可以传递一个叫`routing_key`的额外参数,这里把它称为`binding key`。 ```php $binding_key = 'black'; $channel->queue_bind($queue_name, $exchange_name, $binding_key); ``` `binding key`依赖于`exchange`的类型,`fanout`类型是会忽略这个值的。 在日志系统里面,如果需要根据消息级别过滤消息,就是不同的订阅者收到不同级别的错误日志消息会有不同的处理方式。 之前用的`fanout`exchange类型就不行了,这个类型只能广播消息,而没有其他的灵活性了。 这里的需求需要用`direct`exchange类型来代替,这种类型的算法是消息会推送到`binding key`和`routing key`相同的队列。 > 这里`binding ke...
 发布日期: 2018-11-15    分类: 其他    浏览量: 76   0条评论  
一个消息分发给多个消费者,这就叫做发布-订阅模式。 作为示例,这里构建一个日志系统,由两部分组成,一个是发送日志消息,另一个是接收和打印。 **exchange** `exchange`就是接收生产者的消息,然后推送给队列的一个东西,类似邮局。 `exchange`有几种类型,`direct`, `topic`, `headers` 和`fanout`。 不同的`exchange`类型会有不同的行为,各种类型的使用在后续文章会有介绍,这里我们先只关注最后一种。 `$channel->exchange_declare('logs', 'fanout', false, false, false);` `fanout`类型是广播消息到所有已知的队列。 创建一个名字是`logs`的`exchange`。 ```php $channel->exchange_declare('logs', 'fanout', false, false, false); $channel->basic_publish($msg, 'logs'); ``` ...
 发布日期: 2018-11-13    分类: 其他    浏览量: 94   0条评论  
我这里说的日志是应用日志,比如Web api 出现的一些异常,错误信息等,收集到一起,方便查询检索。 基本架构是,应用把出现的异常错误信息发送到MQ,再存储到数据库,然后提供一个web前端可以查看和检索。 ELK的主要组件如下: - elasticsearch:存储数据的地方 - kibana:可视化数据的web前端 - logstash:数据中转的地方,可以收集数据,过滤转换之后存储起来,输入和输出都可配置,默认是elasticsearch,也可以是其他数据库。 - beats:这个是收集特定数据的一组轻量级工具,可以单独安装用来收集特定数据,比如nginx的日志,系统日志,或者是系统监控信息等,这组工具的信息可以直接写入到`elasticsearch`,也可以通过`logstash`写入。和上面三个工具集成度很高,只需要很少的配置就可以完成收集安装。 这里我只是收集应用日志,所以暂时不需要用到`beats`。 数据流向图: ![流向图](/upload/image/2018/cb0e6a6b22865cfa8524b91ca0120407....
 发布日期: 2018-11-05    分类: 数据库    浏览量: 121   0条评论  
### Nginx支持的负载均衡方案: - 轮训:循环分发请求; - 最少连接:下一个请求会分发给连接数最少的服务器; - ip-hash:用基于ip的hash方法计算来决定使用哪个服务器。 ### 最简单的负载均衡配置 ```nginx http { upstream myapp1 { server srv1.example.com; server srv2.example.com; server srv3.example.com; } server { listen 80; location / { proxy_pass http://myapp1; } } } ``` 测试Nginx是1.10.3版本,系统是ubuntu17.04。 默认80端口是主机用来做负载均衡,8080 - 8082三个端口分布做三个服务主机用来测试。 在`/etc/nginx/ngin...
 发布日期: 2018-11-05    分类: 其他    浏览量: 99   0条评论  
可以使用`composer init`来初始化一个测试项目,然后用`composer require php-amqplib/php-amqplib`来引入`RabbitMQ`开发包,然后就可以进行以下测试了。 下面是一个简单的生产者和消费者代码。 如果运行多个消费者,生产者的消息会通过轮训的方式平均分配给消费者。 生产者(消息发送者): **producer.php** ```php ...
 发布日期: 2018-11-04    分类: 其他    浏览量: 118   0条评论  
官网下载二进制包,或者用对应系统的仓库安装就可以了。 安装好后默认服务是启动的,可以使用下列命令查看状态: `service rabbitmq-server status`或者`systemctl status rabbitmq-server`。 服务是以`rabbitmq`用户运行的。 需要打开的端口: - 4369:RabbitMQ and CLI 工具用来节点发现的。 - 5672,5671:客户端AMQP通信端口。 - 25672:节点间和CLI工具的通信端口,这个端口的是动态的,AMQP端口+20000计算而来。如果不需要外部通信,不需要公开端口。 - 35672 - 35682:用于CLI工具和节点间通信用。动态分配的,计算方法是上的端口号+10000 - 上面的端口号+10010。 - 15672:HTTP API客户端,management UI和rabbitmqadmin使用。 - 61613,61614:STOMP客户端使用。 - 1883, 8883: MQTT客户端使用。 - 15674: STOMP-over-WebSocke...
 发布日期: 2018-11-04    分类: 其他    浏览量: 121   0条评论  
首先有一个完全不需要配置的现成方案,直接用`docker run`运行就可以使用了,项目地址:[https://github.com/jae-jae/docker-pan](https://github.com/jae-jae/docker-pan)。 这个方案利用的是`Aria2`的`web ui`来实现下载管理,`Filerun`来实现文件的管理的,下载后端是`Aria2`这个开源的下载软件。 本篇文章要讲的是在`NextCloud`里面添加离线下载的功能,就类似于百度网盘的离线下载一样的。 我的`nextcloud`是用`docker`运行的,不用`docker`运行的话也是类似的。 首先是在`nextcloud`的管理后台安装应用`ocdownloader`。 作者的`github`项目主页是:[https://github.com/e-alfred/ocdownloader](https://github.com/e-alfred/ocdownloader) 这个应用的下载后端可以是`curl`和`Aria2`,这里不管`c...
 发布日期: 2018-03-05    分类: 其他    浏览量: 1344   0条评论