久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

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

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

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

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

      缺點(diǎn):

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

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

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

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

      yum install gcc-c++

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

      yum install -y pcre pcre-devel

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

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

      yum install -y zlib zlib-devel

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

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

      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查詢?cè)敿?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

      注意:上邊將臨時(shí)文件目錄指定為/var/temp/nginx,需要在/var下創(chuàng)建temp及nginx目錄

      2.2、 編譯安裝

      make

      make  install

      安裝成功查看安裝目錄 :

      cd /usr/local/nginx/

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

      2.3 啟動(dòng)nginx
       

      進(jìn)入目錄:

      cd /usr/local/nginx/sbin/啟動(dòng):

      ./nginx

      查詢nginx進(jìn)程:

      ps aux|grep nginx

      查看nginx狀態(tài):

      service nginx status

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

      2.4 測(cè)試
      nginx安裝成功,啟動(dòng)nginx,即可訪問(wèn)虛擬機(jī)上的nginx:

      查看ip地址:ifconfig

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

      訪問(wèn)地址:http:172.20.10.7

      2.5 停止nginx
       

      方式1,快速停止:

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

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

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

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

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

      2.6 重啟nginx

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

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

      如下:

      ./nginx -s quit./nginx

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

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

      ./nginx -s reload2.7 開機(jī)自啟動(dòng)nginx

      2.7.1 編寫shell腳本
      這里使用的是編寫shell腳本的方式來(lái)處理

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

      這樣在控制臺(tái)就很容易的操作nginx了:查看Nginx當(dāng)前狀態(tài)、啟動(dòng)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,也可以使用上面的命令重新加載新的配置文件并運(yùn)行,可以將此命令加入到rc.local文件中,這樣開機(jī)的時(shí)候nginx就默認(rèn)啟動(dòng)了

      2.7.3 加入到rc.local文件中
       

      vi /etc/rc.local

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

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

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

      2 添加一個(gè)ftp用戶
      此用戶就是用來(lái)登錄ftp服務(wù)器用的。

      [root@bogon ~]# useradd ftpuser

      這樣一個(gè)用戶建完,可以用這個(gè)登錄,記得用普通登錄不要用匿名了。登錄后默認(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

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

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

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

      開啟防火墻: systemctl start firewalld

      禁止firewall開機(jī)啟動(dòng):  systemctl disable firewalld.service 

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

       
      5 修改selinux
       

      外網(wǎng)是可以訪問(wèn)上去了,可是發(fā)現(xiàn)沒(méi)法返回目錄(使用ftp的主動(dòng)模式,被動(dòng)模式還是無(wú)法訪問(wèn)),也上傳不了,因?yàn)閟elinux作怪了。

      修改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,代表,沒(méi)有開啟外網(wǎng)的訪問(wèn)

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

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

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

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

      重啟ftp服務(wù):

      [root@bogon ~]# service vsftpd restart

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

      ———————

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

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

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

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

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

      進(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ù)器

      修改完后需要重新啟動(dòng)nginx

      service nginx restart說(shuō)明

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

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

      打開瀏覽器訪問(wèn):http://172.20.10.7/images/bg1.jpg

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

      完畢!

      good luck !

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