0

我正在尝试编写一个 bash 脚本来将数据库从远程服务器迁移到本地。不幸的是,我们的服务器之一是 windows 服务器。我安装了freesshd,所以我可以使用ssh。

当我从我的 ubuntu shell 运行它时:

sshpass -p 'my_password' ssh user@host 
  'C:/wamp/bin/mysql/mysql5.1.36/bin/mysqldump 
  -u root -pmypassword mybase --result-file=C:/wamp/outfiles/mybase.sql'

它运行良好,并且倾倒了基地。不幸的是,当我从 bash 脚本做同样的事情时 - 我得到了permission denied反馈。为什么?来自脚本的命令和常规 shell 命令之间有什么区别吗?

这是我现在的 bash 脚本:

#!/bin/bash

remoteHost=$1
remoteUser=$2
echo -n "Provide remote db password: "
read -s remoteDbPass
echo ""
echo -n "Provide remote server password: "
read -s remotePass
echo ""
dbName=$3
localDbName=$4
dumpPath=/var/lib/mysql/dumps/
winMysqlPath=C:/wamp/bin/mysql/mysql5.1.36/bin/
winDumpPath=C:/wamp/outfiles/

sshpass -p '$remotePass' ssh $remoteUser@$remoteHost '${winMysqlPath}mysqldump -u root -p$remoteDbPass $dbName --result-file=$winDumpPath$dbName.sql'
pscp -pw $remotePass $remoteUser@$remoteHost:$winDumpPath$dbName.sql $dumpPath$dbName.sql
mysql $localDbName < $dumpPath$dbName.sql
4

1 回答 1

2

用单引号引用的变量'不会被扩展。改用双引号"

于 2013-04-26T09:28:08.603 回答