傳統項目中的圖片管理
傳統項目中,可以在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/
2.3 啟動nginx
進入目錄:
cd /usr/local/nginx/sbin/啟動:
./nginx
查詢nginx進程:
ps aux|grep nginx
查看nginx狀態:
service nginx status
2.4 測試
nginx安裝成功,啟動nginx,即可訪問虛擬機上的nginx:
查看ip地址:ifconfig
訪問地址: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
如果修改了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文件:
重啟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;
}
修改完后需要重新啟動nginx
service nginx restart說明
root則是將images映射到/home/ftpuser/www/images/
確認 nginx 和 vsftpd 啟動成功后 可以試著上傳文件到/home/ftpuser/www/images/ 目錄下
打開瀏覽器訪問:http://172.20.10.7/images/bg1.jpg
完畢!
good luck !