V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
supersheep
V2EX  ›  问与答

mac执行shell时的权限问题

  •  
  •   supersheep · 2012-10-16 23:12:12 +08:00 · 4336 次点击
    这是一个创建于 4216 天前的主题,其中的信息可能已经有所发展或是发生改变。
    shell菜鸟,写了行脚本来同步生产环境数据到本地

    sync.sh

    #!/bin/zsh
    ssh [email protected] "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
    这是什么原因呢?
    3 条回复    1970-01-01 08:00:00 +08:00
    leiz
        1
    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
        2
    supersheep  
    OP
       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
        3
    leiz  
       2012-10-17 10:19:26 +08:00
    你试试改成-h 127.0.0.1,有时候mysql就是这么恶心。
    还不行的话,尝试新建一个用户,再grant权限。

    至于grant命令的用法,直接google即可。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1732 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 00:36 · PVG 08:36 · LAX 17:36 · JFK 20:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.