亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    傳統(tǒng)項目中的圖片管理

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

    優(yōu)點:引用方便,便于管理

    缺點:

    1、如果是分布式環(huán)境圖片引用會出現(xiàn)問題。

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

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

    安裝nginx需要先將官網(wǎng)下載的源碼進(jìn)行編譯,編譯依賴gcc環(huán)境,如果沒有g(shù)cc環(huán)境,需要安裝gcc:

    yum install gcc-c++

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

    yum install -y pcre pcre-devel

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

    zlib庫提供了很多種壓縮和解壓縮的方式,nginx使用zlib對http包的內(nèi)容進(jìn)行g(shù)zip,所以需要在linux上安裝zlib庫。

    yum install -y zlib zlib-devel

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

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

    yum install -y openssl openssl-devel

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

    解壓:

    tar -zxvf nginx-1.8.0.tar.gz進(jìn)入目錄:

    cd nginx-1.8.0

    2.1、 configure

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

    參數(shù)設(shè)置如下:

    ./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下創(chuàng)建temp及nginx目錄

    2.2、 編譯安裝

    make

    make  install

    安裝成功查看安裝目錄 :

    cd /usr/local/nginx/

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    2.3 啟動nginx
     

    進(jìn)入目錄:

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

    ./nginx

    查詢nginx進(jìn)程:

    ps aux|grep nginx

    查看nginx狀態(tài):

    service nginx status

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

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

    查看ip地址:ifconfig

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    訪問地址:http:172.20.10.7

    2.5 停止nginx
     

    方式1,快速停止:

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

    此方式相當(dāng)于先查出nginx進(jìn)程id再使用kill命令強制殺掉進(jìn)程。

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

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

    此方式停止步驟是待nginx進(jìn)程處理任務(wù)完畢進(jìn)行停止。

    2.6 重啟nginx

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

    對nginx進(jìn)行重啟相當(dāng)于先停止nginx再啟動nginx,即先執(zhí)行停止命令再執(zhí)行啟動命令。

    如下:

    ./nginx -s quit./nginx

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

    當(dāng)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 設(shè)置文件的訪問權(quán)限
    chmod a+x /etc/init.d/nginx  (a+x ==> all user can execute  所有用戶可執(zhí)行)

    這樣在控制臺就很容易的操作nginx了:查看Nginx當(dāng)前狀態(tài)、啟動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搭建圖片服務(wù)器

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

    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服務(wù)器用的。

    [root@bogon ~]# useradd ftpuser

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

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

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

    4 防火墻開啟21端口
    查看防火墻狀態(tài): 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

    關(guān)閉防火墻: systemctl stop firewalld.service   

    開啟防火墻: systemctl start firewalld

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

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

     
    5 修改selinux
     

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

    修改selinux:

    執(zhí)行以下命令查看狀態(tài):

    [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

    執(zhí)行上面命令,再返回的結(jié)果看到兩行都是off,代表,沒有開啟外網(wǎng)的訪問

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

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

    6 關(guān)閉匿名訪問
    修改/etc/vsftpd/vsftpd.conf文件:

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    重啟ftp服務(wù):

    [root@bogon ~]# service vsftpd restart

    查看狀態(tài):systemctl status vsftpd.service 

    ———————

    7 設(shè)置開機啟動vsftpd ftp服務(wù)
    [root@bogon ~]# chkconfig vsftpd on

    三、創(chuàng)建目錄
    mkdir /home/ftpuser/www/images/

    修改用戶訪問權(quán)限

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

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

    進(jìn)入目錄: cd /usr/local/nginx/con/

    編輯: vim nginx.conf

    location / {
      root /home/ftpuser/www;#定義服務(wù)器的默認(rèn)網(wǎng)站根目錄位置
      index index.html index.htm;
    }

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    修改完后需要重新啟動nginx

    service nginx restart說明

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

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

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

    Linux下使用Nginx+vsftpd搭建圖片服務(wù)器

    完畢!

    good luck !

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號