通过配置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 ...
随机推荐
- USACO3.23Spinning Wheels
直接枚举角度 数据比较水吧 /* ID: shangca2 LANG: C++ TASK: spin */ #include <iostream> #include<cstdio&g ...
- BZOJ_1005_ [HNOI2008]_明明的烦恼_(组合数学+purfer_sequence+高精度+分解因数+快速幂)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1005 一棵树有n个点,给出没给节点的度,如果没有限制则为-1,求共有多少种可能的树. 分析 蒟 ...
- 【转】OS X Mavericks: 防止 Mac 进入睡眠 -- 不错
原文网址:https://support.apple.com/kb/PH13808?locale=zh_CN&viewlocale=zh_CN 某些 Mac 电脑将在不活跃一段时间后自动进入睡 ...
- MVC3系列~Html.BeginForm与Ajax.BeginForm
Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...
- LinkedList源码解析
LinkedList是基于链表结构的一种List,在分析LinkedList源码前有必要对链表结构进行说明.1.链表的概念链表是由一系列非连续的节点组成的存储结构,简单分下类的话,链表又分为单向链表和 ...
- NESPER的大体结构 z
NEsper从内容上分为两块,NEsper的核心NEsper.dll和NEsper.IO.dll. (1)NEsper的核心包包含了EPL语法解析引擎,事件监听机制,事件处理等核心模块. (2)NEs ...
- [转]NHibernate之旅(11):探索多对多关系及其关联查询
本节内容 多对多关系引入 多对多映射关系 多对多关联查询 1.原生SQL关联查询 2.HQL关联查询 3.Criteria API关联查询 结语 多对多关系引入 让我们再次回顾在第二篇中建立的数据模型 ...
- [liu yanling]软件测试技巧
1.添加.修改功能 (1)是否支持tab键 (2)是否支持enter键 (3)不符合要求的地方是否有错误提示 (4)保存后,是否也插入到数据库中 (5)字段唯一的,是否可以重复添加 (6)对编辑页列表 ...
- [POJ2084]Game of Connections
Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 7888 Accepted: 3965 Description Thi ...
- HW2.14
import java.util.Scanner; public class Solution { public static void main(String[] args) { final dou ...