广州总部电话:020-85564311
广州总部电话:020-85564311

广州网站建设-小程序商城开发-广州小程序开发-企业微信开发公司-网站建设高端品牌-优网科技

19年
互联网应用服务商
请输入搜索关键词
如何提升网页访问速度,优网科技技术大牛教路:动静分离
发布日期:2017-09-22 09:11:26
浏览次数:1713

      当我们日常访问一个网站,如果能迅速地加载出来,浏览到想要的内容,这是网站的用户体验是否良好的一个重要标准,在网站建设当中,也会权衡考虑网站的加载速度来提升用户的浏览体验。网页的访问速度取决于硬件等外部因素,更重要的是网站建设过程中的网页设计、网页规划和技术的实现手段。今天,优网科技的技术大牛,就给大家说说网站建设网站搭建过程中,采用动静分离,能有效提高网页访问速度。

     那么问题来了,动静分离是什么?什么动态的?什么是静态的呢?访问网页的时候,我们总会发现浏览器会加载各种各样的文件,有html文件,有css样式表,有js脚本,还有图片,还有流媒体等各种文件,这些其实就是静态的文件,放在服务器上,无须动态生成的文件那么就是静态文件。那么什么是动态文件呢?例如java写的jsp文件,需要通过编译器进行编译成字节码文件,然后在java虚拟机上运行,运行之后,返回给客户端一个响应,有的时候,还需要到数据库中取出数据,那么这种需要经过编译的文件就称之为动态文件。

      动态文件的处理比静态文件的处理速度要慢N倍,慢在啥地方呢?首先,动态文件需要编译,耗费时间,动态文件要去连接数据库,耗费时间,动态文件需要组织成http响应,耗费时间,根据java的流程,那么就是根据url,找到jsp文件,将jsp文件转换成servlet文件,然后形成类文件,然后在jvm上运行,jvm可能还要加载额外的类文件,然后组成成响应返回给servlet,然后再返回给客户端。

      在使用动静分离的时候,一般使用的模型如下所示:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

       在使用动静分离的时候,需要将一些静态的文件和动态的文件分离开来,从而使用nginx来处理静态请求,而使用tomcat来处理动态的请求,从而会大大的提高处理速度,为啥?

       nginx和httpd是专门用来处理静态文件的,效率极高,并且由nginx直接响应,减少了向后端转发的过程;将动态内容和静态内容进行分离,可以提高资源利用率,nginx的性能得到发挥,也让tomcat不会那么繁忙,动态服务器机器耗费性能,例如在java中的各种方法区对象的回收,堆内存的回收等。

 

构建动静分离的环境

       要想构建动静分离的环境,那么就需要安装nginx,安装jdk,然后安装tomcat,具体的步骤如下:

编译安装nginx:

[root@mogilenode2 nginx-1.10.1]# ./configure –prefix=/usr/local/nginx –with-http_ssl_module –with-http_stub_status_module –with-pcre

[root@mogilenode2 nginx-1.10.1]# make && make install

[root@mogilenode2 ~]# /usr/local/nginx/sbin/nginx (启动nginx)

[root@mogilenode2 ~]# netstat -tnlp|grep nginx(查看监听端口,并且使用浏览器访问测试)

tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      13933/nginx

如何提升网页访问速度,优网科技技术大牛教路:动静分离

安装jdk:

[root@mogilenode3 server]# rpm -ivh jdk-8u144-linux-x64.rpm

Preparing…                ########################################### [100%]

1:jdk1.8.0_144           ########################################### [100%]

Unpacking JAR files…

tools.jar…

plugin.jar…

javaws.jar…

deploy.jar…

rt.jar…

jsse.jar…

charsets.jar…

localedata.jar…

 

配置java环境变量:

[root@mogilenode3 server]# echo “export JAVA_HOME=/usr/java/latest”>/etc/profile.d/java.sh

[root@mogilenode3 server]# echo “export PATH=$JAVA_HOME/bin:$PATH”>>/etc/profile.d/java.sh

[root@mogilenode3 server]# cat /etc/profile.d/java.sh

