站長資訊網
        最全最豐富的資訊網站

        Linux下使用Nginx+vsftpd搭建圖片服務器

        傳統項目中的圖片管理

        傳統項目中,可以在web項目中添加一個文件夾,來存放上傳的圖片。例如在工程的根目錄WebRoot下創建一個images文件夾。把圖片存放在此文件夾中就可以直接使用在工程中引用。

        優點:引用方便,便于管理

        缺點:

        1、如果是分布式環境圖片引用會出現問題。

        2、圖片的下載會給服務器增加額外的壓力。

        一、安裝Nginx
        1 nginx安裝環境
        nginx是C語言開發,建議在linux上運行,本教程使用CentOS6.5作為安裝環境。

        安裝nginx需要先將官網下載的源碼進行編譯,編譯依賴gcc環境,如果沒有gcc環境,需要安裝gcc:

        yum install gcc-c++

        PCRE(Perl Compatible Regular Expressions)是一個Perl庫,包括 perl 兼容的正則表達式庫。nginx的http模塊使用pcre來解析正則表達式,所以需要在linux上安裝pcre庫。

        yum install -y pcre pcre-devel

        注:pcre-devel是使用pcre開發的一個二次開發庫。nginx也需要此庫。

        zlib庫提供了很多種壓縮和解壓縮的方式,nginx使用zlib對http包的內容進行gzip,所以需要在linux上安裝zlib庫。

        yum install -y zlib zlib-devel

        OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼算法、常用的密鑰和證書封裝管理功能及SSL協議,并提供豐富的應用程序供測試或其它目的使用。

        nginx不僅支持http協議,還支持https(即在ssl協議上傳輸http),所以需要在linux安裝openssl庫。

        yum install -y openssl openssl-devel

        2 編譯安裝
        將nginx-1.8.0.tar.gz拷貝至linux服務器。

        解壓:

        tar -zxvf nginx-1.8.0.tar.gz進入目錄:

        cd nginx-1.8.0

        2.1、 configure

        ./configure –help查詢詳細參數(參考本教程附錄部分:nginx編譯參數)

        參數設置如下:

        ./configure

        –prefix=/usr/local/nginx

        –pid-path=/var/run/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

        –http-scgi-temp-path=/var/temp/nginx/scgi

        注意:上邊將臨時文件目錄指定為/var/temp/nginx,需要在/var下創建temp及nginx目錄

        2.2、 編譯安裝

        make

        make  install

        安裝成功查看安裝目錄 :

        cd /usr/local/nginx/

        Linux下使用Nginx+vsftpd搭建圖片服務器

        2.3 啟動nginx
         

        進入目錄:

        cd /usr/local/nginx/sbin/啟動:

        ./nginx

        查詢nginx進程:

        ps aux|grep nginx

        查看nginx狀態:

        service nginx status

        Linux下使用Nginx+vsftpd搭建圖片服務器

        2.4 測試
        nginx安裝成功,啟動nginx,即可訪問虛擬機上的nginx:

        查看ip地址:ifconfig

        Linux下使用Nginx+vsftpd搭建圖片服務器

        訪問地址:http:172.20.10.7

        2.5 停止nginx
         

        方式1,快速停止:

        cd /usr/local/nginx/sbin./nginx -s stop

        此方式相當于先查出nginx進程id再使用kill命令強制殺掉進程。

        方式2,完整停止(建議使用):

        cd /usr/local/nginx/sbin./nginx -s quit

        此方式停止步驟是待nginx進程處理任務完畢進行停止。

        2.6 重啟nginx

        方式1,先停止再啟動(建議使用):

        對nginx進行重啟相當于先停止nginx再啟動nginx,即先執行停止命令再執行啟動命令。

        如下:

        ./nginx -s quit./nginx

        方式2,重新加載配置文件:

        當nginx的配置文件nginx.conf修改后,要想讓配置生效需要重啟nginx,使用-s reload不用先停止nginx再啟動nginx即可將配置信息在nginx中生效,如下:

        ./nginx -s reload2.7 開機自啟動nginx

        2.7.1 編寫shell腳本
        這里使用的是編寫shell腳本的方式來處理

        vi /etc/init.d/nginx  (輸入下面的代碼)

        #!/bin/bash
        # nginx Startup script for the Nginx HTTP Server
        # it is v.0.0.2 version.
        # chkconfig: – 85 15
        # description: Nginx is a high-performance web and proxy server.
        #              It has a lot of features, but it’s not for everyone.
        # processname: nginx
        # pidfile: /var/run/nginx.pid
        # config: /usr/local/nginx/conf/nginx.conf
        nginxd=/usr/local/nginx/sbin/nginx
        nginx_config=/usr/local/nginx/conf/nginx.conf
        nginx_pid=/var/run/nginx.pid
        RETVAL=0
        prog=”nginx”
        # Source function library.
        . /etc/rc.d/init.d/functions
        # Source networking configuration.
        . /etc/sysconfig/network
        # Check that networking is up.
        [ ${NETWORKING} = “no” ] && exit 0
        [ -x $nginxd ] || exit 0
        # Start nginx daemons functions.
        start() {
        if [ -e $nginx_pid ];then
          echo “nginx already running….”
          exit 1
        fi
          echo -n $”Starting $prog: “
          daemon $nginxd -c ${nginx_config}
          RETVAL=$?
          echo
          [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx
          return $RETVAL
        }
        # Stop nginx daemons functions.
        stop() {
                echo -n $”Stopping $prog: “
                killproc $nginxd
                RETVAL=$?
                echo
                [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid
        }
        # reload nginx service functions.
        reload() {
            echo -n $”Reloading $prog: “
            #kill -HUP `cat ${nginx_pid}`
            killproc $nginxd -HUP
            RETVAL=$?
            echo
        }
        # See how we were called.
        case “$1” in
        start)
                start
                ;;
        stop)
                stop
                ;;
        reload)
                reload
                ;;
        restart)
                stop
                start
                ;;
        status)
                status $prog
                RETVAL=$?
                ;;
        *)
                echo $”Usage: $prog {start|stop|restart|reload|status|help}”
                exit 1
        esac
        exit $RETVAL

        按Esc ,然后輸入  :wq  保存并退出

        2.7.2 設置文件的訪問權限
        chmod a+x /etc/init.d/nginx  (a+x ==> all user can execute  所有用戶可執行)

        這樣在控制臺就很容易的操作nginx了:查看Nginx當前狀態、啟動Nginx、停止Nginx、重啟Nginx…

        /etc/init.d/nginx status

        /etc/init.d/nginx start

        /etc/init.d/nginx stop

        /etc/init.d/nginx restart

        Linux下使用Nginx+vsftpd搭建圖片服務器

        如果修改了nginx的配置文件nginx.conf,也可以使用上面的命令重新加載新的配置文件并運行,可以將此命令加入到rc.local文件中,這樣開機的時候nginx就默認啟動了

        2.7.3 加入到rc.local文件中
         

        vi /etc/rc.local

        加入一行  /etc/init.d/nginx start    保存并退出,下次重啟會生效

        二、Linux安裝 ftp 組件
        1 安裝vsftpd組件
        安裝完后,有/etc/vsftpd/vsftpd.conf 文件,是vsftp的配置文件。

        [root@bogon ~]# yum -y install vsftpd

        2 添加一個ftp用戶
        此用戶就是用來登錄ftp服務器用的。

        [root@bogon ~]# useradd ftpuser

        這樣一個用戶建完,可以用這個登錄,記得用普通登錄不要用匿名了。登錄后默認的路徑為 /home/ftpuser.

        3 給ftp用戶添加密碼。
        [root@bogon ~]# passwd ftpuser

        輸入兩次密碼后修改密碼。

        4 防火墻開啟21端口
        查看防火墻狀態: systemctl status firewalld

        開啟端口:  firewall-cmd –zone=public –add-port=21/tcp –permanent

        重新加載端口配置: firewall-cmd –reload

        查詢端口號21 是否開啟: firewall-cmd –query-port=21/tcp

        查詢有哪些端口是開啟的:  firewall-cmd –list-port

        關閉防火墻: systemctl stop firewalld.service   

        開啟防火墻: systemctl start firewalld

        禁止firewall開機啟動:  systemctl disable firewalld.service 

        CentOS升級到7之后,發現無法使用iptables控制Linuxs的端口,baidu之后發現Centos 7使用firewalld代替了原來的iptables。

         
        5 修改selinux
         

        外網是可以訪問上去了,可是發現沒法返回目錄(使用ftp的主動模式,被動模式還是無法訪問),也上傳不了,因為selinux作怪了。

        修改selinux:

        執行以下命令查看狀態:

        [root@bogon ~]# getsebool -a | grep ftp 

        allow_ftpd_anon_write –> off

        allow_ftpd_full_access –> off

        allow_ftpd_use_cifs –> off

        allow_ftpd_use_nfs –> off

        ftp_home_dir –> off

        ftpd_connect_db –> off

        ftpd_use_passive_mode –> off

        httpd_enable_ftp_server –> off

        tftp_anon_write –> off

        執行上面命令,再返回的結果看到兩行都是off,代表,沒有開啟外網的訪問

        [root@bogon ~]# setsebool -P allow_ftpd_full_access on

        [root@bogon ~]# setsebool -P ftp_home_dir on

        6 關閉匿名訪問
        修改/etc/vsftpd/vsftpd.conf文件:

        Linux下使用Nginx+vsftpd搭建圖片服務器

        重啟ftp服務:

        [root@bogon ~]# service vsftpd restart

        查看狀態:systemctl status vsftpd.service 

        ———————

        7 設置開機啟動vsftpd ftp服務
        [root@bogon ~]# chkconfig vsftpd on

        三、創建目錄
        mkdir /home/ftpuser/www/images/

        修改用戶訪問權限

        chown ftpuser /home/ftpuser
        chmod 777 -R /home/ftpuser

         修改nginx/conf/nginx.conf在默認的server里再添加一個location并指定實際路徑:

        進入目錄: cd /usr/local/nginx/con/

        編輯: vim nginx.conf

        location / {
          root /home/ftpuser/www;#定義服務器的默認網站根目錄位置
          index index.html index.htm;
        }

        Linux下使用Nginx+vsftpd搭建圖片服務器

        修改完后需要重新啟動nginx

        service nginx restart說明

         root則是將images映射到/home/ftpuser/www/images/

        確認 nginx 和  vsftpd 啟動成功后 可以試著上傳文件到/home/ftpuser/www/images/ 目錄下

        打開瀏覽器訪問:http://172.20.10.7/images/bg1.jpg

        Linux下使用Nginx+vsftpd搭建圖片服務器

        完畢!

        good luck !

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 精品国产婷婷久久久| 亚洲午夜精品久久久久久浪潮| 精品无人区无码乱码毛片国产 | 亚洲欧美精品综合中文字幕| 国产精品无码一区二区三区电影| 国产成人精品视频播放| 欧美精品免费专区在线观看| 尤物国产在线精品福利一区| 日韩精品中文字幕无码一区| 精品国产国产综合精品| 久久精品国产亚洲麻豆| 精品久久久噜噜噜久久久| 亚洲视频在线精品| 久久久久亚洲精品男人的天堂| 精品国产三级a∨在线| 亚洲精品无码你懂的网站| 精品熟女少妇aⅴ免费久久 | 87国产私拍福利精品视频| 99爱在线精品免费观看| 全球AV集中精品导航福利| 亚洲福利精品电影在线观看| 久久精品女人天堂AV麻| 国产精品国产三级在线高清观看| 婷婷久久精品国产| 欧美成人精品高清在线播放| 精品多毛少妇人妻AV免费久久| 久久国产精品成人片免费| 中文字幕一精品亚洲无线一区| 老司机91精品网站在线观看| 成人午夜精品网站在线观看| 精品久久久久久亚洲精品| 无码国产精品一区二区免费16 | 午夜精品射精入后重之免费观看 | 亚洲精品自在在线观看| 精品午夜福利1000在线观看| 国产精品成人h片在线| 99爱在线视频这里只有精品| 国产精品亚洲а∨无码播放| 久久久久无码精品国产不卡| 精品午夜久久福利大片| 四虎精品影院永久在线播放|