日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > centos >内容正文

centos

(只需挨个复制粘贴命令即可部署)在Centos7下搭建文件服务器(VSFTPD)

發布時間:2023/12/1 centos 85 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (只需挨个复制粘贴命令即可部署)在Centos7下搭建文件服务器(VSFTPD) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
觀看北京尚學堂-百戰程序員筆記

一、VSFTPD簡介

Linux的組件(一款軟件),安裝到Linux后可以通過java代碼(FtpClient)實現文件的上傳。基于FTP協議。
由于VSFTPD是基于FTP協議,客戶端瀏覽器是需要通過http協議訪問圖片;如果希望客戶端直接訪問圖片服務器中的圖片,需要使用Nginx進行反向代理。

二、提煉核心命令

①,下載安裝vsftpd,完全在線安裝版

yum -y install vsftpd

yum install ftp -y

yum:代表從centos中心庫去自動安裝對應的組件
yum install代表安裝的意思
vsftpd代表組件名
-y表示需要確認的地方全部yes

安裝完后,vsftp 的配置文件在/etc/vsftpd/vsftpd.conf
②,添加ftp用戶,ftpuser為用戶名,可自定義

useradd ftpuser

登錄后默認的路徑為 /home/ftpuser
③,添加ftpuser這個用戶的密碼

passwd ftpuser

命名輸入之后需要輸入兩次密碼,太簡單了會有提示

④,ftp 默認的端口為 21,此時需要讓防火墻放開21端口

vim /etc/sysconfig/iptables

在行上面有 22 -j ACCEPT 下面另起一行輸入跟那行差不多的,只是把 22 換成 21,然后: wq 保存。
如圖所示:
⑤,重啟一下iptables

service iptables restart

⑥,修改selinux
此時已經外網已經可以訪問了,但是沒有返回路徑,此時需要修改一下selinux。
先查看一下狀態

getsebool -a | grep ftp

若報錯

setenforce: SELinux is disabled

如果需要重新開啟selinux,請按下面步驟:

vi /etc/selinux/config

更改為:SELINUX=1
必須重啟linux,從云服務器管理控制臺重啟,快速連接Ctrl+Shift+R,不重啟是沒辦法立刻開啟selinux的

若不報錯,執行下面兩行命令,開啟外網訪問

setsebool -P ftpd_full_access on

setsebool -P tftp_home_dir on

即將allow_ftpd_full_access和ftp_home_dir的狀態改成on。

連接服務器的時候要是出錯,最直接的方法就是把防火墻給關了。
訪問服務器的軟件傳輸模式改成主動

⑦,關閉匿名訪問
修改/etc/vsftpd/vsftpd.conf 文件:將anonymous_enable=NO原來是YES,需要改成NO。最后:wq保存并退出即可
步驟如下:
先切換到vsftpd的配置文件默認安裝位置

cd /etc/vsftpd/

ls一下,找到vsftpd.conf配置文件
然后,編輯一下該配置文件

vim vsftpd.conf

找到配置文件里面的這行命令,改成這個狀態anonymous_enable=NO,把YES改為NO。

保存并退出

Esc

:wq

最后,重啟一下stp服務即可

systemctl start vsftpd.service

查看一下服務狀態,若為綠色表示成功

systemctl status vsftpd.service

⑧,開啟被動模式,默認是開啟的,但是要指定一個端口范圍30000~30999,這個端口范圍可以隨意更改。
首先,編輯配置文件

vim /etc/vsftpd/vsftpd.conf

需要插入一些配置,insert插入一下
在配置文件vsftpd.conf最后加入下面兩行指定端口范圍

pasv_min_port=30000
pasv_max_port=30999

同樣iptables 也要相應的開啟這個范圍,參考步驟④,只不過開發的不是21這個端口了,重新復制一行,將端口號改成3000:30999范圍 ,之后記得重啟一下iptables ,參考步驟⑤。

⑨,設置開機自啟動vsftpd ftp服務

systemctl enable vsftpd.service

三、測試一下

連接服務器,在/etc/home/ftpuser上傳一張隨便的圖片,例如為a.png。

ftp://116.62.111.4:21(自己的服務器ip)

訪問成功之后需要進行輸入自己設置的用戶名和密碼(步驟二的②,③)。
也可以這樣訪問:

