-
1.修改Tomcat端口号
在server.xml文件里面修改
2.配置端口号:
端口范围:1~65535,一般在1024~65535之间取值。因为前1~1024大部分都被固定分配了。
3.server.xml中的三个端口:
(1)shutdown端口:端口为8005,负责监听关闭tomcat的请求;
(2)http端口:负责建立http请求;默认端口为8080
(3)AJP协议端口:端口为8009,负责与其他的http服务器建立连接,把tomcat与其他的http服务器集成。
查看全部 -
1.什么是热部署?
就是在不重新启动Tomcat服务器的条件下,将自己的项目部署到Tomcat服务器中。
2.如何配置热部署?---------三种方式
直接将自己的web文件放入webapps文件夹中。
conf/server.xml <host>标签中中添加context标签:
<Context debug="0" docBase="D:\demo1\web" path="/demo1" reloadable="true" />
-----debug越大,程序发生异常时,写入日志文件的详细程度越大,默认为0
------docBase 项目的绝对路径或者相对路径(相对webapps)
------path 项目的访问方式
-------reloadable 如果为true 自动加载新增或者改变的class文件
在conf/catalina下面的localhost中添加一个xml文件
新建一个demo2.xml文件,粘贴配置信息:
<?xml version="1.0" encoding="UTF-8"?>
<Context debug="0" docBase="D:\demo1\web" path="/demo1" reloadable="true" />
这时候demo2作为访问项目的名称,path不起作用。
查看全部 -
catalina中设置(E:\tomcats\tomcat-8\bin\catalina.bat第二行加入以下代码)
JAVA_OPTS="-server -Xms=256m -Xmx512m -XX:metaspace=128m -XX:MaxMetaspaceSize=256m"查看全部 -
单点登录(Single Sign On),简称SSO,是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。
单点登录方式:
(1)以Cookie作为凭证媒介;
(2)通过jsop实现;
(3)通过页面重定向的方式实现;
(4)使用第三方插件实现,如CAS
CAS:开源的企业级单点登录解决方案。
查看全部 -
1.什么是连接池?
准备一个空间,专门存放数据库连接,用户使用时直接从空间中取走连接,关闭时将连接放回空间中。这个空间就被称为连接池。
在程序初始化的时候,集中创建多个数据库连接,并且集中管理,供程序去使用。
不仅可以保证数据库的读写速度,而且更加安全可靠。
连接池提高了性能,也提高了安全性。
2.JDBC操作数据库
加载驱动>创建链接>执行SQL>(关闭数据库)释放连接
3.JDBC库的数据源有两种配置方式
异步配置连接
独立配置连接
4.DBCP
饱受诟病,单线程。
查看全部 -
1.什么是热部署?
就是在不重新启动Tomcat服务器的条件下,将自己的项目部署到Tomcat服务器中。
2.如何配置热部署?---------三种方式
直接将自己的web文件放入webapps文件夹中。
conf/server.xml <host>标签中中添加context标签:
<Context debug="0" docBase="D:\demo1\web" path="/demo1" reloadable="true" />
-----debug越大,程序发生异常时,写入日志文件的详细程度越大,默认为0
------docBase 项目的绝对路径或者相对路径(相对webapps)
------path 项目的访问方式
-------reloadable 如果为true 自动加载新增或者改变的class文件
在conf/catalina下面的localhost中添加一个xml文件
新建一个demo2.xml文件,粘贴配置信息:
<?xml version="1.0" encoding="UTF-8"?>
<Context debug="0" docBase="D:\demo1\web" path="/demo1" reloadable="true" />
这时候demo2作为访问项目的名称,path不起作用。
查看全部 -
1.修改内存的目的
日常开发中,开发项目比较大的时候依赖的jar包比较多,并且在应用服务器启动的时候,会将项目引用的所有的类依次全部加载到内存当中,java的逻辑内存模式分为
堆内存(存储类的实例,数组、引用数据类型也就是用new生成的对象)、
栈内存(存储局部变量比如方法参数)、
静态内存区(持久区,该区内存不会被gc回收,存常量、静态变量、类的源数据:方法、属性什么的)
2.在开发当中经常遇到的内存溢出的异常
OutOfMemoryErroe:Java heap space异常------>堆内存满了
JVM中堆内存的大小默认使用的最小内存是我们物理内存的1/64,最大的使用我们物理内存的1/4,我们通过调整JVM中的初始内存和最大内存来改变我们使用内存的限制
OutOfMemoryError:PermGen space异常-------->静态内存区满了
通常是因为加载的类太多导致的,jdk8以下的需要修改两个参数限制静态区最小和最大内存范围,,jdk8改变了内存模型,将类定义存放到了源数据空间,而源数据空间与堆内存共享的是同一块内存区域,所以在jdk8版本以后就不会再出现PermGen space异常了。
StackOverflowError异常---------->栈内存溢出
通常是由于死循环或无线递归导致的
3.配置内存参数
网上有两种方式,一种是在start.bat,一种是在catalina.bat中
bin/catalina编辑:配到第2行/192行都行
JAVA_OPTS=“-server -Xms512m -Xmx1024m
-XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m ”
-Xms:java heap初始大小 ,默认为物理内存的1/64,最大不要超过物理内存的80%
-Xmx:java heap的最大值,建议设置为物理内存的一半,不要超过实际的物理内存
MetaspaceSize:初始源空间的值,默认21m,
MetaspaceSize:最大源空间的值,默认无上限
虚拟机的堆大小决定了虚拟机花费在数据垃圾上的时间和频率,调整虚拟机的堆大小目的是最小化垃圾回收的时间,一般用物理内存的80%作为堆内存的大小
查看全部 -
1.Server 指整个Tomcat服务器,其中包含多个组件,主要负责管理和启动各个service,同时监听8005端口发过来的shut down命令,用于关闭整个服务器。
2.Service 是Tomcat封装的用于对外提供完整的基于组件的web服务,主要包括connector和container两个核心组件和多个功能组件。各个service之间的独立的,但是他们会共享同一个虚拟机资源。
3.Connector 是Tomcat与外部世界的一个连接器,监听固定的端口,接收外部请求,然后将请求传递给container,并且将container的处理结果再返回给外部。
4.Container 是一个servlet容器,内部由多层容器组成,主要用于管理servlet 的生命周期,然后调用servlet 的相关方法去处理业务逻辑。
5.Jasper 是Tomcat的JSP的解析引擎,用于将JSP文件转化成Java文件,并且编译成.class文件。
6.Naming 其实是一个命名服务,将名称和对象联系起来,使得可以用名称去访问对象。
7.Session 负责管理和创建session,session的持久化。可以自定义,并且支持session的集群。对于Tomcat而言,session是在服务器开辟的内存空间。在开发中,经常用session来存储一些临时的信息。
8.Loging 负责记录相关的日志,包含访问错误信息和一下运行信息。
9.JMX javase中的定义的一个技术规范,主要是为应用程序,设备,系统等植入管理功能的框架。通过jmx可以远程监控Tomcat的运行状况。
查看全部 -
热部署的三种方式
1、直接在tomcat运行的时候将war包发布到Tomcat的webapps目录下
2、在tomcat的server.xml配置文件中添加Context配置,指定项目所在的路径,然后在浏览器中输入项目地址即可访问
3、在localhost目录下新建一个xml文件,输入配置信息(war包的绝对路径)
查看全部 -
tomcat控制台乱码,原因是windows默认字符编码是GB2312。解决方案是找到logging.properties的配置文件,替换utf-8为GB2312
查看全部 -
Connecter组件:
(1)接收客户端连接
(2)加工处理客户端请求
解析过程生成request对象,组装过程生成respose对象
Container组件:
(1)所有的子容器的父接口
(2)使用责任链设计模式
(3)包含四个子容器:Engine、Host、Context、Wrapper
责任链模式:使多个对象都有机会去处理同一个请求,从而避免请求的发送者和接收者之间的耦合关系,将这些对象连成一条链,并沿着这条链传递请求,直到有一个对象处理它为止。
Engine:用来管理多个站点,一个service最多只能由一个engine;
Host:代表一个站点,也可以叫虚拟主机,通过配置Host就可以添加站点。
Context:代表一个应用程序,相当于一个war包。
Wrapper:一个封装了的servlet.
查看全部 -
Connector(连接器)组件是Tomcat最核心的两个组件之一,主要的职责就是负责接收客户端连接和客户端请求的处理加工。每个Connector都将指定一个端口进行监听,分别负责对请求报文的解析和响应报文组装,解析过程生成Request对象,而组装过程涉及Response对象; 如果将Tomcat整体比作一个巨大的城堡,那么Connector组件就是城堡的城门,每个人要进入城门就必须通过城门,它为人们进出城堡提供了通道。同时,一个城堡还可能有两个或者多个城门,每个城门代表了不同的通道; HTTP Connector所支持的协议版本为HTTP/1.1和HTTP/1.0,无须显式适配HTTP的版本,Connector会自动适配版本。每个Connector实例对应一个端口,在同个service实例内可以配置若干个Connector实例; AJP Connector组件用于支持AJP协议通信,当我们想将Web应用中包含的静态内容交给Apache处理的时候,Apache与Tomcat之间的通信协议则使用AJP协议; Connector也在服务器端提供了SSL安全通道的支持,用于客户端以HTTPS方式访问,可以通过配置server.xml的<Connector>节点SSLEnabled属性开启;查看全部
-
conf文件夹配置文件
catalina.policy防止jsp代码破坏tomcat容器
catalina.properties包含的是不能被jsp文件修改的文件列表
context.xml context的配置文件,因为它位于顶层,所以它是被所有web应用所使用的配置文件,默认的内容就是web.xml所在的文件位置
logging.properties Tomcat日志使用的配置文件,配置了文件的输出格式等等一系列信息
server.xml tomcat最主要的配置文件,定义了tomcat的体系结构,这个文件是tomcat启动的时候构建Tomcat容器,修改Tomcat的端口号
tomcat-users.xml tomcat人员页面,一些tomcat管理员的人员信息
web.xml配置tomcat启动信息,比如启动页之类的
查看全部 -
/bin:tomcat 存放运行的命令
Windos
startup.bat 启动命令
shutdown.bat关闭命令
configtest.bat设置内存和字符集
Linux
startup.sh 启动命令
shutdown.sh 关闭命令
configtest.sh 设置内存和字符集
/conf 存放配置文件
catalina.policy 防止jsp代码或用户代码破坏tomcat容器
catalina.properties 包含一些不能对jsp或sevlet修改的夹得文件列表
logging.properties 日志使用配置文件,输出格式等
server.xml 最主要配置文件,端口号
tomcat-users.xml 网页的管理信息和用户信息
web.xml 配置启动信息
/lib 存放java包
/logs 运行期间产生的日志信息,查看日志
/webapps 存放应用程序
/ROOT 根目录
/work 运行时编译后的文件,清除此目录可达到清楚缓存的效果
查看全部 -
啦啦啦啦查看全部
举报