export JAVA_HOME=/usr/java/latest

export PATH=/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

测试jdk及环境变量是否成功:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

安装tomcat:

[root@mogilenode3 server]# tar -xf apache-tomcat-8.5.20.tar.gz -C /usr/local/

l[root@mogilenode3 server]# ln -sv /usr/local/apache-tomcat-8.5.20/ /usr/local/tomcat

`/usr/local/tomcat’ -> `/usr/local/apache-tomcat-8.5.20/’

 

配置tomcat环境变量:

[root@mogilenode3 local]# vim /etc/profile.d/tomcat.sh

[root@mogilenode3 local]# cat !$

cat /etc/profile.d/tomcat.sh

export CATALINA_HOME=/usr/local/tomcat

export PATH=$CATALINA_HOME/bin:$PATH

 

测试tomcat是否安装成功:

[root@mogilenode3 ~]# netstat -tnlp|grep java(注意浏览器访问的时候,添加端口号来进行访问)

tcp        0      0 :::8080                     :::*                        LISTEN      1125/java

tcp        0      0 ::ffff:127.0.0.1:8005       :::*                        LISTEN      1125/java

tcp        0      0 :::8009                     :::*                        LISTEN      1125/java

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

创建动态文件

根据java的目录层次结构,写一个基本的页面,如下:

[root@mogilenode3 webapps]# mkdir kel

[root@mogilenode3 webapps]# cd kel

[root@mogilenode3 kel]# ls -l

total 0

[root@mogilenode3 kel]# mkdir {META-INF,WEB-INF,classes,lib}

[root@mogilenode3 kel]# vim index.jsp

[root@mogilenode3 kel]# cat index.jsp

<%@ page language=”java” %>

<%@ page import=”java.util.*” %>

<html>

<head>

<title>JAVA PAGE</title>

</head>

<body>

<% out.println(“Hello,World”); %>

</body>

</html>

[root@mogilenode3 kel]# ls -l

total 20

drwxr-xr-x 2 root root 4096 Sep 20 14:46 classes

-rw-r–r– 1 root root  201 Sep 20 14:46 index.jsp

drwxr-xr-x 2 root root 4096 Sep 20 14:46 lib

drwxr-xr-x 2 root root 4096 Sep 20 14:46 META-INF

drwxr-xr-x 2 root root 4096 Sep 20 14:46 WEB-INF

 

修改tomcat的配置文件server.xml(添加一个虚拟主机,主机名为www.kel.com,,默认路径为webapps下面的kel目录):

<Host name=”www.kel.com” appBase=”webapps” unpackWARS=”true” autoDeploy=”true”>

<Context path=”” docBase=”kel” reloadable=”true” />

</Host>

测试访问:

[root@mogilenode3 conf]# grep “www.kel.com” /etc/hosts (设置主机名解析)

192.168.1.238 www.kel.com

[root@mogilenode3 conf]# curl http://www.kel.com:8080 (使用curl进行访问)

<html>

<head>

<title>JAVA PAGE</title>

</head>

<body>

Hello,World

</body>

</html>

 

配置nginx

配置主机名解析:

[root@mogilenode2 nginx]# grep “www.kel.com” /etc/hosts

192.168.1.237 www.kel.com

[root@mogilenode2 conf]# ls -l nginx.conf(修改nginx配置文件,将动态请求也就是文件后缀为jsp或者do的请求转发到tomcat上,由于是虚拟主机,所以url中必须写上主机名,静态页面在nginx上处理,静态页面在html路经下)

-rw-r–r– 1 root root 2727 Sep 20 15:09 nginx.conf

server_name  www.kel.com;

#charset koi8-r;

#access_log  logs/host.access.log  main;

location / {

root   html;

index  index.html index.htm;

}

location ~* \.(jsp|do)$ {

proxy_pass http://www.kel.com:8080;

}

 

上传静态文件到nginx的html目录中,用来测试静态文件的访问:

[root@mogilenode2 nginx]# ls -l html/1.jpg

-rw-r–r– 1 root root 25854 Sep 20 15:13 html/1.jpg

 

