开启远程访问MySQL权限,允许远程访问
我们在自己电脑上远程登录数据库会遇到以下错误
data:image/s3,"s3://crabby-images/6dc35/6dc35754438412a4075ef579942b2c83a8a4ef2d" alt="1532427030029_7.24.1.jpg"
原因是MySQL默认是不允许远程访问。如果我们要实现远程访问,就得要去修改远程服务器上MySQL的配置文件 mysqld.cnf 。
在远程服务器终端输入命令:
data:image/s3,"s3://crabby-images/e5c48/e5c48725840ced3bb51f01ba36d3435202548602" alt="1532427041154_7.24.2.png"
把 bind-address = 127.0.0.1 这行注释,再保存退出。重启MySQL服务:
data:image/s3,"s3://crabby-images/f887f/f887f947500fd3f47b34f17f34d528449f634859" alt="1532427052342_7.24.3.png"
data:image/s3,"s3://crabby-images/846a3/846a3ec6d71ad72f54caf7e1f33ee6186705f229" alt="1532427060436_7.24.4.jpg"
data:image/s3,"s3://crabby-images/ae255/ae255a3927d7c8ada3d10a55cc6eae3b71227813" alt="1532427065748_7.24.5.jpg"
我们回到自己电脑再次登录,又出现以下错误:
data:image/s3,"s3://crabby-images/1acdf/1acdf3e50b873a186c94195b161d589d9f577e75" alt="1532427070342_7.24.6.jpg"
原因是安装MySQL时候root用户设置只允许本地登录。
登录mysql后,依次输入以下命令:
data:image/s3,"s3://crabby-images/f0886/f08865434ccdf413ba0bab43b8485ecc3bd7b12b" alt="1532427086639_7.24.7.png"
其中host表示主机,user表示用户,authentication_string表示加密后的密码。
我们可以看到root用户对应的host是localhost,表示root只允许在本地登录。
我们要想远程访问就得把localhost改成 %,一般我们不会修改root的设置,所以就创建一个新的用户用来远程访问。
data:image/s3,"s3://crabby-images/23bac/23bac883a67304acdc127431b0679867ed7ce4e5" alt="1532427099733_7.24.9.png"
data:image/s3,"s3://crabby-images/fcc8d/fcc8dcf672ad2530e8fbf9104a606ee7999adb2e" alt="1532427105655_7.24.10.jpg"
我们再用新创建的用户登录就可以实现远程访问了。
data:image/s3,"s3://crabby-images/a7406/a7406642b82b052cb5782ff008dbc4f194cb8b9a" alt="1532427112186_7.24.11.jpg"
作者:黑马程序员人工智能+Python培训学院
首发:http://python.itheima.com/