首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL设置数据库只读

前言: 默认情况下,我们的 MySQL 实例是可读写的。但有些情况下,我们可以将整个实例设置为只读状态,比如做迁移维护的时候或者将从库设为只读。本篇文章我们来看下 MySQL 设置只读相关知识。...affected (0.00 sec) 2.flush tables with read lock 设置 除了 read_only 参数外,执行 flush tables with read lock 也可将数据库设置为只读状态...执行此命令会给数据库加全局读锁,使得数据库处于只读状态,以下语句会被阻塞:数据更新语句(增删改)、数据定义语句(建表、修改表结构等)和更新类事务的提交语句。...以个人数据库运维经验来讲,一般只有从库需要设置只读状态,从库端建议开启 read_only 或 super_read_only,避免人为写入。...总结: 本篇文章主要介绍了 MySQL 只读状态相关知识,其实除了从库外,其余实例很少设置全局只读,只是遇到某种需求的情况下需要将数据库设为只读状态,写本篇文章的目的也是遇到此类需求时,可以有个参考。

7.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    新特性解读 | MySQL 8.0 支持对单个数据库设置只读

    1新特性概要 对单个数据库设置只读状态,可以通过 ALTER DATABASE 语句中的 READ ONLY 选项来实现,该选项在 MySQL 8.0.22 版本[1] 中引入,用于控制是否允许对数据库及其对象...2使用方法 以设置数据库 lfq 为只读状态举例,可以观测到修改数据库只读状态对已建立连接的用户是立即生效的(即:session1 修改 lfq 数据库只读,session2 中 lfq 的只读状态是立即生效的...) #session1,再次查一下数据库只读状态,OPTIONS值为“READ ONLY=1”,数据库只读状态修改成功 MySQL localhost:3000 ssl SQL > SELECT...#session2,查询数据库只读状态,数据库只读状态,session1修改lfq数据库只读,session2中lfq的只读状态是立即生效的 MySQL localhost:3000 ssl...备份只读数据库,通过备份文件恢复出来的数据库不是只读的,如果恢复后需要只读,则需要手动执行 ALTER DATABASE 语句设置数据库只读

    53510

    理解:灾备和只读数据库

    主流数据容灾模式1、基于数据库逻辑复制:实时获取数据日志进行复制,异步方案,典型代表:Shareplex for Oracle、Oracle GoldenGate、MySQL 主从复制,PostgreSQL...但每种解决方案都有优缺点:容灾模式优点缺点备注数据库-逻辑复制效率高,灵活性高,数据库可用双活数据一致性不能完全保证,维护难度较高实时获取数据日志进行复制,如:MySQL 主从复制数据库-物理复制对系统环境要求高...只读数据库读写分离数据库的读写分离是一种数据库架构优化策略,将数据库的读操作和写操作分别分配到不同的服务器上,旨在提高数据库系统的性能和可扩展性。...业务场景基于腾讯云的数据库架构分析主库:业务写入流量灾备库:通过Mysql主从复制,异步进行数据同步,特殊情况下转为主库只读库:业务读出流量只读库:运营侧需求的读出流量流量容灾库的必要性区分核心业务和非核心业务...只读数据库不允许写入操作,但可以读取数据,适用于读操作远多于写操作的场景。综上所述,灾备和只读各有其独特的功能和适用场景,我们可以根据自身业务需求选择合适的数据库类型。

    1800

    如何给指定数据库创建只读用户?

    在SQL Server 中,为了保护数据库的安全,需要给不同的使用者开通不同的访问用户,那么如何简单的控制用户的权限呢?下面我们就创建一个只读用户,给大家学习使用。...创建访问指定数据库只读用户 1、首先打开【Microsoft SQLServer Management Studio】,用管理员账户登录。...针对每一个数据库,在下方【数据库角色成员身份】中,选择【db_datareader】,同时默认架构中也选择【db_datareader】 6、这样,一个只读用户就建立好了,用此用户登录时,就只能对映射的数据库进行只读访问了...添加只读用户查看存储过程权限 而当我们设置只给某些用户授权只读权限时(即public),这些用户可能需要查看sql的存储过程;因此需要授权给它。...”选择该用户可以操作的数据库 5、在“数据库角色成员身份”里选择"db_datareader" 6、这样一个只读用户就创建完成了。

    44810

    Mysql的read_only 只读属性说明 (运维笔记)

    MySQL数据库中,在进行数据迁移和从库只读状态设置时,都会涉及到只读状态和Master-Slave主从关系设置, 以下针对real_only只读属性做些笔记记录: 1) 对于MySQL单实例数据库和...master库,如果需要设置为只读状态,需要进行如下操作和设置: 将MySQL设置为只读状态的命令: mysql> show global variables like "%read_only%"; mysql...主从同步的salve库 将slave从库设置为只读状态,需要执行的命令为: mysql> set global read_only=1; 将salve库从只读状态变为读写状态,需要执行的命令是: mysql...权限的用户的数据修改操作;在MySQL中设置read_only=1后,普通的应用用户进行insert、update、delete等会产生数据变化的DML操作时,都会报出数据库处于只读模式不能发生数据变化的错误...这样通过设置"read_only=1"和"flush tables with read lock;"两条命令,就可以确保数据库处于只读模式,不会发生任何数据改变,在MySQL进行数据库迁移时,限定master

    4.7K20

    MYSQL设置远程账户登陆总结

    为了给MYSQL用户设置远程连接权限,经历的种种错误总结 ERROR 2003 (HY00 原因是MySQL考虑到安全因素,默认配置只让从本地登录 打开 /etc/mysql/my.cnf 文件,找到 ...在本地用 root 登录: mysql -u root -p 修改 MySQL 数据库中 user 表中 对应用户名的 Host 字段,将 localhost 改为 % use mysql; update...是因为mysql数据库的user表里,存在用户名为空的账户即匿名账户,导致登录的时候是虽然用的是root,但实际是匿名登录的,通过错误提示里的''@'localhost'可以看出来,于是解决办法见 先关闭...此时要记得,紧接着输入    # mysql -u root mysql    mysql> delete from user where USER='';    mysql> FLUSH PRIVILEGES...后..先输入其它命令,再用mysql -u root mysql .它又会出现这个错误了. 然后KILL掉MYSQL进程,..重启正常的进程..

    2.7K30

    SQL 中如何给指定数据库创建只读用户?

    在SQL Server 中,为了保护数据库的安全,需要给不同的使用者开通不同的访问用户,那么如何简单的控制用户的权限呢?下面我们就创建一个只读用户,给大家学习使用。...创建访问指定数据库只读用户 1、首先打开【Microsoft SQLServer Management Studio】,用管理员账户登录。...针对每一个数据库,在下方【数据库角色成员身份】中,选择【db_datareader】,同时默认架构中也选择【db_datareader】 6、这样,一个只读用户就建立好了,用此用户登录时,就只能对映射的数据库进行只读访问了...添加只读用户查看存储过程权限 而当我们设置只给某些用户授权只读权限时(即public),这些用户可能需要查看sql的存储过程;因此需要授权给它。...”选择该用户可以操作的数据库 5、在“数据库角色成员身份”里选择"db_datareader" 6、这样一个只读用户就创建完成了。

    3.9K20

    ProxySQL + MySQL MGR读写分离架构的Sysbench只读压测报告

    当 Master 宕机,应用系统可能需要修改数据库连接地址,才能保证服务的可用性。为解决上述问题,可在 MRG 上层增加代理层,例如 ProxySQL。...实验结果表明: 在不引入负载均衡、ProxySQL Cluster 等中间件的理想情况下,【应用直连 MGR 2 个只读实例】QPS 最大值能达到 100w,为【应用直连 MySQL Master】的只读...实验发现,【4 层负载均衡 +ProxySQL Cluster+MGR 读写分离】架构的只读 QPS 最大值为 89w,约为【应用直连 MySQL Master】的只读 QPS 最大值 37w 的 2.4...压测指标 每秒执行请求数 QPS(Queries Per Second)数据库每秒执行的 SQL 数,包含 INSERT、SELECT、UPDATE、DETELE、COMMIT 等。...总 结 【4 层负载均衡 + ProxySQL Cluster + MGR 读写分离】架构适用于在大量并发读请求场景,只读 QPS 最大能达到 89w,约为【应用直连 MySQL Master】的只读

    84120

    PHP+MYSQL+COOKIE自动登陆3

    因为是自动登录几天所以这样啊 //然后是知道了用户名与密码之后是链接 $link=mysqli_connect('localhost','root','','test44'); //然后是指定php链接数据库的字符集...7天看是否点击,为什么一周内自动登陆7天要加int因为是天啊 $username=mysqli_real_escape_string($link,$username);为安全?...autologin)//点击了 { $expTime=time()+7*24*60*60; } else//没有点击不启动它把 { $expTime=0; } 点击了就能点就能自动登陆...7天啊,不需要在登陆了,但是注意一点7天后会自动退出,时间从你登陆后开始 如果没有点击的话,会为0, setcookie('islogin',1,$expTime);核心是用户名+点击一周内7天+登录按钮都...因为销毁密码难道别的用户不能用这个密码了吗是吧 exit(" alert('登录成功'); location.href='dl.php'; "); 登陆成功

    1.6K20

    mysql密码遗忘和登陆报错问题

    --------------------------- 发现的一个坑: mysql之前进行了全量备份,在恢复后,发现用之前的密码登陆不进去了!...使用上面的方法,无密码登陆后再重置密码,但是重置密码后发现仍然登陆不进去。 最后发现是因为mysql.user表内容被清空了!...6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | +-----------+------+-------------------------------------------+ 然后使用重置后的密码就能正常登陆了...ln -s /usr/local/mysql/var/mysql.sock /var/lib/mysql/mysql.sock 这样就没问题了 [root@test-huanqiu ~]# mysql...比如都修改为mysql:mysql权限 (2)可能进程里已经存在mysql进程 ps -ef|grep mysql 查出要是有mysql进程存在,就kill掉,再尝试重启mysql (3)可能是多次在机器上安装

    3.3K100
    领券