linux下實現shell腳本自動連接mongodb數據庫並創建索引


在linux下創建shell腳本

chmod 755 test.sh

#!/bin/bash
mongo 127.0.0.1:27017/wooyun <<EOF 2>/dev/null
db.wooyun_zentaos.ensureIndex({"datetime":1})
EOF

因為自己是在windows下編輯的shell腳本,然后上傳

所以在linux上執行

-bash: ./test.sh: /bin/bash^M: bad interpreter: No such file or directory

VI打開文件,沒發現任何問題,

把/bin/bash改成/bin/sh

-bash: ./test.sh: /bin/sh^M: bad interpreter: No such file or directory

依然報錯,腳本內容在VI下沒有任何問題,仔細一看錯誤消息,^M..明顯在第一行末尾被加入了個^M,

這種情況應該有兩種原因

1.在WIN底下用文本編輯工具修改過參數變量,在保存的時候沒注意編碼格式造成的,

2.也有可能是在VIM里修改,第一行末尾按到ctrl_v

 

這種情況應該有兩種原因

1.在WIN底下用文本編輯工具修改過參數變量,在保存的時候沒注意編碼格式造成的,

2.也有可能是在VIM里修改,第一行末尾按到ctrl_v

錯誤原因之一很有可能是你的腳本文件是DOS格式的, 即每一行的行尾以\r\n來標識, 其ASCII碼分別是0x0D, 0x0A.
可以有很多種辦法看這個文件是DOS格式的還是UNIX格式的, 還是MAC格式的
(1). vi filename
然后用命令
:set ff?
可以看到dos或unix的字樣. 如果的確是dos格式的, 那么你可以用set ff=unix把它強制為unix格式的, 然后存盤退出. 再運行一遍看.

2.可以用執行dos2unix 命令轉換編碼

#dos2unix myshell.sh

3..也可以用sed 這樣的工具來做:
sed 's/^M//' filename > tmp_filename
mv -f tmp_filename filename
來做
特別說明:^M並不是按鍵shift + 6產生的^和字母M, 它是一個字符, 其ASCII是0x0D, 生成它的辦法是先按CTRL+V, 然后再回車(或CTRL+M)

關於^M

new line of DOS/Windows

new line of dos/win:   0X0d0a
new line of linux/unix: 0X0a

 

連接mysql的

http://www.jb51.net/article/53955.htm

http://www.2cto.com/database/201410/343557.html

http://blog.163.com/ji_1006/blog/static/1061234120122217824662/

http://www.jb51.net/article/40942.htm

mysql -u USERNAME -p PASSWORD DATABASENAME <<EOF 2>/dev/null
    show databases;
EOF

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM