這篇文章主要介紹“怎么使用nginx+tomcat實(shí)現(xiàn)靜態(tài)和動(dòng)態(tài)頁面的分離”,在日常操作中,相信很多人在怎么使用nginx+tomcat實(shí)現(xiàn)靜態(tài)和動(dòng)態(tài)頁面的分離問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對(duì)大家解答”怎么使用nginx+tomcat實(shí)現(xiàn)靜態(tài)和動(dòng)態(tài)頁面的分離”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
天鎮(zhèn)網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),天鎮(zhèn)網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為天鎮(zhèn)上千多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請(qǐng)找那個(gè)售后服務(wù)好的天鎮(zhèn)做網(wǎng)站的公司定做!
實(shí)驗(yàn)環(huán)境:windows
實(shí)驗(yàn)工具:nginx、tomcat
windows下安裝nginx非常簡單,去官網(wǎng)下載壓縮包解壓后并且雙擊解壓目錄下的nginx.exe程序即可。然后在瀏覽器輸入localhost可出現(xiàn)下圖,即表示nginx已經(jīng)在工作。
nginx的工作流程是:對(duì)外,nginx是一個(gè)服務(wù)器,所有的請(qǐng)求都先請(qǐng)求到nginx,然后再由nginx對(duì)內(nèi)網(wǎng)進(jìn)行請(qǐng)求的分發(fā)到tomcat,然后tomcat處理完請(qǐng)求后將數(shù)據(jù)發(fā)送給nginx,然后由nginx發(fā)送給用戶,整個(gè)過程對(duì)用戶的感覺就是nginx在處理用戶請(qǐng)求。既然這樣子,nginx肯定需要進(jìn)行配置,主要的配置文件是conf文件夾下的nginx.conf,因?yàn)槲抑饕沁M(jìn)行了靜態(tài)與動(dòng)態(tài)分離,所以沒有進(jìn)行靜態(tài)文件緩存,也沒有進(jìn)行負(fù)載均衡的配置。
#user nobody; worker_processes 2; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { #nginx默認(rèn)最大并發(fā)數(shù)是1024個(gè)用戶線程 worker_connections 1024; } http { include mime.types; default_type application/octet-stream; #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; #http1.1在請(qǐng)求完之后還會(huì)保留一段時(shí)間的連接,所以這里的timeout時(shí)長不能太大,也不能太小, #太小每次都要建立連接,太大會(huì)浪費(fèi)系統(tǒng)資源(用戶不再請(qǐng)求服務(wù)器) keepalive_timeout 65; #gzip on; server { #nginx監(jiān)聽80端口 listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; #這里的/表示所有的請(qǐng)求 #location / { #將80端口的所有請(qǐng)求都轉(zhuǎn)發(fā)到8080端口去處理,proxy_pass代表的是代理路徑 # proxy_pass http://localhost:8080; # root html; # index index.html index.htm; #} #對(duì)項(xiàng)目名進(jìn)行訪問就去訪問tomcat服務(wù) location /student_vote { proxy_pass http://localhost:8080; } #對(duì)jsp和do結(jié)尾的url也去訪問tomcat服務(wù) location ~ \.(jsp|do)$ { proxy_pass http://localhost:8080; } #對(duì)js、css、png、gif結(jié)尾的都去訪問根目錄下查找 location ~ \.(js|css|png|gif)$ { root f:/javaweb; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } # proxy the php scripts to apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the php scripts to fastcgi server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param script_filename /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} } # another virtual host using mix of ip-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # https server # #server { # listen 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:ssl:1m; # ssl_session_timeout 5m; # ssl_ciphers high:!anull:!md5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} }
上面的配置中我把默認(rèn)的location /給注釋掉了,因?yàn)樗鼤?huì)攔截所有的請(qǐng)求,無論是動(dòng)態(tài)還是靜態(tài),還有一個(gè)就是對(duì)靜態(tài)文件的配置我配置成了javaweb的工作區(qū)間,接下來會(huì)說明為什么。
因?yàn)橹皩懙捻?xiàng)目一直以來都是使用jsp內(nèi)置對(duì)象來進(jìn)行目錄的文件訪問,但是使用了nginx一切都需要改變,當(dāng)我使用了nginx,并且項(xiàng)目沒有進(jìn)行路徑的修改的時(shí)候,總是無法加載靜態(tài)文件,查看日志發(fā)現(xiàn)這樣的錯(cuò)誤:2016/05/20 18:27:30 [error] 6748#6936: *225 createfile() "f:/javaweb/student_vote/lib/images/username.png" failed (3: the system cannot find the path specified), client: 127.0.0.1, server: localhost, request: "get /student_vote/lib/images/username.png http/1.1", host: "localhost", referrer: "http://localhost/student_vote/index.jsp",大致信息是根據(jù)jsp中文件的配置,nginx將會(huì)從/stdent_vote(這是我的項(xiàng)目名)/lib/images包中查找靜態(tài)文件,而我又不想對(duì)項(xiàng)目文件做太大變化,其實(shí)還有一種方法是不使用jsp的內(nèi)置對(duì)象,直接使用http://localhost/username.png來代替內(nèi)置對(duì)象訪問靜態(tài)文件,但是這樣改要改很多的地方,所以我就直接將web-inf文件夾下的lib文件夾拷到上一個(gè)文件夾,也就是該文件夾和web-inf文件夾是兄弟文件夾的關(guān)系。
通過上述操作,就實(shí)現(xiàn)了動(dòng)態(tài)與靜態(tài)的分離了,無圖無真相,下面展示效果圖。
上圖可以看到server是“apache-coyote/1.1”。tomcat的連接器就是這個(gè)。
而上面的server可以看到是nginx,說明對(duì)外而言接收請(qǐng)求的服務(wù)器是nginx。
到此,關(guān)于“怎么使用nginx+tomcat實(shí)現(xiàn)靜態(tài)和動(dòng)態(tài)頁面的分離”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!