中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現用Shell腳本搭建FTP服務器

發布時間:2021-09-28 14:11:35 來源:億速云 閱讀:245 作者:iii 欄目:開發技術

本篇內容介紹了“如何實現用Shell腳本搭建FTP服務器”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

各種知識點都寫在注釋里。

只需要 sudo $PATH/ftpsetup.sh即可,默認以test/test為用戶名密碼登錄,登錄后的根目錄只讀,子目錄writable可寫。

Ubuntu 13和Linux Mint 15上測試ok。

代碼如下:

#!/bin/bash
# by liuhx 2013-Nov-04.
# 設置ftp環境的腳本。ftp的根目錄為只讀,其下的writable目錄為可寫

# 可自定義以下四項
# ftp用戶名
userName="test"
# ftp密碼
password="test"
# ftp根目錄,末尾不要加/
ftp_dir="$HOME/ftp"
# 可寫目錄的目錄名
writable="writable"


# 如果沒有加sudo,提示錯誤并退出
if [ "x$(id -u)" != x0 ]; then 
  echo "Error: please run this script with 'sudo'." 
  exit 1
fi

# 核心工具,vsftpd。 -y是對所有提示都回答yes
sudo apt-get -y install vsftpd
# db-util是用來生成用戶列表數據庫的工具
sudo apt-get -y install db-util

# 以下步驟參考https://help.ubuntu.com/community/vsftpd#The_workshop
# 創建用戶名和密碼的數據庫,以單數行為用戶名,雙數行為密碼記錄
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

# 創建PAM file。bash的here-document,直接輸出這些內容覆蓋原文件
(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

# 獲取當前的用戶名,不能用whoami或$LOGNAME,否則得到的是root
owner=`who am i| awk '{print $1}'`

# 創建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
# 虛擬用戶需要映射為本地用戶,設為自己,避免權限問題,但同時也令自己對ftp根目錄不可寫
sudo echo "guest_username=$owner" >> vsftpd.conf


# 設置了每個虛擬用戶只可以瀏覽其根及子目錄(否則可訪問磁盤根目錄),
# 這樣會被要求根目錄不可寫,所以創建一個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

“如何實現用Shell腳本搭建FTP服務器”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海门市| 化州市| 江川县| 中阳县| 烟台市| 松滋市| 房山区| 色达县| 西华县| 木里| 措美县| 遂昌县| 林周县| 团风县| 平乡县| 尼玛县| 灵武市| 榆树市| 揭东县| 五家渠市| 稷山县| 菏泽市| 尉氏县| 南宁市| 康定县| 奉节县| 双峰县| 原阳县| 西华县| 阿荣旗| 安阳县| 柳河县| 都兰县| 天水市| 阜新| 岳阳市| 清远市| 建水县| 启东市| 安顺市| 康乐县|