访问nginx服务器测试静态文件访问:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

访问nginx服务器,测试动态页面访问:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

总结:

       总体上来说,动静分离还是比较简单的,主要让前端的代理服务器直接响应静态请求,让前端的代理服务器转发动态请求到后端的tomcat服务器即可。注意上面的是实验环境,对于tomcat的运行的用户是直接的root用户,在生产中,必须修改为其他不能登录的用户,例如tomcat用户。

优网科技,优秀企业首选的互联网供应服务商

优网科技秉承"专业团队、品质服务" 的经营理念,诚信务实的服务了近万家客户,成为众多世界500强、集团和上市公司的长期合作伙伴!

优网科技成立于2001年,擅长网站建设、网站与各类业务系统深度整合,致力于提供完善的企业互联网解决方案。优网科技提供PC端网站建设(品牌展示型、官方门户型、营销商务型、电子商务型、信息门户型、DIY体验、720全景展厅及3D虚拟仿真)、移动端应用(手机站APP开发)、微信定制开发(微信官网、微信商城、企业微信)、微信小程序定制开发等一系列互联网应用服务。


责任编辑:优网科技

版权所有:http://www.uweb.net.cn (优网科技) 转载请注明出处

如何提升网页访问速度,优网科技技术大牛教路:动静分离

日期:2017-09-22 09:11:26 发布人:优网科技

      当我们日常访问一个网站,如果能迅速地加载出来,浏览到想要的内容,这是网站的用户体验是否良好的一个重要标准,在网站建设当中,也会权衡考虑网站的加载速度来提升用户的浏览体验。网页的访问速度取决于硬件等外部因素,更重要的是网站建设过程中的网页设计、网页规划和技术的实现手段。今天,优网科技的技术大牛,就给大家说说网站建设网站搭建过程中,采用动静分离,能有效提高网页访问速度。

     那么问题来了,动静分离是什么?什么动态的?什么是静态的呢?访问网页的时候,我们总会发现浏览器会加载各种各样的文件,有html文件,有css样式表,有js脚本,还有图片,还有流媒体等各种文件,这些其实就是静态的文件,放在服务器上,无须动态生成的文件那么就是静态文件。那么什么是动态文件呢?例如java写的jsp文件,需要通过编译器进行编译成字节码文件,然后在java虚拟机上运行,运行之后,返回给客户端一个响应,有的时候,还需要到数据库中取出数据,那么这种需要经过编译的文件就称之为动态文件。

      动态文件的处理比静态文件的处理速度要慢N倍,慢在啥地方呢?首先,动态文件需要编译,耗费时间,动态文件要去连接数据库,耗费时间,动态文件需要组织成http响应,耗费时间,根据java的流程,那么就是根据url,找到jsp文件,将jsp文件转换成servlet文件,然后形成类文件,然后在jvm上运行,jvm可能还要加载额外的类文件,然后组成成响应返回给servlet,然后再返回给客户端。

      在使用动静分离的时候,一般使用的模型如下所示:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

       在使用动静分离的时候,需要将一些静态的文件和动态的文件分离开来,从而使用nginx来处理静态请求,而使用tomcat来处理动态的请求,从而会大大的提高处理速度,为啥?

       nginx和httpd是专门用来处理静态文件的,效率极高,并且由nginx直接响应,减少了向后端转发的过程;将动态内容和静态内容进行分离,可以提高资源利用率,nginx的性能得到发挥,也让tomcat不会那么繁忙,动态服务器机器耗费性能,例如在java中的各种方法区对象的回收,堆内存的回收等。

 

构建动静分离的环境

       要想构建动静分离的环境,那么就需要安装nginx,安装jdk,然后安装tomcat,具体的步骤如下:

编译安装nginx:

[root@mogilenode2 nginx-1.10.1]# ./configure –prefix=/usr/local/nginx –with-http_ssl_module –with-http_stub_status_module –with-pcre

[root@mogilenode2 nginx-1.10.1]# make && make install

[root@mogilenode2 ~]# /usr/local/nginx/sbin/nginx (启动nginx)

