前言:
在分布式架構中,往往會有多個tomcat赡若,然后你上傳的圖片只是在其中的某一個tomcat扣溺,你訪問時是由集群的tomcat隨機提供服務。當你訪問的tomcat是有圖片的那個時镐确,圖片能正常顯示包吝,如果恰巧是那個沒有圖片的tomcat時,圖片就不能正常顯示源葫。這就完成了訪問同一個圖片诗越,可能你刷新一次可以訪問,再刷新一次圖片就訪問不到了息堂。這時,我們就需要一個服務器用來專門存儲圖片,一般我們都用nginx她按。
歡迎大家關注我的公眾號 javawebkf医舆,目前正在慢慢地將簡書文章搬到公眾號,以后簡書和公眾號文章將同步更新振坚,且簡書上的付費文章在公眾號上將免費薇搁。
簡介:
1、nginx:
Nginx是一款輕量級的Web 服務器/反向代理服務器及電子郵件(IMAP/POP3)代理服務器渡八,并在一個BSD-like 協(xié)議下發(fā)行啃洋。其特點是占有內存少,并發(fā)能力強屎鳍,事實上nginx的并發(fā)能力確實在同類型的網(wǎng)頁服務器中表現(xiàn)較好宏娄,中國大陸使用nginx網(wǎng)站用戶有:百度、京東逮壁、新浪孵坚、網(wǎng)易、騰訊窥淆、淘寶等十饥。以上是百度百科的介紹,我們目前只需要知道nginx是一個服務器就行了祖乳,類似于tomcat的服務器逗堵,只不過我們把它用來保存圖片。
2眷昆、vsftp:
VSFTP是一個基于GPL發(fā)布的類Unix系統(tǒng)上使用的FTP服務器軟件蜒秤,它有安全、高速亚斋、穩(wěn)定等特點作媚。我們暫且這樣理解:vsftp就是用來傳輸文件的一個服務,在linux系統(tǒng)中開啟vsftp服務帅刊,然后在windows中就可以通過linux系統(tǒng)的ip纸泡、vsftp服務的端口、vsftp的用戶名及密碼連接vsftp服務赖瞒,然后就可以方便的把windows中東西上傳到linux中女揭,也可以把linux中的東西下載到windows中蚤假。
3、nginx+vsftp:
上面分別介紹了nginx和vsftp吧兔,那么這兩個東西怎么組合起來用呢磷仰?怎么實現(xiàn)這個圖片服務器呢?我們知道境蔼,tomcat安裝好啟動后灶平,在瀏覽器輸入localhost:8080
,就會出現(xiàn)tomcat的歡迎頁箍土,nginx也一樣逢享。比如linux的ip是192.168.50.122
,那么啟動nginx后吴藻,在瀏覽器訪問這個地址也會出現(xiàn)nginx的歡迎頁瞒爬,其實是因為它有個默認的訪問頁面,完整的地址應該是192.168.50.122/index.html
调缨,那么我們就可以根據(jù)這個疮鲫,把它默認的訪問頁面改成我們上傳的圖片的保存路徑,比如上傳了一張pic.jpg圖片到linux的/home/ftpuser/images
中弦叶,如果我們把默認訪問頁面改成/home/ftpuser
俊犯,那么在瀏覽器中輸入192.168.50.122/images/pic.jpg
,就可以訪問到這張圖片了伤哺。下面就來介紹nginx燕侠、vsftp的安裝以及配置。
nginx的安裝:
1立莉、環(huán)境:
nginx是C語言開發(fā)绢彤,建議在linux上運行,本教程使用Centos 7作為安裝環(huán)境蜓耻。先要安裝如下東西:
①茫舶、gcc:
yum install gcc-c++
②、pcre:
yum install -y pcre pcre-devel
③刹淌、zlib:
yum install -y zlib zlib-devel
④饶氏、openssl:
yum install -y openssl openssl-devel
⑤、開啟防火墻端口:
我們把nginx和vsftp要用到的端口先開啟有勾,免得后面出錯:
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --zone=public --add-port=443/tcp --permanent
firewall-cmd --zone=public --add-port=22/tcp --permanent
firewall-cmd --zone=public --add-port=21/tcp --permanent
firewall-cmd --zone=public --add-port=30000-30999/tcp --permanent
將以上5條命令逐一執(zhí)行就行了疹启。
完成以上安裝和設置,就可以開始安裝nginx了蔼卡。
2喊崖、安裝nginx:
①、下載:
wget -c https://nginx.org/download/nginx-1.10.1.tar.gz
版本大家可以上官網(wǎng)看一下,把版本號改成自己想下的那個就行了荤懂。
②茁裙、解壓:
tar -zxvf nginx-1.10.1.tar.gz
cd nginx-1.10.1
③、設置編譯參數(shù):
./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 \
--http-scgi-temp-path=/var/temp/nginx/scgi
直接把這段代碼貼到linux中執(zhí)行就行了势誊。
④呜达、編譯:
make
⑤谣蠢、安裝:
make install
⑥粟耻、啟動nginx:
cd /usr/local/nginx/sbin
./nginx
執(zhí)行這個命令后是沒有任何提示的,然后在瀏覽器中訪問虛擬機的ip眉踱,出現(xiàn)nginx歡迎頁則安裝成功挤忙。
⑦、關閉nginx:
在剛才的sbin目錄下執(zhí)行:
./nginx -s stop
遇到的坑:
第一次啟動nginx沒問題谈喳,如果重啟了一下虛擬機册烈,再次到nginx的sbin目錄下執(zhí)行./nginx
,出現(xiàn)下圖所示的錯誤:
解決辦法:
在run文件夾下創(chuàng)建一個nginx文件夾即可婿禽。
cd /var/run
mkdir nginx
創(chuàng)建nginx文件夾后成功啟動:
但是我發(fā)現(xiàn)每次重啟了虛擬機這個nginx文件夾都會被干掉赏僧,每次都要重新創(chuàng)建nginx文件夾才能啟動nginx,不知道是何原因扭倾。知道的老鐵們請賜教哦淀零!
vsftp的安裝:
1、安裝:
yum -y install vsftpd
2膛壹、添加ftp用戶:
useradd ftpuser
3驾中、給ftp用戶添加密碼:
passwd ftpuser
輸入兩次密碼后修改密碼。
4模聋、修改selinux:
①查看狀態(tài):
getsebool -a | grep ftp
執(zhí)行這個命令可以看到
allow_ftpd_full_access --> off
ftp_home_dir --> off
這兩個都off肩民,執(zhí)行如下命令設置為on:
[root@localhost ~]# setsebool -P ftpd_full_access on
[root@localhost ~]# setsebool -P ftp_home_dir on
再次執(zhí)行getsebool -a | grep ftp
看到那兩個狀態(tài)是on就行了。
5链方、關閉匿名訪問:
執(zhí)行
vim /etc/vsftpd/vsftpd.conf
命令:
還要在vsftp.conf文件最下面添加以下內容:
然后保存退出即可持痰。
6、設置開機啟動:
[root@localhost ~]# chkconfig vsftpd on
7祟蚀、測試:
打開filezilla工具工窍,輸入虛擬機的ip,21端口暂题,用戶名和密碼移剪,點擊快速連接,連接vsftp服務:
如圖所示則連接成功薪者。
配置nginx為圖片服務器:
按照以上步驟安裝好nginx和vsftp后纵苛,還是不能訪問上傳的圖片的,需要進行如下配置:
執(zhí)行
vim /usr/local/nginx/conf/ nginx.conf
命令,打開nginx的配置文件:
按道理這樣就可以了攻人,但是我訪問卻報錯:
403 forbidden取试,最后發(fā)現(xiàn)是因為ftpuser文件夾沒有可讀權限,執(zhí)行如下命令:
chmod -R 755 /home/ftpuser
再次訪問即可成功怀吻!
至此圖片服務器搭建完成瞬浓!至于在Java中如何使用這個圖片服務器,請參考Java實現(xiàn)把圖片上傳到圖片服務器蓬坡。
總結:
在搭建的過程中猿棉,遇到很多坑,因為我參考的教程是centos 6屑咳,防火墻是iptables萨赁,而centos 7是firewall,還有教程的不完整導致的各種問題兆龙,然后一步步的百度杖爽,終于解決。所以在此寫下這篇個人認為比較完整的筆記紫皇,供廣大猿友參考慰安,一起學習,共同進步聪铺!