mac执行shell时的权限问题

2012-10-16 23:12:12 +08:00
 supersheep
shell菜鸟,写了行脚本来同步生产环境数据到本地

sync.sh

#!/bin/zsh
ssh f2e@f2e.dp "mysqldump -uroot -pdp_f2e_mysql_db tada |gzip -c -" | gunzip -c - | mysql -uroot tada

发现直接在命令行执行,或者source sync.sh都没问题
但是 zsh sync.sh以及./sync.sh
都会提示 ./sync.sh:2: permission denied: mysql
这是什么原因呢?
4361 次点击
所在节点    问与答
3 条回复
leiz
2012-10-17 00:41:50 +08:00
mysql指定的账号是root,所以denied. 这里的root是指mysql里面的root账号.
检查你在mysql用户表里面的root来源地址的限制。
use mysql;
select host, user, password from user;

1. 在mysql内更新root的许可来源地址。
2. 在mysql启动命令里添加 -h 参数指定服务器地址.
supersheep
2012-10-17 07:59:12 +08:00
@leiz mysql表root相关里有如下记录
+--------------------------+------+-------------------------------------------+
| host | user | password |
+--------------------------+------+-------------------------------------------+
| localhost | root | |
| HsumatoMacBook-Pro.local | root | |
| 127.0.0.1 | root | |

我需要如何更新呢?./sync.sh的来源应该就是localhost吧。
以及把mysql -uroot tada改为 mysql -uroot -hlocalhost tada还是出现同样的错误……
leiz
2012-10-17 10:19:26 +08:00
你试试改成-h 127.0.0.1,有时候mysql就是这么恶心。
还不行的话,尝试新建一个用户,再grant权限。

至于grant命令的用法,直接google即可。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/50168

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX