部署mysql后,无法设置用户远程登陆(%只所有用户,不可以,只能给指定的ip?)

MySQL允许远程访问的设置

1.注释bind-address = 127.0.0.1。

代码如下:

>sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

将bind-address = 127.0.0.1注释掉(即在行首加#),如下:

代码如下:

# Instead of skip-networking the default is now to listen only on

# localhost which is more compatible and is not less secure.

# bind-address          = 127.0.0.1

除了注视掉这句话之外,还可以把后面的IP地址修改成允许连接的IP地址。但是,如果只是开发用的数据库,为了方便起见,还是推荐直接注释掉。

从上面的注释中,可以看出,旧版本的MySQL(从一些资料上显示是5.0及其以前的版本)上使用的是skip-networking。所以,善意提醒一下,使用旧版本的小伙伴请注意一下。

2.删除匿名用户

登录进数据库:

代码如下:

>mysql -uroot -p123456

然后,切换到数据库mysql。SQL如下:

代码如下:

use mysql;

然后,删除匿名用户。SQL如下:

代码如下:

delete from user where user=‘‘;

3.增加允许远程访问的用户或者允许现有用户的远程访问。

接着上面,删除匿名用户后,给root授予在任意主机(%)访问任意数据库的所有权限。SQL语句如下:

代码如下:

mysql> grant all privileges on *.* to ‘root‘@‘%‘ identified by ‘123456‘ with grant option;

如果需要指定访问主机,可以把%替换为主机的IP或者主机名。另外,这种方法会在数据库mysql的表user中,增加一条记录。如果不想增加记录,只是想把某个已存在的用户(例如root)修改成允许远程主机访问,则可以使用如下SQL来完成:

代码如下:

update user set host=‘%‘ where user=‘root‘ and host=‘localhost‘;

4.退出数据库

代码如下:

mysql> exit

在MySQL Shell执行完SQL后,需要退出到Bash执行系统命令,需要执行exit。因为这个太常用也太简单。以下内容就提示“退出”,不再重复列出这个命令。

5.重启数据库

完成上述所有步骤后,需要重启一下数据库,才能让修改的配置生效。执行如下命令重启数据库:

代码如下:

>sudo service mysql restart

时间: 2024-10-16 00:44:10

部署mysql后,无法设置用户远程登陆(%只所有用户,不可以,只能给指定的ip?)的相关文章

Linux关闭root用户远程登陆

之前的博文有写到如何修改远程登陆端口,这次说一下如何禁止root用户远程登陆. 方法很简单,首先用root用户vi /etc/ssh/sshd_config文件,找到如下文件 # Authentication: #LoginGraceTime 2m #PermitRootLogin yes #StrictModes yes 将#PermitRootLogin yes前的注释符号#去掉,并将yes改成no.即 PermitRootLogin no 保存并退出vi,再用root登陆时,会显示无法连接

MYSQL授权用户远程登陆

因为之前一直在服务器上直接操作mysql,所以没有遇到过什么问题,今天开发突然要测试个功能,需要连接数据库,发现一直连接不上! 因为时间过得比较久mysql的root密码已经忘记 1.linux下更改root密码 vim /etc/my.cnf 在[mysqld]的段中加上一句:skip-grant-tables skip-grant-tables wq保存 /etc/init.d/mysqld reatart #重启mysql服务 mysql #登录mysql   Welcome to the

破解Windows Server 2003只允许3个用户远程登陆

导读:WIN2003在使用远程桌面登录的时候,一台机器默认情况下只允许3个用户同时登录. 这很不方便.我们修改WIN2003远程桌面的连接数,可以设置3个以上用户远程桌面. 1.启动终端服务:在"运行"里输入 gpedit.msc 后按回车键,选择"计算机配置"——"管理模板"——"windows组件"——"终端服务",把“限制连接数量”设置为"已启动",最大连接数设为100,把&quo

mysql 从库设置read-only 对super权限的用户无效的问题

由于在测试mysql主从读写分离的时候,用root用户设置从库为read-only ,但是重启生效后发现,root用户照样可以进行update insert ,此时root用有all privilege权限,包括super(管理)权限 测试单独回收revoke root的super权限后再试,发现root此时 已经不能写操作了 因此在给普通用户,或区分读写分离用户时,注意要回收super权限,否则对read-only无效. 另外为了防止普通用户对从库进行插入,在给用户分配权限时要回收super权

mysql 设置远程登陆以及新增用户

mysql 简单的管理命令: 启动mysql sudo start mysql 停止mysql sudo stop mysql 允许远程访问的设置: sudo vi /etc/mysql/my.cnf 注释掉 bind-address = 127.0.0.1 增加新用户: GRANT ALL PRIVILEGES ON *.* TO [email protected]'%' IDENTIFIED BY "123456"; GRANT命令说明: ALL PRIVILEGES 是表示所有权

MySQL用户远程登陆

默认情况下,root用户是不具备远程登录的权限. 1.切换mysql表,查看当前用户信息 select host,user from user where user = 'root' 2.给用户进行授权 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'ds' WITH GRANT OPTION; 这里%代表任意地址,也可以指定访问的IP地址.ds 代表远程访问密码

[winserver]设置Server2008R2远程桌面允许每个用户运行多个会话

首先打开"服务器管理器",选择"角色"-在对话框右边部分选择"添加角色" 根据提示一步步安装即可. 然后在角色中找到"远程桌面服务" 去掉"限制每个用户只能进行一个会话" 这样就可以用同一个用户进行多次远程连接会话.

Confluence 6 用户目录图例 - 使用 LDAP 授权,在用户第一次登陆时拷贝用户

上面的图:Confluence 连接到一个 LDAP 目录只用作授权,当用户登录 Confluence 的时候,使用 LDAP 授权并且将用户信息同步到本地路服务器上. https://www.cwiki.us/display/CONFLUENCEWIKI/Diagrams+of+Possible+Configurations+for+User+Management 原文地址:http://blog.51cto.com/ossez/2105170

(转)Linux SSH配置和禁止Root远程登陆设置

原文 一.修改vi /etc/ssh/sshd_config 文件 1.修改默认端口:默认Port为22,并且已经注释掉了:修改是把注释去掉,并修改成其它的端口. 2.禁止root用户远程登陆:修改PermitRootLogin,默认为yes且注释掉了:修改是把注释去掉,并改成no. 3.PermitEmptyPasswords   no不允许空密码用户login 二.ssh的公钥认证配置: 修改vi /etc/ssh/sshd_config 文件 RSAAuthentication yes