ftp://用戶名:密碼@自己服務器的ip

例如:ftp://ftpuser:密碼@116.62.111.4

四、通過java代碼FtpClient上傳圖片到ftpuser

①,創建一個maven項目
②,在pom.xml配置文件中添加約束

<dependencies><dependency><groupId>commons-net</groupId><artifactId>commons-net</artifactId><version>3.3</version></dependency></dependencies>

③,編寫測試類Text

將E盤下的sq.jpg上傳到服務器上為abc.jpg
package com.pdsu.bjsxt;import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream;import org.apache.commons.net.ftp.FTPClient;public class Test {public static void main(String[] args) throws IOException {FTPClient ftp = new FTPClient();ftp.connect("服務器ip", 21);//設置ip和端口ftp.login("用戶名", "密碼");//設置用戶名和密碼//設置文件類型ftp.setFileType(FTPClient.BINARY_FILE_TYPE);//圖片設置為上傳成二進制類型,否則會出現亂碼//選擇一個文件上傳,將E盤下的sq.jpg上傳到服務器上為abc.jpgInputStream is = new FileInputStream("E:/sq.jpg");ftp.storeFile("abc.jpg", is);ftp.logout();//關閉流System.out.println("上傳成功");} }
將E盤下的sq.jpg上傳到wsq文件夾下成為yy.jpg。
其中wsq文件夾不可以自動創建需要自己手動創建才行 package com.pdsu.bjsxt;import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream;import org.apache.commons.net.ftp.FTPClient;public class Test {public static void main(String[] args) throws IOException {FTPClient ftp = new FTPClient();ftp.connect("服務器ip", 21);//設置ip和端口ftp.login("用戶名", "密碼");//設置用戶名和密碼 //設置文件類型ftp.setFileType(FTPClient.BINARY_FILE_TYPE);//圖片設置為上傳成二進制類型,否則會出現亂碼//選擇一個文件上傳,將E盤下的sq.jpg上傳到服務器上為abc.jpgInputStream is = new FileInputStream("E:/sq.jpg");ftp.changeWorkingDirectory("/home/ftpuser/wsq");//將文件上傳到wsq文件夾下的yy.jps,其中wsq文件夾不可以自動創建需要自己手動創建ftp.storeFile("yy.jpg", is);ftp.logout();//關閉流System.out.println("上傳成功");} }

模板工具類(直接復制修改main函數即可)

package com.pdsu.utils;import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream;import org.apache.commons.net.ftp.FTP; import org.apache.commons.net.ftp.FTPClient; import org.apache.commons.net.ftp.FTPFile; import org.apache.commons.net.ftp.FTPReply;/*** ftp上傳下載工具類*/ public class FtpUtil {/*** Description: 向FTP服務器上傳文件* * @param host* FTP服務器hostname* @param port* FTP服務器端口* @param username* FTP登錄賬號* @param password* FTP登錄密碼* @param basePath* FTP服務器基礎目錄* @param filePath* FTP服務器文件存放路徑。例如分日期存放:/2015/01/01。文件的路徑為basePath+filePath* @param filename* 上傳到FTP服務器上的文件名* @param input* 輸入流* @return 成功返回true,否則返回false*/public static boolean uploadFile(String host, int port, String username, String password, String basePath,String filePath, String filename, InputStream input) {boolean result = false;FTPClient ftp = new FTPClient();try {int reply;ftp.connect(host, port);// 連接FTP服務器// 如果采用默認端口,可以使用ftp.connect(host)的方式直接連接FTP服務器ftp.login(username, password);// 登錄reply = ftp.getReplyCode();if (!FTPReply.isPositiveCompletion(reply)) {ftp.disconnect();return result;}// 切換到上傳目錄if (!ftp.changeWorkingDirectory(basePath + filePath)) {// 如果目錄不存在創建目錄String[] dirs = filePath.split("/");String tempPath = basePath;for (String dir : dirs) {if (null == dir || "".equals(dir))continue;tempPath += "/" + dir;if (!ftp.changeWorkingDirectory(tempPath)) {if (!ftp.makeDirectory(tempPath)) {return result;} else {ftp.changeWorkingDirectory(tempPath);}}}}// 設置上傳文件的類型為二進制類型ftp.setFileType(FTP.BINARY_FILE_TYPE);// 上傳文件if (!ftp.storeFile(filename, input)) {return result;}input.close();ftp.logout();result = true;} catch (IOException e) {e.printStackTrace();} finally {if (ftp.isConnected()) {try {ftp.disconnect();} catch (IOException ioe) {}}}return result;}/*** Description: 從FTP服務器下載文件* * @param host* FTP服務器hostname* @param port* FTP服務器端口* @param username* FTP登錄賬號* @param password* FTP登錄密碼* @param remotePath* FTP服務器上的相對路徑* @param fileName* 要下載的文件名* @param localPath* 下載后保存到本地的路徑* @return*/public static boolean downloadFile(String host, int port, String username, String password, String remotePath,String fileName, String localPath) {boolean result = false;FTPClient ftp = new FTPClient();try {int reply;ftp.connect(host, port);// 如果采用默認端口,可以使用ftp.connect(host)的方式直接連接FTP服務器ftp.login(username, password);// 登錄reply = ftp.getReplyCode();if (!FTPReply.isPositiveCompletion(reply)) {ftp.disconnect();return result;}ftp.changeWorkingDirectory(remotePath);// 轉移到FTP服務器目錄FTPFile[] fs = ftp.listFiles();for (FTPFile ff : fs) {if (ff.getName().equals(fileName)) {File localFile = new File(localPath + "/" + ff.getName());OutputStream is = new FileOutputStream(localFile);ftp.retrieveFile(ff.getName(), is);is.close();}}ftp.logout();result = true;} catch (IOException e) {e.printStackTrace();} finally {if (ftp.isConnected()) {try {ftp.disconnect();} catch (IOException ioe) {}}}return result;}public static void main(String[] args) throws FileNotFoundException {//將E盤下的sq.jpg圖片上傳到服務器的/home/ftpuser為下,上傳成為qqq.jpg這個圖片InputStream is = new FileInputStream("E:/sq.jpg");boolean result = FtpUtil.uploadFile("192.168.139.131", 21, "用戶名", "密碼", "/home/ftpuser", "/","qqq.jpg", is);if (result)System.out.println("上傳成功");elseSystem.out.println("上傳失敗");} }

五、反向代理安裝Nginx

Nginx是C語言開發,需要有C語言的環境,需要安裝一些組件
①,將壓縮包上傳到/usr/local/tmp下
切換一下目錄

cd /etc/vsftpd

安裝組件gcc

yum install gcc-c++ -y

安裝組件pcre

yum install -y pcre pcre-devel

安裝組件zlib

yum install -y zlib zlib-devel

安裝組件openssl

yum install -y openssl openssl-devel

②、準備創建一些文件夾,這幾個文件夾需要手動創建
進去var文件夾下面

cd /var

查看一下目錄結構

ls

里面沒有temp文件夾,此時需要創建一個temp文件夾

mkdir temp

進去文件夾里面

cd temp

在temp文件夾下創建一個nginx文件夾

mkdir nginx

③、進入到壓縮包所在的目錄

cd /usr/local/tmp

ls

解壓壓縮包

tar zxvf nginx-1.8.0.tar.gz

ls

進入到解壓后的目錄

cd nginx-1.8.0

ls

目錄里面會有個configure文件
其中\代表換行操作

./configure \> --prefix=/usr/local/nginx \ > --pid-path=/var/run/nginx/nginx.pid \ > --lock-path=/var/lock/nginx.lock \ > --error-log-path=/var/log/nginx/error.log \ > --http-log-path=/var/log/nginx/access.log \ > --with-http_gzip_static_module \ > --http-client-body-temp-path=/var/temp/nginx/client \ > --http-proxy-temp-path=/var/temp/nginx/proxy \ > --http-fastcgi-temp-path=/var/temp/nginx/fastcgi \ > --http-uwsgi-temp-path=/var/temp/nginx/uwsgi \

復制粘貼(此時的目錄必須在nginx-1.8.0目錄下)!!!!

進行編譯

make

安裝

make install

返回到安裝nginx的目錄下

cd /usr/local/nginx

ls

會發現有三個文件夾conf html sbin
conf :里面有所有nginx配置文件都在這個文件夾里面,其中nginx.conf是主配置文件
html:里面有兩個頁面,50x.html訪問出錯的頁面,和一個index.html訪問服務器默認的歡迎頁
sbin:啟動文件目錄,進去sbin目錄里面,cd sbin,ls,里面有個啟動文件nginx,然后啟動一下nginx,./nginx默認的是80端口
需要使防火墻放行8端口,參考二、④

然后,瀏覽器輸入http:你的ip回來到nginx自帶的index.html歡迎頁面

④、停止nginx服務
首先需要進入到sbin目錄下

cd /usr/local/nginx/sbin

啟動:

./nginx

快速停止:相當與eclipse從控制臺點紅方塊

./nginx -s stop

完整停止(推薦使用):相當與eclipse將服務stop

./nginx -s quit

⑤、設置nginx開機自啟動–使用編寫shell腳本

cd /etc/init.d

創建nginx文件編輯

vim nginx

#!/bin/sh # nginx - this script starts and stops the nginx daemin # # chkconfig: - 85 15# description: Nginx is an HTTP(S) server, HTTP(S) reverse \ # proxy and IMAP/POP3 proxy server# processname: nginx # config: /usr/local/nginx/conf/nginx.conf # pidfile: /usr/local/nginx/logs/nginx.pid# Source function library.. /etc/rc.d/init.d/functions# Source networking configuration.. /etc/sysconfig/network# Check that networking is up.[ "$NETWORKING" = "no" ] && exit 0nginx="/usr/local/nginx/sbin/nginx"prog=$(basename $nginx)NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"lockfile=/var/lock/subsys/nginxstart() {[ -x $nginx ] || exit 5[ -f $NGINX_CONF_FILE ] || exit 6echo -n $"Starting $prog: "daemon $nginx -c $NGINX_CONF_FILEretval=$?echo[ $retval -eq 0 ] && touch $lockfilereturn $retval}stop() {echo -n $"Stopping $prog: "killproc $prog -QUITretval=$?echo[ $retval -eq 0 ] && rm -f $lockfilereturn $retval}restart() {configtest || return $?stopstart}reload() {configtest || return $?echo -n $"Reloading $prog: "killproc $nginx -HUPRETVAL=$?echo}force_reload() {restart}configtest() {$nginx -t -c $NGINX_CONF_FILE}rh_status() {status $prog}rh_status_q() {rh_status >/dev/null 2>&1}case "$1" instart)rh_status_q && exit 0$1;;stop)rh_status_q || exit 0$1;;restart|configtest)$1;;reload)rh_status_q || exit 7$1;;force-reload)force_reload;;status)rh_status;;condrestart|try-restart)rh_status_q || exit 0;;*)echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"exit 2esac

⑥、設置文件的訪問權限

cd /etc/init.d

chmod 755 /etc/init.d/nginx

chkconfig --add nginx

(a+x ==> all user can execute 所有用戶可執行)
此時ls 會發現nginx變成了綠色的可執行文件了
⑦、在rc.local文件中加入一行配置

vi /etc/rc.local

加入這一行代碼,表示開機自啟動

/etc/init.d/nginx start

Esc

:wq

測試一下

cd /etc/init.d

service nginx start

/etc/init.d/nginx status

全報綠即安裝成功

⑧,加權限
進入到nginx的目錄下

cd /usr/local/nginx

ls

cd conf

ps aux|grep nginx

可以看見這里是nobody用戶權限

vim nginx.conf

在第一行中將user用戶打開并且改成你的用戶名

用戶權限必須給,這一步很重要

user ftpuser

若報錯

cd /usr/local/nginx/sbin

查看進程

ps aux|grep nginx

殺死進程(若刪不掉,是因為有守護進程,將root也給刪掉)

kill -7 -進程ID

然后在重啟nginx

./ nginx

此時要是在報錯需要添加歡迎頁面

加載歡迎頁面

cd /usr/local/nginx/conf

vim nginx.conf

VSFTPD卸載
rpm -qa | grep vsftpdrpm -e vsftpd

總結

以上是生活随笔為你收集整理的(只需挨个复制粘贴命令即可部署)在Centos7下搭建文件服务器(VSFTPD)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。