[root@mogilenode2 ~]# netstat -tnlp|grep nginx(查看监听端口,并且使用浏览器访问测试)

tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      13933/nginx

如何提升网页访问速度,优网科技技术大牛教路:动静分离

安装jdk:

[root@mogilenode3 server]# rpm -ivh jdk-8u144-linux-x64.rpm

Preparing…                ########################################### [100%]

1:jdk1.8.0_144           ########################################### [100%]

Unpacking JAR files…

tools.jar…

plugin.jar…

javaws.jar…

deploy.jar…

rt.jar…

jsse.jar…

charsets.jar…

localedata.jar…

 

配置java环境变量:

[root@mogilenode3 server]# echo “export JAVA_HOME=/usr/java/latest”>/etc/profile.d/java.sh

[root@mogilenode3 server]# echo “export PATH=$JAVA_HOME/bin:$PATH”>>/etc/profile.d/java.sh

[root@mogilenode3 server]# cat /etc/profile.d/java.sh

export JAVA_HOME=/usr/java/latest

export PATH=/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

测试jdk及环境变量是否成功:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

安装tomcat:

[root@mogilenode3 server]# tar -xf apache-tomcat-8.5.20.tar.gz -C /usr/local/

l[root@mogilenode3 server]# ln -sv /usr/local/apache-tomcat-8.5.20/ /usr/local/tomcat

`/usr/local/tomcat’ -> `/usr/local/apache-tomcat-8.5.20/’

 

配置tomcat环境变量:

[root@mogilenode3 local]# vim /etc/profile.d/tomcat.sh

[root@mogilenode3 local]# cat !$

cat /etc/profile.d/tomcat.sh

export CATALINA_HOME=/usr/local/tomcat

export PATH=$CATALINA_HOME/bin:$PATH

 

测试tomcat是否安装成功:

[root@mogilenode3 ~]# netstat -tnlp|grep java(注意浏览器访问的时候,添加端口号来进行访问)

tcp        0      0 :::8080                     :::*                        LISTEN      1125/java

tcp        0      0 ::ffff:127.0.0.1:8005       :::*                        LISTEN      1125/java

tcp        0      0 :::8009                     :::*                        LISTEN      1125/java

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

创建动态文件

根据java的目录层次结构,写一个基本的页面,如下:

[root@mogilenode3 webapps]# mkdir kel

[root@mogilenode3 webapps]# cd kel

[root@mogilenode3 kel]# ls -l

total 0

[root@mogilenode3 kel]# mkdir {META-INF,WEB-INF,classes,lib}

[root@mogilenode3 kel]# vim index.jsp

[root@mogilenode3 kel]# cat index.jsp

<%@ page language=”java” %>

<%@ page import=”java.util.*” %>

<html>

<head>

<title>JAVA PAGE</title>

</head>

<body>

<% out.println(“Hello,World”); %>

</body>

</html>

[root@mogilenode3 kel]# ls -l

total 20

drwxr-xr-x 2 root root 4096 Sep 20 14:46 classes

-rw-r–r– 1 root root  201 Sep 20 14:46 index.jsp

drwxr-xr-x 2 root root 4096 Sep 20 14:46 lib

drwxr-xr-x 2 root root 4096 Sep 20 14:46 META-INF

drwxr-xr-x 2 root root 4096 Sep 20 14:46 WEB-INF

 

修改tomcat的配置文件server.xml(添加一个虚拟主机,主机名为www.kel.com,,默认路径为webapps下面的kel目录):

<Host name=”www.kel.com” appBase=”webapps” unpackWARS=”true” autoDeploy=”true”>

<Context path=”” docBase=”kel” reloadable=”true” />

</Host>

测试访问:

[root@mogilenode3 conf]# grep “www.kel.com” /etc/hosts (设置主机名解析)

192.168.1.238 www.kel.com

[root@mogilenode3 conf]# curl http://www.kel.com:8080 (使用curl进行访问)

<html>

<head>

<title>JAVA PAGE</title>

</head>

<body>

Hello,World

</body>

</html>

 

配置nginx

配置主机名解析:

