php读写分离是什么意思,php项目实现读写分离

标签:connect   host   地址   开启   sep   htm   手册   ram   参数

环境介绍

thinkphp6+mysql8+cnetos8

1,已配置好的主从复制数据库,详情请了解

https://www.cnblogs.com/stronger-xsw/p/12785384.html

2,打开thinkphp项目下config目录配置文件database.php文件

tp6项目具体配置如下

return [

// 默认使用的数据库连接配置

‘default‘ => ‘mysql‘,

// 自定义时间查询规则

‘time_query_rule‘ => [],

// 自动写入时间戳字段

// true为自动识别类型 false关闭

// 字符串则明确指定时间字段类型 支持 int timestamp datetime date

‘auto_timestamp‘ => true,

// 时间字段取出后的默认时间格式

‘datetime_format‘ => ‘Y-m-d H:i:s‘,

// 数据库连接配置信息

‘connections‘ => [

‘mysql‘ => [

// 数据库类型

‘type‘ => ‘mysql‘,

// 服务器地址

‘hostname‘ =>‘192.168.110.131,192.168.110.132,192.168.110.133‘,//第一台为主服务器,后面两台从服务器

// 数据库名

‘database‘ => ‘mydb‘,

// 用户名

‘username‘ => ‘root‘,//用户名全部一样可以这样写,只要有一个不同就分开写

// 密码

‘password‘ => ‘123456,12345678,123456‘,

// 端口

‘hostport‘ => ‘3306‘,

// 数据库连接参数

‘params‘ => [],

// 数据库编码默认采用utf8

‘charset‘ =>‘utf8‘,

// 数据库表前缀

‘prefix‘ => ‘‘,

// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)

‘deploy‘ => 1,//1为开启分布式

// 数据库读写是否分离 主从式有效

‘rw_separate‘ => true,//是否开启读写分离

// 读写分离后 主服务器数量

‘master_num‘ => 1,

// 指定从服务器序号

‘slave_no‘ => ‘‘,

// 是否严格检查字段是否存在

‘fields_strict‘ => true,

// 是否需要断线重连

‘break_reconnect‘ => false,

// 监听SQL

‘trigger_sql‘ => env(‘app_debug‘, true),

// 开启字段缓存

‘fields_cache‘ => false,

// 字段缓存路径

‘schema_cache_path‘ => app()->getRuntimePath() . ‘schema‘ . DIRECTORY_SEPARATOR,

],

// 更多的数据库配置信息

],

];

3,详情介绍参考tp6手册

https://www.kancloud.cn/manual/thinkphp6_0/1037577

php项目实现读写分离

标签:connect   host   地址   开启   sep   htm   手册   ram   参数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现PHP配置MySQL读写分离,首先需要配置好MySQL的主从复制。主要原理是判断SQL语句是否是SELECT语句,如果是则走主库,否则走从库。在PHP中,可以通过以下步骤来实现: 1. 配置MySQL主从复制:确保主数据库将更新同步到从数据库。可以参考中提供的示例代码来配置。 2. 在PHP代码中,使用数据库连接库(如PDO或mysqli)来连接到主从数据库。根据需要,配置主数据库和从数据库的连接参数。 3. 在执行SQL语句之前,检查SQL语句的类型。如果是SELECT语句,则使用主数据库的连接来执行;如果是其他类型的语句,则使用从数据库的连接来执行。 以下是一个简单的示例代码,展示了如何在PHP中配置MySQL读写分离: ```php // 主数据库连接配置 $masterHost = '主数据库主机名'; $masterUsername = '主数据库用户名'; $masterPassword = '主数据库密码'; $masterDatabase = '主数据库名称'; // 从数据库连接配置 $slaveHost = '从数据库主机名'; $slaveUsername = '从数据库用户名'; $slavePassword = '从数据库密码'; $slaveDatabase = '从数据库名称'; // 连接主数据库 $masterConnection = new PDO("mysql:host=$masterHost;dbname=$masterDatabase", $masterUsername, $masterPassword); // 连接从数据库 $slaveConnection = new PDO("mysql:host=$slaveHost;dbname=$slaveDatabase", $slaveUsername, $slavePassword); // 执行SQL语句 $sql = "SELECT * FROM table_name"; $isSelectQuery = (stripos($sql, 'SELECT') === 0); // 判断是否是SELECT语句 if ($isSelectQuery) { // 使用主数据库连接执行SELECT语句 $statement = $masterConnection->query($sql); } else { // 使用从数据库连接执行其他类型的语句 $statement = $slaveConnection->query($sql); } // 处理查询结果 $results = $statement->fetchAll(PDO::FETCH_ASSOC); // 输出查询结果 foreach ($results as $row) { echo $row['column_name'] . '<br>'; } ``` 请注意,这只是一个简单的示例代码,实际应用中可能需要进行更复杂的配置和处理。具体的配置和代码实现可能会根据你使用的PHP框架或库而有所不同。你可以参考中的示例代码,根据自己的需求进行适当的修改和扩展。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [PHP实现的mysql读写分离操作示例](https://download.csdn.net/download/weixin_38545117/13733603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [常用mysql数据库配置文件](https://download.csdn.net/download/zslsh44/88278582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [ThinkPHP配置简单的mysql读写分离](https://blog.csdn.net/weixin_34071713/article/details/94105081)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值