linux下简洁优化部署tomcat应用
本文来自我的github pages博客http://galengao.github.io/ 即www.gaohuirong.cn
摘要:
- 本文是自己根据公司架构部署tomcat方法整理出来的文本
修改系统内核
修改linux的一些系统参数,以优化系统性能
- 修改LIMITS.CONF
$ vi /etc/security/limits.conf
# 增加
* soft nofile
* hard nofile
- 修改SYSCTL.CONF
# 备份
$ mv /etc/sysctl.conf /etc/sysctl.conf.bak $ vi /etc/sysctl.conf
# 插入
net.ipv4.ip_forward =
net.ipv4.conf.default.rp_filter =
net.ipv4.conf.default.accept_source_route =
kernel.sysrq =
kernel.core_uses_pid =
net.ipv4.tcp_syncookies =
kernel.msgmnb =
kernel.msgmax =
kernel.shmmax =
kernel.shmall =
net.ipv4.tcp_max_tw_buckets =
net.ipv4.tcp_sack =
net.ipv4.tcp_window_scaling =
net.ipv4.tcp_rmem =
net.ipv4.tcp_wmem =
net.core.wmem_default =
net.core.rmem_default =
net.core.rmem_max =
net.core.wmem_max =
net.core.netdev_max_backlog =
net.core.somaxconn =
net.ipv4.tcp_max_orphans =
net.ipv4.tcp_max_syn_backlog =
net.ipv4.tcp_timestamps =
net.ipv4.tcp_synack_retries =
net.ipv4.tcp_syn_retries =
net.ipv4.tcp_tw_recycle =
net.ipv4.tcp_tw_reuse =
net.ipv4.tcp_mem =
net.ipv4.tcp_fin_timeout =
net.ipv4.tcp_keepalive_time =
net.ipv4.ip_local_port_range =
安装APR
- 下载apr-1.5.2.tar.gz和apr-util-1.5.4.tar.gz
安装apr,方便tomcat 开启aoi
apr下载地址
$ tar -zxvf apr-1.5..tar.gz
$ tar -zxvf apr-util-1.5..tar.gz
$ yum install gcc gcc-c++ autoconf libtool # apr安装
$ cd apr-1.5.
$ ./configure --prefix=/usr/local/apr
# --prefix=/usr/local/apr指apr的安装路径,以下要用到
$ make
$ make install # apr-util安装
$ cd apr-util-1.5.
$ ./configure --with-apr=/usr/local/apr
# --with-apr=/usr/local/apr 指定APR安装路径
$ make
$ make install
安装JDK1.7
下载jdk-7u76-linux-x64.tar.gz 拷贝到/usr/local下面
cd /usr/local
$ tar -zxvf jdk-7u76-linux-x64.tar.gz # mv 重命名 为jdk1..0_76
mv jdk1..0_76 jdk1. # 在环境变量/etc/profile里配置JAVA_HOME
JAVA_HOME=/usr/local/jdk1.
PATH=$PATH:$HOME/bin:$JAVA_HOME/bin
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export JAVA_HOME PATH CLASSPATH # 环境变量立即生效
$ source .bash_profile
编译安装tomcat
创建DATA目录
$ mkdir /data
复制TOMCAT到目标目录并解压
$ cp apache-tomcat-7.0..tar.gz /data
$ tar -zxvf apache-tomcat-7.0..tar.gz
# mv 重命名为你所需的项目名称,如zhnx
$ mv apache-tomcat-7.0. zhnx
进入TOMCAT精简目录
请参照下面步骤一步一步顺序操作
$ cd zhnx # 把项目除了bin lib conf目录的其它全部删除
$ rm -rf LICENSE logs NOTICE RELEASE-NOTES RUNNING.txt temp/webapps/work/ # 在同目录新建三个文件夹domain、server、sbin
$ mkdir domain
$ mkdir server
$ mkdir sbin # 把bin 和lib目录移动到server下面
$ mv bin/ server/
$ mv lib/ server/ # 把conf目录移动到domain下面
$ mv conf/ domain/ # 安装tomcat native 开启aio
# 进入server/bin目录下安装tomcat native 与apr连起来 开启tomcat aio模式
$ cd server/bin # 解压 tomcat native
$ tar -zxvf tomcat-native.tar.gz # 进入安装tomcat native目录
$ cd tomcat-native-1.1.-src
$ cd jni
$ cd native # 执行命令
$ ./configure --with-apr=/usr/local/apr --with-java-home=/usr/local/jdk1..0_76
$ make
$ make install # 创建项目目录(这里项目名称示例CENTER)
$ cd /data/zhnx/domain
$ mkdir center # 把conf目录移动到项目下
$ mv conf/ center/
拷贝并修改脚本启动参数
- 到目录/data/zhnx/sbin 下新建三个脚本,这里与center项目为例:startcenter.sh、stopcenter.sh和super.sh
$ cd /data/zhnx/sbin
# 脚本一
$ vi startcenter.sh
#!/bin/bash # 下面需要修改的地方
# 、HOME=/data/zhnx根据自己建的目录
export HOME=/data/zhnx
export DOMAIN_HOME=${HOME}/domain
export LOG_HOME=${HOME}/logs
export TOMCAT_HOME=${HOME}/server #Variable settings begin
# 下面需要修改的地方
# 、export projectName=center 服务名称,即war包名称
# 、export httpPort= 启动接收请求端口端口
# 、export serverPort= tomcat启动的本地端口
export projectName=center
export httpPort=
export serverPort=
export minMsMem=3200m
export maxMsMem=3200m
export ssMem=300k
export mnMem=1100m
export survivorRatior=
export minPermSize=250m
export maxPermSize=300m
export threshold=
export fraction=
export pageSize=128m
export warFile=${HOME}/center_webapps # 服务名加webapps war包地址
export logFile=${LOG_HOME}/${projectName}/catalina.$(date +'%Y-%m-%d').out
export pidFile=${LOG_HOME}/${projectName}.pid
export LD_LIBRARY_PATH=/usr/local/apr/lib
export heapDumpPath=${DOMAIN_HOME}/${projectName}/heapDump
#Variable settings end #JVM args settings begin
# 下面需要修改的地方:
# 、Dtjtag=center服务名称
CATALINA_OPTS="-server -Dtjtag=center -Dtomcat.server.port=${serverPort} -Dtomcat.http.port=${httpPort} -Dtomcat.deploy.home=${warFile}"
CATALINA_OPTS="${CATALINA_OPTS} -Xms${minMsMem} -Xmx${maxMsMem} -Xss${ssMem} -Xmn${mnMem} -XX:SurvivorRatio=${survivorRatior} -XX:PermSize=${minPermSize} -XX:MaxPermSize=${maxPermSize}"
CATALINA_OPTS="${CATALINA_OPTS} -XX:+UseCompressedOops -XX:+TieredCompilation -XX:+AggressiveOpts -XX:+UseBiasedLocking"
CATALINA_OPTS="${CATALINA_OPTS} -XX:+DisableExplicitGC -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -Xnoclassgc -XX:MaxTenuringThreshold=${threshold} -XX:CMSInitiatingOccupancyFraction=${fraction} -XX:LargePageSizeInBytes=${pageSize} -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${heapDumpPath}"
#JVM args settings end export CATALINA_BASE=${DOMAIN_HOME}/${projectName}
export CATALINA_OPTS
export CATALINA_OUT="${logFile}"
export CATALINA_PID="${pidFile}"
export CATALINA_OPTS
${TOMCAT_HOME}/bin/catalina.sh start exit $?
$ cd /data/zhnx/sbin
# 脚本二
$ vi stopcenter.sh #!/bin/bash # 下面需要修改的地方
# 、HOME=/data/zhnx根据自己建的目录
# 、JAVA_HOME=/usr/local/jdk1. 根据自己JDK的路劲
export HOME=/data/zhnx
export JAVA_HOME=/usr/local/jdk1.
export DOMAIN_HOME=${HOME}/domain
export LOG_HOME=${HOME}/logs
export TOMCAT_HOME=${HOME}/server
export CLASSPATH=.:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
export PATH=${JAVA_HOME}/bin:${PATH} #Variable settings begin
# 下面需要修改的地方
# 、export projectName=center 项目名称,即war包名称
# 、export serverPort= tomcat本地启动端口,以上面对应
export projectName=center
export serverPort=
#Variable settings end export JAVA_OPTS="-Dtomcat.server.port=${serverPort}"
export CATALINA_PID="${LOG_HOME}/${projectName}.pid"
export CATALINA_BASE=${DOMAIN_HOME}/${projectName}
${TOMCAT_HOME}/bin/catalina.sh stop -force
exit $?
$ cd /data/zhnx/sbin
# 脚本三
vi super.sh checkProcess(){
pid=`ps -ef|grep ${classname}|grep -v 'grep'|awk '{print $2}'`
if [ "X${pid}" != "X" ]; then
return
else
return
fi
} printStartStatus(){
checkProcess
if [ $? -eq ]; then
echo "${_moduleName} start sucessful. [OK]"
return
else
echo "${_moduleName} start Failed. [Failed]"
return
fi
} startProcess(){
echo $
checkProcess
if [ $? -eq ]; then
echo "${_moduleName} had started."
return
else
${start}
sleep
printStartStatus
fi
} stopProcess(){
echo $
checkProcess
if [ $? -eq ]; then
echo "${_moduleName} not running. [FAILED]"
else
pid=`ps -ef|grep ${classname}|grep -v 'grep'|awk '{print $2}'`
if [ "X${pid}" = "X" ]; then
echo "${_moduleName} had stop. [OK]"
else
kill - $pid
echo "${_moduleName} stop sucessful. [OK]"
fi
fi
} restartProcess(){
stopProcess $
startProcess $
} getProcessStatus(){
checkProcess
if [ $? -eq ]; then
echo "${_moduleName} is running."
return
else
echo "${_moduleName} is not running."
return
fi
} unstall(){
checkProcess
if [ $? -eq ]; then
pid=`ps -ef|grep ${classname}|grep -v 'grep'|awk '{print $2}'`
if [ "X${pid}" != "X" ]; then
kill - $pid
fi
fi
${remove}
} commandError(){
echo ""
echo "ERROR:UNKNOWN COMMAND:\"$_command\" "
exit
}
- 到目录/etc/rc.d/init.d/下新建一个脚本,这里与center项目为例:center
$ cd /etc/rc.d/init.d/
# 脚本四
$ vi center #!/bin/sh # 下面需要修改的地方
# 、classname="tjtag=center" center服务名称
# 、_moduleName="center" modul名称
# 、start="/data/zhnx/sbin/startcenter.sh" 上面新建的脚本
# 、. /data/zhnx/sbin/super.sh 上面新建的脚本
classname="tjtag=center"
_command=$
_moduleName="center"
start="/data/zhnx/sbin/startcenter.sh"
. /data/zhnx/sbin/super.sh
case $_command in
start)
startProcess "Starting ${_moduldName}:"
;;
stop)
stopProcess "Stoping ${_moduldName}:"
;;
restart)
restartProcess "Stoping ${_moduldName}:" "Starting ${_moduldName}:"
;;
status)
getProcessStatus
;;
*)
commandError
;;
esac
删除原始的并替换修改过的SERVER.XML
$ cd /data/zhnx/domain/center/conf
$ rm -rf server.xml vi server.xml <?xml version='1.0' encoding='utf-8'?>
<Server port="${tomcat.server.port}" shutdown="SHUTDOWN">
<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="off" />
<Listener className="org.apache.catalina.core.JasperListener" />
<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
<Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> <GlobalNamingResources>
<Resource name="UserDatabase" auth="Container"
type="org.apache.catalina.UserDatabase"
description="User database that can be updated and saved"
factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
pathname="conf/tomcat-users.xml" />
</GlobalNamingResources> <Service name="Catalina"> <Connector URIEncoding="UTF-8" minSpareThreads="" maxSpareThreads="" enableLookups="false" disableUploadTimeout="true" acceptCount="" maxThreads="" maxProcessors="" minProcessors="" useURIValidationHack="false" compression="on" compressionMinSize="" compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" protocol="org.apache.coyote.http11.Http11AprProtocol" port="${tomcat.http.port}" connectionTimeout=""/> <Engine name="Catalina" defaultHost="localhost"> <Realm className="org.apache.catalina.realm.LockOutRealm">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>
</Realm> <Host name="localhost" appBase="${tomcat.deploy.home}" unpackWARs="true" autoDeploy="false">
<Context path="" docBase="sso" sessionCookiePath="/" sessionCookieDomain=".qasite.com" useHttpOnly="true" crossContext="true" debug="" reloadable="false">
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:192.168.10.11:11220" sticky="false" lockingMode="auto"
sessionBackupAsync="false" sessionBackupTimeout=""
transcoderFactoryClass="de.javakaffee.web.msm.JavaSerializationTranscoderFactory" />
</Context>
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
prefix="localhost_access_log." suffix=".txt"
pattern="%h %l %u %t "%r" %s %b" />
</Host>
</Engine>
</Service>
</Server>
若有自己需要增加的jar就拷进去
$ cd /data/zhnx/server/lib 把jar考进去
项目部署
新建目录webapp名称与startcenter.sh里的webapps名称一样
日志名称与服务名一样
$ mkdir -p /data/zhnx/center_webapps
$ mkdir -p /data/zhnx/logs/center
center.war 部署至 center_webapps
部署时需将对应webapps目录下的文件及文件夹清空;
然后把项目war包拷入对应webapps目录下
启动服务
service center start
linux下简洁优化部署tomcat应用的更多相关文章
- linux下实现自动部署tomcat的脚本
linux下实现自动部署tomcat的脚本 由于经常部署war到tomccat上,经常有一些重复的工作要做:停服务.备份war包.上传新的war包.启动服务.索性就写了一个自动部署的脚本. 脚本如下a ...
- linux下jvm优化、tomcat调优
系统环境:jdk1.8,apache-tomcat-8.5.35 一.jvm优化 进入 bin/catalina.sh,修改JAVA_OPTS配置: JAVA_OPTS="-server - ...
- Linux 下启动两个tomcat
Linux 下启动两个tomcat 闲来无事学习nginx,想要配置个load balance.可是先决条件是:得有两个web容器.两个电脑是不用想了.只能想办法在一个机器上启动两个tomcat.原以 ...
- 在linux下安装并操作tomcat
1.安装tomcat1).下载tomcat从官网http://tomcat.apache.org/下载tomcat,保存在/home目录下.root@ubuntu:/home/ubuntu/Downl ...
- MongoDB在Linux下常用优化设置
MongoDB在Linux下常用优化设置 以下是一些MongoDB推荐的常用优化设置.在生产环境下选取合适的参数值,例如预读值和默认文件描述符数目等,会对系统性能有很大的影响. 1.关闭数据库文件的 ...
- Linux下配置多个tomcat多个域名
Linux下配置多个tomcat多个域名复制tomcat:mkdir /home/server/testcp -rf /home/server/shichuan/* /home/server/test ...
- Linux下Apache服务部署静态网站------网站服务程序
文章链接(我的CSDN博客): Linux下Apache服务部署静态网站------网站服务程序
- Linux下使用JDK11部署Nacos启动报错:Could not find or load main class
Linux下使用JDK11部署Nacos 错误日志 /nacos/jdk-11.0.12/bin/java -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize ...
- linux下打开、关闭tomcat,实时查看tomcat运行日志
启动:一般是执行sh tomcat/bin/startup.sh 停止:一般是执行sh tomcat/bin/shutdown.sh脚本命令 查看:执行ps -ef |grep tomcat 输出如下 ...
随机推荐
- [机器学习]模型评价参数,准确率,召回率,F1-score
很久很久以前,我还是有个建筑梦的大二少年,有一天,讲图的老师看了眼我的设计图,说:"我觉得你这个设计做得很紧张".当时我就崩溃,对紧张不紧张这样的评价标准理解无能.多年后我终于明白 ...
- 单独编译IMX6Q的VPU示例程序:mxc_vpu_test.out
mxc_vpu_test.out是飞思卡尔为IMX6Q编写的VPU示例程序,有编解码和简单的网络传输功能. 首先从/opt/freescale/pkgs/中提取出imx-test-3.0.35-4.1 ...
- mysql alter总结
mysql alter总结(转载) 1:删除列 ALTER TABLE [表名字] DROP [列名称] 2:增加列 ALTER TABLE [表名字] ADD [列名称] INT NOT NULL ...
- Hibernate 的原生 SQL 查询
Hibernate除了支持HQL查询外,还支持原生SQL查询. 对原生SQL查询执行的控制是通过SQLQuery接口进行的,通过执行Session.createSQLQuery()获取 ...
- rsync学习笔记
转载地址:http://www.cnblogs.com/maxincai/p/5142245.html rsync同步工具 1.rsync介绍 rsync是一款开源的.快速的.多功能的.可实现全量及增 ...
- CSS选择器的新用法
前面的话 现在,预处理器(如sass)似乎已经成为开发CSS的标配,正如几年前jQuery是开发JS的标配一样.JS的querySelector借鉴了jQuery的选择器思想,CSS选择器也借鉴了预处 ...
- 【转】linux grep命令
1.作用 Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来 2.格式 grep [options] 3.主要参数 [options]主要参数: - ...
- 搭建yum仓库与定制rpm包
笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 当我们自动化部署集群的时候,想要快速的安装所有服务,搭建yum仓库与定制rpm包是我们首先要做的 原创作品,转载请 ...
- tf.train.shuffle_batch函数解析
tf.train.shuffle_batch (tensor_list, batch_size, capacity, min_after_dequeue, num_threads=1, seed=No ...
- input里面placeholder水平居中
<style type="text/css">input::-ms-input-placeholder{text-align: center;}input::-webk ...