[root@mogilenode2 nginx]# grep “www.kel.com” /etc/hosts

192.168.1.237 www.kel.com

[root@mogilenode2 conf]# ls -l nginx.conf(修改nginx配置文件,将动态请求也就是文件后缀为jsp或者do的请求转发到tomcat上,由于是虚拟主机,所以url中必须写上主机名,静态页面在nginx上处理,静态页面在html路经下)

-rw-r–r– 1 root root 2727 Sep 20 15:09 nginx.conf

server_name  www.kel.com;

#charset koi8-r;

#access_log  logs/host.access.log  main;

location / {

root   html;

index  index.html index.htm;

}

location ~* \.(jsp|do)$ {

proxy_pass http://www.kel.com:8080;

}

 

上传静态文件到nginx的html目录中,用来测试静态文件的访问:

[root@mogilenode2 nginx]# ls -l html/1.jpg

-rw-r–r– 1 root root 25854 Sep 20 15:13 html/1.jpg

 

访问nginx服务器测试静态文件访问:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

访问nginx服务器,测试动态页面访问:

如何提升网页访问速度,优网科技技术大牛教路:动静分离

 

总结:

       总体上来说,动静分离还是比较简单的,主要让前端的代理服务器直接响应静态请求,让前端的代理服务器转发动态请求到后端的tomcat服务器即可。注意上面的是实验环境,对于tomcat的运行的用户是直接的root用户,在生产中,必须修改为其他不能登录的用户,例如tomcat用户。

责任编辑:优网科技

版权所有:http://www.uweb.net.cn (优网科技) 转载请注明出处

