php 分布式数据库查询,分布式数据库

# 分布式数据库

ThinkPHP内置了分布式数据库的支持,包括主从式数据库的读写分离,但是分布式数据库必须是相同的数据库类型。

配置`database.deploy` 为1 可以采用分布式数据库支持。如果采用分布式数据库,定义数据库配置信息的方式如下:

```

//分布式数据库配置定义

return [

// 启用分布式数据库

'deploy' => 1,

// 数据库类型

'type' => 'mysql',

// 服务器地址

'hostname' => '192.168.1.1,192.168.1.2',

// 数据库名

'database' => 'demo',

// 数据库用户名

'username' => 'root',

// 数据库密码

'password' => '',

// 数据库连接端口

'hostport' => '',

]

```

连接的数据库个数取决于`hostname`定义的数量,所以即使是两个相同的IP也需要重复定义,但是其他的参数如果存在相同的可以不用重复定义,例如:

```

'hostport'=>'3306,3306'

```

```

'hostport'=>'3306'

```

等效。

```

'username'=>'user1',

'password'=>'pwd1',

```

```

'username'=>'user1,user1',

'password'=>'pwd1,pwd1',

```

等效。

还可以设置分布式数据库的读写是否分离,默认的情况下读写不分离,也就是每台服务器都可以进行读写操作,对于主从式数据库而言,需要设置读写分离,通过下面的设置就可以:

```

'rw_separate' => true,

```

在读写分离的情况下,默认第一个数据库配置是主服务器的配置信息,负责写入数据,如果设置了`master_num`参数,则可以支持多个主服务器写入。其它的都是从数据库的配置信息,负责读取数据,数量不限制。每次连接从服务器并且进行读取操作的时候,系统会随机进行在从服务器中选择。

还可以设置`slave_no` 指定某个服务器进行读操作。

> 如果从数据库连接错误,会自动切换到主数据库连接。

调用模型的CURD操作的话,系统会自动判断当前执行的方法的读操作还是写操作,如果你用的是原生SQL,那么需要注意系统的默认规则: **写操作必须用模型的execute方法,读操作必须用模型的query方法**,否则会发生主从读写错乱的情况。

> 注意:主从数据库的数据同步工作不在框架实现,需要数据库考虑自身的同步或者复制机制。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/503288.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java程序员遇到瓶颈后我们可以试着朝四个方向拓展?你们觉得呢?

现如今随着IT行业的火热,人们对于编程技术也是越来越关注重视,在从业后我们做Java开发难免会遇到一些瓶颈。在我看来解决这个问题一般有以下4种方向: 基于产品本身 要记住公司招人是解决问题的,基于现有问题出发,大家…

oracle 布尔盲注,Oracle基于延时的盲注总结

0x00 前言oracle注入中可以通过页面响应的状态,这里指的是响应时间,通过这种方式判断SQL是否被执行的方式,便是时间盲注;oracle的时间盲注通常使用DBMS_PIPE.RECEIVE_MESSAGE(),而另外一种便是decode()与高耗时SQL操作…

Java架构师除了必备的技术之外,这些技能也需必备?你们觉得呢?

成为Java架构师首先你必须是一名Java高级开发工程师,熟练使用各种框架,并且能知道他们其中的原理。jvm虚拟机原理、调优,懂得jvm能让你写出性能更好的代码;池技术,什么对象池,连接池,线程池等等 Java构架师…

bat oracle导出数据库,bat命令oracle自动备份

echo offecho echo windows环境下Oracle数据库的自动备份脚本echo 说明:启动备份时,需要配置以下变量echo 1、BACKUP_DIR 指定要备份到哪个目录echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码ech…

Java编程学习并不难,有坚持的动力与良好的心态尤为重要

时间过得很快,回想刚学习Java编程开发的懵懂无知,到现在可以做出简单的项目,可以明显的感觉到自己确实进步了。Java编程其实并不难学,难的是你能够一如既往的保持好的学习态度,并愿意努力的去背、去记、去做项目练习。…

php常用函数、算法,PHP常用函数和常量

PHP常用系统常量__FILE__文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。自 PHP 4.0.2 起,总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径),而在此之前的版本有时会包含一个相对路径。__DIR__文…

Java编程开发中高效编码的7个技巧?你应该知道……

1. 使用 JDK 8 或更高版本 从 JDK 8 以及 更高版本开始,引进许多新功能将允许你编写更短、更具表现力的代码,包括 lambda 表达式、functional 接口、stream API等。你实际上不需要记住他们,因为 IDEA 将帮助你使用这些功能,这也是…

下载jdk一定要登录oracle么,如何下载oracle jdk|oracle jdk下载慢,要登录等等问题

