2

我有一个名为 database.php 的文件。在那个文件里面:

database_useranme = "ferdinel";
database_sixtysec = "ferdinel_db";

现在我制作了一个脚本来获取数据库'ferdinel_db',这是我的脚本:

#!/bin/bash

#To get the line that has a "database_sixtysec ="
getdb=`grep "database_sixtysec =" < /www/vhost/database.php`

# To verify Output what's inside in get_db
echo "$getdb"   

# This one is to get the ferdinel_db
databaseName=`echo ${getdb#*\"} | tr -d '"; '`         

#Below is to count the file if exist in $databaseName variable (ferdinel_db)
countFlag=`ls /var/lib/mysql/$databaseName | grep 'sixty_options.frm\|site_settings.frm' | wc -l` 

#Ouput Either 0 , 1 or 2
echo $countFlag

然后我chmod +xchown root:root脚本。

现在当我尝试运行它时,输出是:

$database_sixtysec = "ferdinel_db";
: No such file or directory_db
0

我希望为 2,因为当我在 /var/lib/mysql/ferdinel_db/ 中手动查看时,那里有Sixty_options.frmsite_settings.frm

我在末尾添加-x#!/bin/bash ,这是什么输出:

' getdb='$database_sixtysec = "ferdinel_db";
'+ echo 'ferdinel_db";
++ tr -d '"; '
+ databaseName=$'ferdinel_db\r'
' echo '$database_sixtysec = "ferdinel_db";
$database_sixtysec = "ferdinel_db";
++ ls $'/var/lib/mysql/ferdinel_db\r'
++ grep 'sixty_options.frm\|site_settings.frm'
++ wc -l
: No such file or directorycssv25_db

在 db 的末尾有一些东西,比如\r

4

3 回答 3

5

您的脚本有 CRLF 结尾。尝试使用dos2unix编辑器中的设置来修复它。

于 2013-09-26T21:42:54.803 回答
1

将脚本的第一行更改为:

#!/bin/bash -x

并运行它。这将使您更好地了解脚本中发生的事情。

于 2013-09-26T21:48:53.017 回答
0

我只是想通了!

首先,为了真正发生的事情,我-x#!/bin/bash.

#!/bin/bash -x

当我运行它时,您可以查看所有过程,这是输出:

' getdb='$database_sixtysec = "ferdinel_db";
'+ echo 'ferdinel_db";
++ tr -d '"; '
+ databaseName=$'ferdinel_db\r'
' echo '$database_sixtysec = "ferdinel_db";
$database_sixtysec = "ferdinel_db";
++ ls $'/var/lib/mysql/ferdinel_db\r'
++ grep 'sixty_options.frm\|site_settings.frm'
++ wc -l
: No such file or directorycssv25_db

我在+ databaseName=$'ferdinel_db\r'. 并且对此进行研究,这就是我们所说的Windows 回车,因为文件是在 Windows 中编辑的。

所以要\r在末尾消除ferdinel_db,我\rtr -d '"; '

databaseName=`echo ${getdb#*\"} | tr -d '"; \r'`

这解决了我的问题。感谢您的所有帮助!

于 2013-09-27T15:06:58.417 回答