上一篇 返回列表 下一篇
推荐案例
眼光高度决定品牌厚度 !
广州网站建设-大良实验小学系统开发
广州网站建设-大良实验小学系统开发
大良实验小学于1998年成立,占地4万5千多平方米,是顺德区规模的民办学校之一。现有71个教学班,学生3223人,教职员工436人。学校按广东省一级学校标准建设,配有图书馆、舞蹈室、管乐室、多媒体电子琴室、实验室、英语乐园等功能场室36个,还拥有大礼堂、羽毛球馆、生物园、地理园、游泳池和200米塑胶运动场等活动场所。学校先后荣获“广东省一级学校”、“全国少先队红旗大队”、“广东省首届优秀书香校园”、“广东省书法教育名校”、“广东省综合实践样本学校”等光荣称号。
广州网站建设-海天味业公众号开发
广州网站建设-海天味业公众号开发
海天是中国调味品行业的优秀企业,专业的调味品生产和营销企业,历史悠久,是中华人民共和国商务部公布的首批“中华老字号”企业之一。目前生产的产品涵盖酱油、蚝油、酱、醋、料酒、调味汁、鸡精、鸡粉、腐乳等几大系列百余品种300多规格,年产值过百亿元。
广州网站建设-中凯网站建设
广州网站建设-中凯网站建设
中凯(海南)控股集团有限公司本次项目是集团网站建设,与优网科技合作过程中,双方配合默契,保质保量的仅一个月就完成了整站建设。优网科技帮助中凯(海南)快速树立了一个集团专业形象展示,同时网站的设计效果、体验和交互也让中凯(海南)非常满意。
广州网站建设-中国联塑网站建设
广州网站建设-中国联塑网站建设
中国联塑集团控股有限公司(简称:中国联塑,股份代号:2128.HK )是国内大型建材家居产业集团,产品及服务涵盖管道产品、水暖卫浴、整体厨房、整体门窗、装饰板材、净水设备、消防器材、卫生材料、海洋养殖、环境保护、建材家居渠道与服务等领域。
广州网站建设-前海益广网站建设
广州网站建设-前海益广网站建设
深圳前海益广股权投资有限公司成立于2016年04月18日,注册地位于深圳市前海深港合作区前湾一路1号A栋201室,经营范围包括一般经营项目是:股权投资;受托管理股权投资基金;受托资产管理;企业管理咨询、经济信息咨询;投资兴办实业等。
广州网站建设-萨米特高端品牌网站建设
广州网站建设-萨米特高端品牌网站建设
佛山市萨米特陶瓷销售有限公司始于2000年,在陶瓷行业风潮中发展壮大,是新明珠陶瓷集团的核心品牌。萨米特瓷砖注重营销系统的升级与消费体验模式的实施,倡导“设计+生活”的品牌理念,致力于打造有温度,有态度的瓷砖品牌。用设计提高人居价值,以创新驱动行业发展,与全球不同国家和文化背景的消费者共享美好家居。
广州网站建设-欧迪克网站建设
广州网站建设-欧迪克网站建设
佛山市南海欧迪克五金制品有限公司始创于2003年,致力于发展高端硅镁铝合金安全门窗,木铝门窗、阳光房定制,集研发、生产、销售、服务于一体。自创立以来,系列产品畅销大江南北,获得由权威媒体及单位颁发的多项殊荣。目前为止,“欧迪克门窗”的专卖店遍布全国800多个县市及地区,共有1000多家专卖店辐射全国。
广州网站建设-好太太网站建设
广州网站建设-好太太网站建设
好太太集团是一家集研发、生产、销售、服务于一体的智能家居企业,产品与服务涵盖智能晾晒、智能锁、智能电器等众多领域。坐落于广州番禺区,自1999年始便致力于打造 “好太太”品牌,经过将近二十年的发展,如今好太太已成为全球的晾衣架行业研发、生产、销售、服务商,在中国拥有近2000万户家庭在使用好太太产品。好太太集团于2017年主板上市,成为智能晾晒领域首家A股上市企业。
广州网站建设-中山公用水务网站建设
广州网站建设-中山公用水务网站建设
中山公用事业集团股份有限公司成立于1998年,是一家国有控股的上市公司(SZ:000685)。公司坚持“产业经营+资本运营”双轮驱动的战略思路,定位环保水务为核心业务,通过提升环保水务板块的产业经营能力,与资本运营平台协同增效,致力打造行业内有影响力的领先企业,积极担当社会责任和环境保护的公民企业,促成员工实现自身价值的平台企业。
广州网站建设--华标集团物业公众号
广州网站建设--华标集团物业公众号
华标集团物业为了进一步提升服务质量,满足业主的多元化需求,采用微信公众号作为服务平台,为业主提供日常物业缴费、报事报修、社区活动等便利性服务。本次量身定制的微信公众号,旨在打造一个高效、稳定、便捷的线上服务平台,让业主享受到更加贴心、便捷的物业服务。
广州网站建设-欧派家居集团官网建设
广州网站建设-欧派家居集团官网建设
欧派集团官网作为欧派对外展现品牌形象、传达服务理念的重要信息平台,也向用户展示了欧派最新的资讯和相关的售后服务。优网作为欧派集团的信息化战略合作伙伴,本次的官网开发基于专业的设计水平和扎实的技术能力,为欧派的互联网品牌形象全面升级。
广州网站建设-康臣药业网站建设
广州网站建设-康臣药业网站建设
康臣药业集团(HK.01681)是一家主要从事现代中成药及医用成像对比剂研发、生产及营销的现代化制药企业,创立于1997年,于2013年12月19日在香港联合交易所主板上市,旗下拥有广州康臣药业有限公司、康臣药业(内蒙古)有限责任公司、广西玉林制药集团有限责任公司、广州康臣药物研究有限公司等从事药品生产和研发的企业,运营康臣、玉林等知名医药品牌,在国内建有广东广州、内蒙古通辽、广西玉林等3个生产基地,员工逾2000人。

我要投稿

姓名

文章链接

提交即表示你已阅读并同意《个人信息保护声明》

专属顾问 专属顾问
扫码咨询您的优网专属顾问!
专属顾问
马上咨询
扫一扫马上咨询
扫一扫马上咨询

扫一扫马上咨询

展开菜单
关于我们
优网观点
项目动态
公司新闻
优网学院
常见问题
收起菜单
活动会议应用
答题应用
班车预定应用
应急值班表应用
春节活动应用
活动直播应用
内部培训及任务应用
返回上一级