- thinkphp5支持php,如何让swoole完美支持ThinkPHP5呢
坎布里奇大脸猫
thinkphp5支持php
视频教程推荐TP5与workerman实战在线客服首先开启swoole的http服务开启swoole的http服务并设置提供给url访问页面的文件的根目录,代码如下。这样在浏览器只能访问…static下面的文件,而无法访问其他目录下的文件。http.serverset(['enable_static_handler'=>true,'document_root'=>"/usr/local/openr
- ThinkPHP6中使用GatewayWorker
有衡
phpGatewayWorketphp
首先是先安装composerrequireworkerman/gateway-workercomposerrequireworkerman/gatewayclient下载demo服务器开通TCP端口8282、1238将Applications\YourApp目录随便放ThinkPHP6的哪个位置,我这里放在了app\gateway\ws目录中配置composer.json"autoload":{"
- php怎么进行异步编程,简述php异步编程
三木在Yummy
php怎么进行异步编程
前言传统的php-fpm一个进程执行一个请求,要达到多少并发,就要生成多少个进程。更糟糕的是每次请求都需要重新编译执行,导致并发一直上不来。因此出现了Swoole和WorkerMan两个国内流行的常驻内存框架。这两个框架原理都是通过事件循环,让程序一直停留在内存,等待外部请求,达到高并发。为什么需要异步先来看一个例子在工作目录下新建文件slowServer.phpsleep(5);//5秒后才能返
- php怎么进行异步编程,php异步编程是怎样的?
日立中央空调
php怎么进行异步编程
前言传统的php-fpm一个进程执行一个请求,要达到多少并发,就要生成多少个进程。更糟糕的是每次请求都需要重新编译执行,导致并发一直上不来。因此出现了Swoole和WorkerMan两个国内流行的常驻内存框架。这两个框架原理都是通过事件循环,让程序一直停留在内存,等待外部请求,达到高并发。为什么需要异步先来看一个例子在工作目录下新建文件slowServer.phpsleep(5);//5秒后才能返
- 93年小姐姐浅谈workerman
落魄PHP女程序员
说好了再出一篇文章专门讲一下workerman,本宝宝就是不会食言的啦,虽然可能没有人看,自娱自乐吧.1.首先workermen是什么?workerman是一款纯php开发的开源高性能的phpsocket服务框架。学习起来还是相对简单的,内核极简,仅有几个php文件而且只暴露几个接口,其他功能通过组件的方式扩展。2.应用方向?(1)即时通讯类例如网页即时聊天,即时消息推送,微信小程序,手机app消
- PHP客服系统-vue客服聊天系统
行动之上
源码免费下载php
PHP-Vue客服聊天系统是一款高效、灵活的客户服务解决方案,基于ThinkPHP6、Vue3和Workerman(Gateworker)框架开发,专为单商户场景打造。系统亮点:分布式部署支持,轻松应对高并发场景;本地消息存储功能,确保数据安全可靠;自动欢迎语及常见问题分组展示,提升用户体验;知识库个人或通用回复支持,快速解决客户问题;自定义昵称、图像、按钮、图标及样式,打造个性化客服界面;客服端
- TP5手动集成GatewayWorker
xiaopzi123123
php
重点://由于是手动添加,因此需要注册命名空间,方便自动加载,具体代码路径以实际情况为准\think\Loader::addNamespace(['Workerman'=>EXTEND_PATH.'Workerman/workerman','GatewayWorker'=>EXTEND_PATH.'Workerman/gateway-worker/src',]);也可以放到vendor目录下,用V
- 【备忘】thinkphp5.1之websocket长连接框架使用流程简述
SDL大华
websocket网络协议网络
前言本文纯属经验备注,有许多地方未进行测试,请勿照搬,仅供参考。之前专门花了几天时间测试了websocket,当时只记得踩了许多坑,但是没有对测试流程进行记录,导致长时间未使用从而无从下手。今天就简单记录一下使用流程。环境介绍php7.4+linuxnginxthinkphp5.1workerman流程1、安装长连接框架:composerrequireworkerman/gateway-worke
- Laykefu客服系统 任意文件上传漏洞复现
OidBoy_G
漏洞复现安全web安全
0x01产品简介Laykefu是一款基于workerman+gatawayworker+thinkphp5搭建的全功能webim客服系统,旨在帮助企业有效管理和提供优质的客户服务。0x02漏洞概述Laykefu客服系统/admin/users/upavatar.html接口处存在文件上传漏洞,而且当请求中Cookie中的”user_name“不为空时即可绕过登录系统后台,未经身份验证的攻击者可利用
- WorkerMan WebSocket端口不通的原因
红鹰z
用workerMan刚做了一个demo的聊天室,感觉挺好玩的,决定对不懂后台的前端装个大爷,1.本地的客户端与服务端都是127.0.0.1:2346自己开两个浏览器测试的时候跑的很愉快,同时将客户端与服务端改成192.168.5.18:2346网段2.结果同事的局域网访问我机器的80端口demo后,报错了,还讥讽的笑我,你要给我看bug吗?3.直接看解决的结果!!解决的结果!!!结果!!!你将要遇
- ThinkPHP5 与WorkerMan结合,实现在线客服聊天(即时通讯)
PHP技术社区
IT教程WorkerManphp
workerman本身是一个PHP多进程服务器框架,具有PHP进程管理以及socket通信的模块,所以不依赖php-fpm、nginx或者apache等这些容器便可以独立运行。 Workerman的一些应用方向如下:即时通讯类例如网页即时聊天、即时消息推送、微信小程序、手机app消息推送、PC软件消息推送等等 在很多人学习Workerman都遇到了很多困难,那么我将在这里分享一套课程,点击领取:
- Workerman--后端消息实时推送至前端
Jokey_12138
phpworkerman
在开发过程中,我们经常会遇到如下这种情况。前端列表展示后台数据库中的数据,但是在后台的某一个接口中向数据库插入一条数据,此时数据库已更新,但是前端展示数据并没有更新,需要手动刷新才可以。但是每次都自己手动更新,太麻烦了,这时候就可以用到workerman来解决问题了。Workerman是一款纯PHP开发的开源高性能的PHPsocket服务器框架。被广泛的用于手机app、移动通讯,微信小程序,手游服
- 【博客重构之路】webman-admin安装指南
sockstack
webmanwebman-admin博客开发重构技术分享
原文地址【博客重构之路】webman-admin安装指南视频地址【bilibili】webman是什么webman是一款基于workerman开发的高性能HTTP服务框架。webman用于替代传统的php-fpm架构,提供超高性能可扩展的HTTP服务。你可以用webman开发网站,也可以开发HTTP接口或者微服务。除此之外,webman还支持自定义进程,可以做workerman能做的任何事情,例如
- Can only install one of: topthink/think-installer[v2.0.0, v1.0.12].
moTzxx
ThinkPHPLinuxworkerMan
这种情况发生在:我要在自己的ThinkPHP5.1.2框架中,使用composer命令安装workerMan拓展的时候所提示的信息composer命令:composerrequiretopthink/think-worker=v2.0.9提示信息打印信息如下:./composer.jsonhasbeenupdatedLoadingcomposerrepositorieswithpackageinf
- thinkphp6.0的workerman在PHP8.0下报错
走进大山的孩子
workerman
一、我先升级了thinkphp6.0到最新版本:composerupdatetopthink/framework二、结果提示我composer版本过低,需要升级到2,于是我又升级了composercomposerself-update三、我又升级了workerman:composerrequiretopthink/think-worker四、执行phpthinkworker:gateway-d报错
- 通讯app:
Go的神秘男朋友
php
为了开发一个即时通讯的app,包含发送文字、语音、视频以及视频通话的功能,我们需要考虑以下的技术栈和实现步骤:技术栈建议:前端:ReactNative或Flutter用于跨平台移动应用开发。后端:ThinkPHP+Workerman。数据库:MySQL或其他关系型数据库用于存储用户信息、聊天记录等。实时通讯:WebSocket用于实时消息传递。媒体处理:FFmpeg用于语音和视频的转码、压缩等处理
- C++ 职工管理系统源码(初学者练手项目/全注释)
默示MoS
C++初学者开发语言c++
目录一、文章概述项目不足(于2023.10.1添加)二、头文件:1.boss.h2.employee.h3.manager.h4.worker.h5.workerManager.h三、源文件:1.boss.cpp2.employee.cpp3.manager.cpp4.workerManager.cpp5.职工管理系统.cpp(main.cpp)三、结语一、文章概述代码是跟着黑马的b站教程敲的,源
- workerman实现聊天系统
也许会了
安装thinkphp5.1composercreate-projecttopthink/think=5.1.x-devtp5andWorkerman安装think-workercomposerrequiretopthink/think-worker=2.0.*直接安装Workermancomposerrequireworkerman/workerman(2)我们先看think-worker的代码c
- laraval6.0 GatewayWorker 交互通信
Miss 古月先生
phplaravelgateway
laravel6.0GatewayWorker通讯开发前准备下载GatewayWorker及操作方式前端demo测试效果项目中安装GatewayClient开发前准备GatewayClient官网:https://www.workerman.net/当前使用的是宝塔操作下载GatewayWorker及操作方式前端demo测试效果项目中安装GatewayClientcomposerrequirewo
- php 使用多线程
Go的神秘男朋友
php开发语言
fpm+cli+socket+redisPHP多线程-阿里云开发者社区常驻内存:op+cliEasyTask:PHP常驻内存多进程任务管理器,支持定时任务(PHPresidentmemorymulti-processtaskmanager,supportstimingtasks)协程:swooleSwoole-PHP协程框架高性能PHP应用容器workerman微服务:reids+cliSwoft
- PHP RabbitMQ 结合 WorkerMan 消息过期、消息队列长度、消费超次数、死信队列
Chen_2017_Strive
phprabbitmqrabbitmqphp
1.学习基础用法、消息过期队列过期丢弃、队列长度超出丢弃、消费超次数处理、死信队列代码地址:php_rabbitmq:学习rabbmitmq、workerman、redis,rabbitmq消息过期、队列长度限制、重试次数限制、死信队列https://gitee.com/Chen_2017_Strive/php_rabbitmq.git参考文献:RabbitMQ-PHP操作RabbitMQ-简单模
- workerman启动时报错pcntl_fork被禁用
汐泽学园
PHPphp
报错信息pcntl_fork()hasbeendisabledforsecurityreasonsinfile/xxx/workerman/Worker.php解决方法pcntl_fork被禁用了。找到php.ini文件并打开从disable_functions中删除pcntl_fork重启apache或者nginx
- workerman分布式部署
hcqDezhp
php
文档:http://doc2.workerman.net/326146目标:项目需要研发im聊天功能,若用户量逐渐增大,单服务器的部署方式恐怕无法满足,因此,考虑使用多服务器分布式部署共同支撑大量人群同时在线。首先我们需要先了解运行原理,官方文档的解释是:1、Register、Gateway、BusinessWorker进程启动2、Gateway、BusinessWorker进程启动后向Regis
- workman使用手册1.0
outluck
php
workman官网地址:高性能PHP应用容器workerman1:把workman项目放到linux服务器后,需要启动你的php文件,才可以使用定位到项目根目录:例:cd/mnt/workman启动代码:phpoutin.phpstart-d停止代码:phpoutin.phpstop以debug(调试)方式启动:phpoutin.phpstart2:workman服务端写法uidConnetion
- tp3集成Workerman
从兄
thinkphphtmlphpphphtmlworkerman
workerman是一个高性能的PHPsocket服务器框架,workerman基于PHP多进程以及libevent事件轮询库使用tp3框架集成Workerman,需要先把下载的Workerman放到ThinkPHP\Library目录下,把Workerman文件夹下的所有文件加上.class.php后缀,除Workerman\Lib\Constants.php不用修改这里有已修改好的worker
- workerman
一个临漂的实习生
php
workerman—官网具体的上手体验流程workerman手册->GatewayWorker手册->webman手册->webman-admin手册文档关系刚上手的时候看到四个文档,不知道看哪个,感觉很迷茫。简单介绍下四个文档之间的关系。比作一棵树,根茎枝干就是workerman,剩余的三个是其衍生作品,是叶子。简单示例在webman中装webman-admin,装gateway,简单实现htt
- 最新Workerman 在线客服系统源码/附搭建教程-ThinkPHP网站在线客服系统源码
hmz856
前端PHP后端前端php开源
源码简介:Workerman开发的Ai智能客服在线客服系统网站源码,里面有附带安装教程文档搭建教程。它是最新Workerman在线客服系统源码。源码链接:网盘源码密码:hma8源码特点:作为网站在线客服系统源码,它有下面几个特点:1、模块化开发2、强大的一键生成功能极速简化你的开发流程,加快你的项目开发3、响应式布局4、自动适配,无需要担心兼容性问题5、完善的权限管理6、自由分配子级权限、一个管理
- php 串口转mqtt,tcp,udp
pxw1992
网络
核心代码串口句柄加入io复用,非阻塞目前windows平台仅支持com1,com2,com3,com4,大数还在研究中。网络框架使用的是workerman.这个资料很多,linux平台使用的是stty,windows使用的是mode。网上搞了2天。
- php消息推送
smallmww
PHP后端php数据库
使用PHP来实现消息推送功能-学新通(swvq.com)Workerman是一款运行在PHP环境下的高性能的异步事件驱动框架,由著名PHP框架YII的作者王盼创建。该框架通过使用PHPsocket扩展实现了对WebSocket的支持,并在此基础上实现了处理TCP/UDP协议的能力。下面,我们来演示一下通过使用Workerman库来实现消息推送的具体步骤:1.安装Workerman库在命令行中使用以
- thinkphp6的自定义命令下不能启动多个workerman的相关的进程提示Workerman[think] already running.
varphp
php后端websocket
我的场景1.自定义命令行任务定时器2.workermanwebsocket服务启动结果phpthinkworker:gateway【启动成功】phpthinkcrontabstart【启动失败】此时提示Workerman[think]alreadyrunning.解决方式在自定义命令中的protectedfunctionexecute函数增加以下设置Worker::$pidFile=app()->
- SQL的各种连接查询
xieke90
UNION ALLUNION外连接内连接JOIN
一、内连接
概念:内连接就是使用比较运算符根据每个表共有的列的值匹配两个表中的行。
内连接(join 或者inner join )
SQL语法:
select * fron
- java编程思想--复用类
百合不是茶
java继承代理组合final类
复用类看着标题都不知道是什么,再加上java编程思想翻译的比价难懂,所以知道现在才看这本软件界的奇书
一:组合语法:就是将对象的引用放到新类中即可
代码:
package com.wj.reuse;
/**
*
* @author Administrator 组
- [开源与生态系统]国产CPU的生态系统
comsci
cpu
计算机要从娃娃抓起...而孩子最喜欢玩游戏....
要让国产CPU在国内市场形成自己的生态系统和产业链,国家和企业就不能够忘记游戏这个非常关键的环节....
投入一些资金和资源,人力和政策,让游
- JVM内存区域划分Eden Space、Survivor Space、Tenured Gen,Perm Gen解释
商人shang
jvm内存
jvm区域总体分两类,heap区和非heap区。heap区又分:Eden Space(伊甸园)、Survivor Space(幸存者区)、Tenured Gen(老年代-养老区)。 非heap区又分:Code Cache(代码缓存区)、Perm Gen(永久代)、Jvm Stack(java虚拟机栈)、Local Method Statck(本地方法栈)。
HotSpot虚拟机GC算法采用分代收
- 页面上调用 QQ
oloz
qq
<A href="tencent://message/?uin=707321921&Site=有事Q我&Menu=yes">
<img style="border:0px;" src=http://wpa.qq.com/pa?p=1:707321921:1></a>
- 一些问题
文强chu
问题
1.eclipse 导出 doc 出现“The Javadoc command does not exist.” javadoc command 选择 jdk/bin/javadoc.exe 2.tomcate 配置 web 项目 .....
SQL:3.mysql * 必须得放前面 否则 select&nbs
- 生活没有安全感
小桔子
生活孤独安全感
圈子好小,身边朋友没几个,交心的更是少之又少。在深圳,除了男朋友,没几个亲密的人。不知不觉男朋友成了唯一的依靠,毫不夸张的说,业余生活的全部。现在感情好,也很幸福的。但是说不准难免人心会变嘛,不发生什么大家都乐融融,发生什么很难处理。我想说如果不幸被分手(无论原因如何),生活难免变化很大,在深圳,我没交心的朋友。明
- php 基础语法
aichenglong
php 基本语法
1 .1 php变量必须以$开头
<?php
$a=” b”;
echo
?>
1 .2 php基本数据库类型 Integer float/double Boolean string
1 .3 复合数据类型 数组array和对象 object
1 .4 特殊数据类型 null 资源类型(resource) $co
- mybatis tools 配置详解
AILIKES
mybatis
MyBatis Generator中文文档
MyBatis Generator中文文档地址:
http://generator.sturgeon.mopaas.com/
该中文文档由于尽可能和原文内容一致,所以有些地方如果不熟悉,看中文版的文档的也会有一定的障碍,所以本章根据该中文文档以及实际应用,使用通俗的语言来讲解详细的配置。
本文使用Markdown进行编辑,但是博客显示效
- 继承与多态的探讨
百合不是茶
JAVA面向对象 继承 对象
继承 extends 多态
继承是面向对象最经常使用的特征之一:继承语法是通过继承发、基类的域和方法 //继承就是从现有的类中生成一个新的类,这个新类拥有现有类的所有extends是使用继承的关键字:
在A类中定义属性和方法;
class A{
//定义属性
int age;
//定义方法
public void go
- JS的undefined与null的实例
bijian1013
JavaScriptJavaScript
<form name="theform" id="theform">
</form>
<script language="javascript">
var a
alert(typeof(b)); //这里提示undefined
if(theform.datas
- TDD实践(一)
bijian1013
java敏捷TDD
一.TDD概述
TDD:测试驱动开发,它的基本思想就是在开发功能代码之前,先编写测试代码。也就是说在明确要开发某个功能后,首先思考如何对这个功能进行测试,并完成测试代码的编写,然后编写相关的代码满足这些测试用例。然后循环进行添加其他功能,直到完全部功能的开发。
- [Maven学习笔记十]Maven Profile与资源文件过滤器
bit1129
maven
什么是Maven Profile
Maven Profile的含义是针对编译打包环境和编译打包目的配置定制,可以在不同的环境上选择相应的配置,例如DB信息,可以根据是为开发环境编译打包,还是为生产环境编译打包,动态的选择正确的DB配置信息
Profile的激活机制
1.Profile可以手工激活,比如在Intellij Idea的Maven Project视图中可以选择一个P
- 【Hive八】Hive用户自定义生成表函数(UDTF)
bit1129
hive
1. 什么是UDTF
UDTF,是User Defined Table-Generating Functions,一眼看上去,貌似是用户自定义生成表函数,这个生成表不应该理解为生成了一个HQL Table, 貌似更应该理解为生成了类似关系表的二维行数据集
2. 如何实现UDTF
继承org.apache.hadoop.hive.ql.udf.generic
- tfs restful api 加auth 2.0认计
ronin47
目前思考如何给tfs的ngx-tfs api增加安全性。有如下两点:
一是基于客户端的ip设置。这个比较容易实现。
二是基于OAuth2.0认证,这个需要lua,实现起来相对于一来说,有些难度。
现在重点介绍第二种方法实现思路。
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层。如果你也有此打算,阅读下面的文档,实现自动化并获得收益。SeatGe
- jdk环境变量配置
byalias
javajdk
进行java开发,首先要安装jdk,安装了jdk后还要进行环境变量配置:
1、下载jdk(http://java.sun.com/javase/downloads/index.jsp),我下载的版本是:jdk-7u79-windows-x64.exe
2、安装jdk-7u79-windows-x64.exe
3、配置环境变量:右击"计算机"-->&quo
- 《代码大全》表驱动法-Table Driven Approach-2
bylijinnan
java
package com.ljn.base;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.uti
- SQL 数值四舍五入 小数点后保留2位
chicony
四舍五入
1.round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位。
2.numeric 函数的2个参数,第一个表示数据长度,第二个参数表示小数点后位数。
例如:
select cast(round(12.5,2) as numeric(5,2))  
- c++运算符重载
CrazyMizzz
C++
一、加+,减-,乘*,除/ 的运算符重载
Rational operator*(const Rational &x) const{
return Rational(x.a * this->a);
}
在这里只写乘法的,加减除的写法类似
二、<<输出,>>输入的运算符重载
&nb
- hive DDL语法汇总
daizj
hive修改列DDL修改表
hive DDL语法汇总
1、对表重命名
hive> ALTER TABLE table_name RENAME TO new_table_name;
2、修改表备注
hive> ALTER TABLE table_name SET TBLPROPERTIES ('comment' = new_comm
- jbox使用说明
dcj3sjt126com
Web
参考网址:http://www.kudystudio.com/jbox/jbox-demo.html jBox v2.3 beta [
点击下载]
技术交流QQGroup:172543951 100521167
[2011-11-11] jBox v2.3 正式版
- [调整&修复] IE6下有iframe或页面有active、applet控件
- UISegmentedControl 开发笔记
dcj3sjt126com
// typedef NS_ENUM(NSInteger, UISegmentedControlStyle) {
// UISegmentedControlStylePlain, // large plain
&
- Slick生成表映射文件
ekian
scala
Scala添加SLICK进行数据库操作,需在sbt文件上添加slick-codegen包
"com.typesafe.slick" %% "slick-codegen" % slickVersion
因为我是连接SQL Server数据库,还需添加slick-extensions,jtds包
"com.typesa
- ES-TEST
gengzg
test
package com.MarkNum;
import java.io.IOException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.annotation
- 为何外键不再推荐使用
hugh.wang
mysqlDB
表的关联,是一种逻辑关系,并不需要进行物理上的“硬关联”,而且你所期望的关联,其实只是其数据上存在一定的联系而已,而这种联系实际上是在设计之初就定义好的固有逻辑。
在业务代码中实现的时候,只要按照设计之初的这种固有关联逻辑来处理数据即可,并不需要在数据库层面进行“硬关联”,因为在数据库层面通过使用外键的方式进行“硬关联”,会带来很多额外的资源消耗来进行一致性和完整性校验,即使很多时候我们并不
- 领域驱动设计
julyflame
VODAO设计模式DTOpo
概念:
VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对
- 单例设计模式
hm4123660
javaSingleton单例设计模式懒汉式饿汉式
单例模式是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例类的特殊类。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统源。如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。
&nb
- logback
zhb8015
loglogback
一、logback的介绍
Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-class
- 整合Kafka到Spark Streaming——代码示例和挑战
Stark_Summer
sparkstormzookeeperPARALLELISMprocessing
作者Michael G. Noll是瑞士的一位工程师和研究员,效力于Verisign,是Verisign实验室的大规模数据分析基础设施(基础Hadoop)的技术主管。本文,Michael详细的演示了如何将Kafka整合到Spark Streaming中。 期间, Michael还提到了将Kafka整合到 Spark Streaming中的一些现状,非常值得阅读,虽然有一些信息在Spark 1.2版
- spring-master-slave-commondao
王新春
DAOspringdataSourceslavemaster
互联网的web项目,都有个特点:请求的并发量高,其中请求最耗时的db操作,又是系统优化的重中之重。
为此,往往搭建 db的 一主多从库的 数据库架构。作为web的DAO层,要保证针对主库进行写操作,对多个从库进行读操作。当然在一些请求中,为了避免主从复制的延迟导致的数据不一致性,部分的读操作也要到主库上。(这种需求一般通过业务垂直分开,比如下单业务的代码所部署的机器,读去应该也要从主库读取数