mysql数据库配置远程访问

运行环境

本地:Java JDBC连接
ubuntu服务器,mysql数据库

创建用户

在mysql里创建一个非root用户,用于远程访问

命令:

mysql> CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 

说明:
username - 你将创建的用户名,
host - 指定该用户在哪个主机上可以登陆,
如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%.
注意: % 不包括localhost
password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器.

例:
CREATE USER ‘cat’@’localhost’ IDENTIFIED BY ‘123456’;
CREATE USER ‘cat’@’112.80.248.73’ IDENDIFIED BY ‘123456’;
CREATE USER ‘cat’@’%’ IDENTIFIED BY ‘123456’;
CREATE USER ‘cat’@’%’ IDENTIFIED BY ”;
CREATE USER ‘gakki’@’%’;

授权

命令:

mysql> GRANT privileges ON databasename.tablename  TO 'username'@'host' WITH GRANT OPTION; 

说明:
privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见http://www.jb51.net/article/31850.htm).
如果要授予所的权限则使用ALL.;
databasename - 数据库名,
tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*
WITH GRANT OPTION-让该用户拥有给其他用户授权的权利,可以不写确保权限安全

例:
GRANT SELECT, INSERT ON test.user TO ‘cat’@’%’;
GRANT ALL ON *.* TO ‘cat’@’%’;

## 查看用户是否已经添加进去
mysql> SELECT User,Host FROM mysql.user;

更多操作见http://www.jb51.net/article/31850.htm

修改配置文件my.cnf

$ sudo vim /etc/mysql/my.cnf

添加:

#确保监听所有ip,默认只监听了127.0.0.1或者是localhost
bind-address = 0.0.0.0

重启mysql服务

$ sudo service mysql restart

如果服务器是 CentOS7,需要将 MySQL 服务加入防火墙

访问测试

$ mysql -h 112.80.248.73 -u gakki -p

你可能感兴趣的:(mysql,服务器)