/java/jdk/8u231-b11/5b13a193868b4bf28bcb45c792fce896/jdk-8u231-linux-x64.tar.gz注意替换--------------------------------------------附上一批网址,这些应该也够了http://ns1.iranns.ir 这个比较新https://mirrors.huaweicloud.com/java/http://enos.itcoll…

oracle 11g segment,11g视图dba_segments中增加了一个有用的segment_subtype字段!

以前我们要查一个segment所在的表空间是assm还是mssm,需要查看这个segment所在的表空间的segment_space_management 字段属性,在11g中不需要了,只需要查看dba_segments的segment_subtype就可以了,看似一个小小的改进,却…

谈谈Java与大数据之间的关系你们都了解了清楚了吗?

Java是计算机编程语言界的王者,大数据是当下IT领域中最新潮的技术,Java和大数据都是当下十分受企业欢迎的IT技术,也是企业核心竞争力的重要组成部分,都说学大数据要先学Java,那么Java和大数据有什么关系呢?…

linux用户组chownd,Linux系统centos6下用户与用户组权限命令用法 chmod与chown

查看当前目录下文件的权限:命令:ll 或:ls -l-rw-r--r--. 1 root root 6 Nov 9 16:42 abc.htmldrw-r--r--. 1 root root 6 Nov 9 16:42 pages其中“-rw-r–r–”表示权限,一共有十个字符。第一个字符,如果是“-”则表示…

自学Java必看的知识点,猿们怎么看?

1.你需要精通面向对象分析与设计(OOA/OOD)、涉及模式(GOF,J2EEDP)以及综合模式。你应该了解UML,尤其是class、object、interaction以及statediagrams。 2. 你需要学习Java语言的基础知识以及它的核心类库(collections、serialization、streams、network…

linux 源码包编译,源码包编译安装

程序包编译安装:Application-VERSION-release.src.rpm–> 安装后,使用rpmbuild命令制作成二进制格式的rpm包,而后再安装源代码 –> 预处理 –> 编译 –> 汇编 –> 链接 –> 执行源代码组织格式:多文件&#xff…

谈一谈Java编程开发中虚拟机的内存区域划分?猿们怎么看?

java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域,有的区域随虚拟机进程的启动而存在,有的区域则依赖线程而存在。包括以下几个运行时数据区域: 程序计数器(线程私有): 可以…

linux桌面使用网卡设置,Linux的KDE桌面下怎样设置网络连接?

a) 在KDE的“启动程序”菜单,选择“KNOPPIX”—>“Network/Internet”—>点击“ADSL/PPPOE configuration”。b) 配置程序会自动找到您的网卡设备,确认后请选中“yes”并回车。c) 程序自动扫描已安装的ADSL Modem。d) 已找到ADSL Modem&#xff0c…

成为一名成功的程序员要做到以下10点?网友:是真的吗?

编程是一个没有极限的职业,所以要成为一名优秀的程序员,你必须超越现有已存在的极限。在程序员职业生涯的开始阶段,他们将面临许多挑战,面对困境,他们之中有一些人将会放弃,而只有少数人会坚持到底&#xf…

掌握Java编程思想,学好Java只需要三步?网友:真的吗?

Java可谓是热门的编程语言,我们的生活方方面面都离不开Java。想学Java的人也是络绎不绝,那么零基础如何学习Java编程?拥有编程思想呢?小编给你答案。 一、从Java基础开始 找一个Java的基础教程学一下,学习Java基础的时…

linux tar 大小不同,linux – 如何在使用tar时设置bzip2块大小?

export BZIP--fasttar cjf foo.tar.bz2 foo或者将tar的输出传递给bzip2.虽然你应该从bzip2手册页中注意到:-1 (or --fast) to -9 (or --best)Set the block size to 100 k, 200 k .. 900 k when compressing.Has no effect when decompressing. See MEMORY MANAGEME…

10个简单的 Java 性能调优技巧

优化应用程序以获得最佳性能不是一件容易的事情。但是,这并不意味着如果你不具备这些知识,就不能做任何事情。这里有11个易于遵循的建议和最佳实践可以帮助你创建一个性能良好的应用程序。 大部分建议是针对Java的。但也有若干建议是与语言无关的&#…

服务器linux启动,Linux 服务器环境启动

1、PHP关闭phpkillall php-fpmphp重启/usr/local/php/sbin/php-fpm &或者/usr/local/php/sbin/php-fpm {start|stop|quit|restart|reload|logrotate}--start 启动php的fastcgi进程--stop 强制终止php的fastcgi进程--quit 平滑终止php的fastcgi进程--restart 重启php的fastc…