Shell腳本搭建FTP服務(wù)器(vsftpd)
各種知識(shí)點(diǎn)都寫在注釋里。
只需要 sudo $PATH/ftpsetup.sh即可,默認(rèn)以test/test為用戶名密碼登錄,登錄后的根目錄只讀,子目錄writable可寫。
Ubuntu 13和Linux Mint 15上測(cè)試ok。
#!/bin/bash
# by liuhx 2013-Nov-04.
# 設(shè)置ftp環(huán)境的腳本。ftp的根目錄為只讀,其下的writable目錄為可寫
# 可自定義以下四項(xiàng)
# ftp用戶名
userName="test"
# ftp密碼
password="test"
# ftp根目錄,末尾不要加/
ftp_dir="$HOME/ftp"
# 可寫目錄的目錄名
writable="writable"
# 如果沒(méi)有加sudo,提示錯(cuò)誤并退出
if [ "x$(id -u)" != x0 ]; then
echo "Error: please run this script with 'sudo'."
exit 1
fi
# 核心工具,vsftpd。 -y是對(duì)所有提示都回答yes
sudo apt-get -y install vsftpd
# db-util是用來(lái)生成用戶列表數(shù)據(jù)庫(kù)的工具
sudo apt-get -y install db-util
# 以下步驟參考https://help.ubuntu.com/community/vsftpd#The_workshop
# 創(chuàng)建用戶名和密碼的數(shù)據(jù)庫(kù),以單數(shù)行為用戶名,雙數(shù)行為密碼記錄
cd /tmp
printf "$userName\n$password\n" > vusers.txt
db_load -T -t hash -f vusers.txt vsftpd-virtual-user.db
sudo cp -f vsftpd-virtual-user.db /etc/
cd /etc
chmod 600 vsftpd-virtual-user.db
if [ ! -e vsftpd.conf.old ]; then
sudo cp -f vsftpd.conf vsftpd.conf.old
fi
# 創(chuàng)建PAM file。bash的here-document,直接輸出這些內(nèi)容覆蓋原文件
(sudo cat <<EOF
auth required pam_userdb.so db=/etc/vsftpd-virtual-user
account required pam_userdb.so db=/etc/vsftpd-virtual-user
session required pam_loginuid.so
EOF
) > pam.d/vsftpd.virtual
# 獲取當(dāng)前的用戶名,不能用whoami或$LOGNAME,否則得到的是root
owner=`who am i| awk '{print $1}'`
# 創(chuàng)建vsftpd的配置文件。
(sudo cat <<EOF
listen=YES
anonymous_enable=NO
local_enable=YES
virtual_use_local_privs=YES
write_enable=YES
local_umask=000
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
hide_ids=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd.virtual
guest_enable=YES
user_sub_token=$USER
rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
EOF
) > vsftpd.conf
sudo echo "local_root=$ftp_dir" >> vsftpd.conf
# 虛擬用戶需要映射為本地用戶,設(shè)為自己,避免權(quán)限問(wèn)題,但同時(shí)也令自己對(duì)ftp根目錄不可寫
sudo echo "guest_username=$owner" >> vsftpd.conf
# 設(shè)置了每個(gè)虛擬用戶只可以瀏覽其根及子目錄(否則可訪問(wèn)磁盤根目錄),
# 這樣會(huì)被要求根目錄不可寫,所以創(chuàng)建一個(gè)writable的子目錄
mkdir "$ftp_dir"
mkdir "$ftp_dir/$writable"
sudo chmod a-w "$ftp_dir"
sudo chown -R $owner:$owner $ftp_dir
sudo /etc/init.d/vsftpd restart
- Java連接sftp服務(wù)器實(shí)現(xiàn)上傳下載功能
- Java連接服務(wù)器的兩種方式SFTP和FTP
- Windows?10搭建SFTP服務(wù)器的詳細(xì)過(guò)程【公網(wǎng)遠(yuǎn)程訪問(wèn)】
- PyCharm如何配置SSH和SFTP連接遠(yuǎn)程服務(wù)器
- go語(yǔ)言實(shí)現(xiàn)sftp包上傳文件和文件夾到遠(yuǎn)程服務(wù)器操作
- 詳解Java使用Jsch與sftp服務(wù)器實(shí)現(xiàn)ssh免密登錄
- java使用SFTP上傳文件到資源服務(wù)器
- Java使用SFTP上傳文件到服務(wù)器的簡(jiǎn)單使用
- 開源SFTP服務(wù)器軟件SFTPGo詳解
相關(guān)文章
Shell腳本創(chuàng)建指定大小文件的測(cè)試數(shù)據(jù)
這篇文章主要介紹了Shell腳本創(chuàng)建指定大小文件的測(cè)試數(shù)據(jù),本文同時(shí)給出使用DD命令和Shell腳本解決這個(gè)需求,給出的腳本功能更加強(qiáng)大,需要的朋友可以參考下2015-03-03bash腳本如何監(jiān)控cup/內(nèi)存/磁盤使用率
本文主要介紹了bash腳本如何監(jiān)控cup/內(nèi)存/磁盤使用率,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10每天學(xué)一個(gè) Linux 命令之more命令
more命令,功能類似 cat ,more會(huì)以一頁(yè)一頁(yè)的顯示方便使用者逐頁(yè)閱讀,而最基本的指令就是按空白鍵(space)就往下一頁(yè)顯示,按 b 鍵就會(huì)往回(back)一頁(yè)顯示,而且還有搜尋字串的功能2016-12-12Linux共享內(nèi)存實(shí)現(xiàn)機(jī)制的詳解
這篇文章主要介紹了Linux共享內(nèi)存實(shí)現(xiàn)機(jī)制的詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07Linux用戶在第一次登錄時(shí)強(qiáng)制更改初始密碼
在多用戶Linux環(huán)境下,創(chuàng)建使用某個(gè)隨機(jī)默認(rèn)密碼的用戶帳戶是標(biāo)準(zhǔn)做法。之后在成功登錄后,新用戶可以將默認(rèn)密碼更改成自己的密碼。出于安全方面的原因,常常建議“迫使”用戶在第一次登錄后更改默認(rèn)密碼,以確保最初的一次性密碼不再使用,需要的朋友可以參考下2015-10-10