通过配置tomcat虚拟路径配置站点的静态资源
我们常常站点中会提供给用户上传文件、图片、视频或者诸如为了提高性能生成的静态文件等存储在站点应用中。但如果静态资源文件和项目文件在同一个目录下,当我们重新部署文件时,war重新解压会导致静态资源文件的丢失。如果通过提前备份这些静态文件,一来添加了不少麻烦,而来随着上传的数据文件的增加,文件数和文件大小的增加,增加了部署的时间。那么如何解决这个问题?
通过编写bash脚本实现指定目录解压
由于我的服务器是linux服务器,应用服务器是tomcat。因此要使用bash脚本进行解压的,并规定哪些目录是可以替换的,哪些目录必须保留不能删除和覆盖。
在解压和覆盖之前先进行备份相关应用程序和资源文件。要想通过自定义的解压更新,必须关闭tomcat的自解压功能。在server.xml中不能设置该应用的context的节点属性 reloadable="true".以下是自解压脚本代码。假设站点名称为site
# site deploy script WEB_APP_DIR="/home/webapps/site"
WEB_DEPLOY_DIR="/home/deploy/site"
BACKUP_DIR="/home/backup/site"
WAR_FILENAME="site.war" #stop tomcat service
cd $TOMCAT_HOME/bin
./shutdown.sh mkdir $WEB_DEPLOY_DIR
#backup file
cp -R $WEB_APP_DIR $BACKUP_DIR/site_$(date -d today +%Y%m%d%H%M%S)
cp $WEB_APP_DIR/WEB-INF/classes/setup/applicationContext.xml $WEB_DEPLOY_DIR/applicationContext.xml #copy apps
cd $WEB_DEPLOY_DIR
cp /ftpupload/$WAR_FILENAME $WAR_FILENAME jar -xf $WAR_FILENAME rm -r $WEB_APP_DIR/WEB-INF
cp -R WEB-INF $WEB_APP_DIR rm -r $WEB_APP_DIR/ckeditor
cp -R ckeditor $WEB_APP_DIR rm -r $WEB_APP_DIR/css
cp -R css $WEB_APP_DIR rm -r $WEB_APP_DIR/js
cp -R js $WEB_APP_DIR rm -r $WEB_APP_DIR/images
cp -R images $WEB_APP_DIR rm -r $WEB_APP_DIR/META-INF
cp -R META-INF $WEB_APP_DIR rm -r $WEB_APP_DIR/about
cp -R about $WEB_APP_DIR rm -r $WEB_APP_DIR/ueditor
cp -R ueditor $WEB_APP_DIR rm -r $WEB_APP_DIR/upload
cp -R upload $WEB_APP_DIR cp index.jsp $WEB_APP_DIR #recover config file
cp applicationContext.xml $WEB_APP_DIR/WEB-INF/classes/setup/
echo $WEB_DEPLOY_DIR
#remove all deploy files
rm -rf $WEB_DEPLOY_DIR #start tomcat service
cd $TOMCAT_HOME/bin
./startup.sh
将以上内容保存为site_deploy.sh,并对该bash文件进行授权
chmod +x site_deploy.sh
通过给tomcat配置虚拟目录
假设站点名称为site,我们在server.xml中添加一个带有虚拟路径的site的站点配置
<Host name="site.com" appBase="/home/tomcat/webapps/" unpackWARs="true" autoDeploy="true" >
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="/home/logs/tomcat/site"
prefix="site." suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
<Context path="" docBase="/home/webapps/site" reloadable="true" crossContext="true"/>
<Context path="/html" docBase="/home/apache2/htdocs/site" reloadable="true" crossContext="true"/>
</Host>
- /home/webapps/site为站点主应用程序的部署路径。
- /html为站点的虚拟路径,/home/apache2/htdocs/site为静态资源存储绝对路径。
通过以上便可以解决上面所说的问题。应用程序的部署不影响到用户上传的数据文件以及程序生成的静态数据文件。
如果有通过apache部署负载均衡的,需要在httpd.conf设定虚拟路径的别名才能正常访问静态资源文件。
Alias /html /home/apache2/htdocs/moral
通过配置tomcat虚拟路径配置站点的静态资源的更多相关文章
- 【IDEA】IDEA中配置tomcat虚拟路径的两种方法
首先要确保使用的是本地的tomcat服务器,而不是maven插件. -------------------------第一种:使用IDEA工具自动配置(推荐这种)------------------- ...
- TOMCAT虚拟路径配置
在tomcat安装好后,只要把你的web项目copy到%TOMCAT_HOME%webapp下面就可以是使用啦!!其实还有种方法就是设定虚拟目录,即把项目的目录映射到tomcat中.这样做即可以不用重 ...
- 配置tomcat虚拟路径
这个问题其实很简单,首先找到你安装的tomcat的路径然后,在Tomcat6.0/conf/Catalina路径下创建localhost文件夹,如果有,就不用创建,然后在该文件夹下创建一个xml文件, ...
- Linux下设置Tomcat虚拟路径
问题描述:我在上传图片的位置不在Tomcat服务器下,用户无法访问 解决方案:配置Tomcat虚拟路径使用户可以访问图片 配置Tomcat # cd /usr/local/apache-tomcat- ...
- IDEA 设置 TOMCAT 虚拟路径
今天在使用 IDEA 配置 TOMCAT 虚拟路径时一直报错,最终解决方式整理如下: 一.使用 Tomcat 自己的虚拟路径 1.在 Tomcat9\conf 目录下找到 server.xml 文件, ...
- IDEA 启动项目,tomcat中配置的虚拟路径无法使用
有时候,使用idea启动项目,非动静分离项目,直接根据图片url地址显示图片,会发现图片无法显示,tomcat中配置的虚拟路径无法使用,这时候需要配置idea.选择路径,然后给与一个访问名就行了.
- 关于tomcat配置了虚拟路径,但是在Idea中无法生效的问题
1. 确认 tomcat 的server.xml 文件中配置的虚拟路径是否正确 其中,path表示访问的虚拟路径,docBase表示真实路径 2. Idea 服务器配置中是否勾选 “Deploy ap ...
- Tomcat虚拟目录配置方法及原理
tomcat 安装好之后,只需要把你的程序包放到$Tomcat_Home$/webapps下就可以直接使用了.这样会使webapps越来越大就需要设置虚拟目录: 1.单个应用设置: 在<Host ...
- 配置Tomcat监听80端口 配置Tomcat虚拟主机 Tomcat日志
配置Tomcat监听80端口 • vim /usr/local/tomcat/conf/server.xml Connector port=" protocol="HTTP/1.1 ...
随机推荐
- BZOJ2351: [BeiJing2011]Matrix
2351: [BeiJing2011]Matrix Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 589 Solved: 171[Submit][S ...
- [LOJ 1008] Fibsieve`s Fantabulous Birthday
A - Fibsieve`s Fantabulous Birthday Time Limit:500MS Memory Limit:32768KB 64bit IO Format:%l ...
- poj 1184 广搜进阶题
起初的想法果然就是一个6000000的状态的表示. 但是后面觉得还是太过于幼稚了. 可以看看网上的解释,其实就是先转换位置,然后再改变数字的大小. #include<iostream> # ...
- 期待已久的2012年度最佳jQuery插件揭晓
近日,国外著名博客WDL发布了2012年度最佳 jQuery 插件.jQuery 自2006年发布以来,经过6年的迅速发展,目前已是最流行和使用最广泛的 JavaScript 框架,这主要归功于众多围 ...
- 《转》如何让你的网页加载时间降低到 1s 内
当初分析了定宽高值和定宽高比这两种常见的图片延迟加载场景,也介绍了他们的应对方案,还做了一点技术选型的工作. 经过一段时间的项目实践,在先前方案的基础上又做了很多深入的优化工作.最终将好奇心日报的网页 ...
- zookeeper实现分布锁
分布式锁服务在大家的项目中或许用的不多,因为大家都把排他放在数据库那一层来挡.当大量的行锁.表锁.事务充斥着数据库的时候.一般web应用很多的瓶颈都在数据库上,这里给大家介绍的是减轻数据库锁负担的一种 ...
- 多线程归并排序的实现 java
多线程是非常适合归并排序的,因为归并排序是分治法,所以分割后可以独立运行,最后将结果归并起来就行了.如何写一个多线程程序呢?今天无聊,总结一下啊. 首先写个普通的归并排序,以后的多线程就调用这个排序. ...
- [九度OJ]1431.Sort(寻找前m大数并排序)
原题链接:http://ac.jobdu.com/problem.php?pid=1431 题目描述: 给你n个整数,请按从大到小的顺序输出其中前m大的数. 输入: 每组测试数据有两行,第一行有两个数 ...
- HOG特征
HOG(Histogram of gradient)统计图像局部区域的梯度方向信息来作为该局部图像区域的表征.HOG特征具有以下几个特点: (1)不具有旋转不变性(较大的方向变化),实际应用中不变性是 ...
- vmware虚拟机下ubuntu 13.04使用zeranoe脚本交叉编译ffmpeg
2013-07-01今天是建党节,习总书记指出,党的建设要以“照镜子.正衣冠.洗洗澡.治治病”为总要求.希望我们的党越来越纯洁,为人民谋福利.言归正传,每次项目中需要编译相应的ffmpeg,都很费时费 ...