当前位置:首页 » 存储配置 » 需要哪些配置文件

需要哪些配置文件

发布时间: 2022-11-13 09:36:43

① 基于ssh框架的javaweb项目配置文件都有哪些

三大框架需要用到的配置文件总共有一下几个:struts.xml、hibernate-cfg.xml 、spring.xml 、web.xml。添加了配置文件其实只是其中的一个步骤,第二步,应该添加各个框架的jar包(添加需要用到的就行)。 这样,三个框架的环境才算配置完成。

② 网络配置涉及哪些配置文件

Ubuntu系统进行网络配置有的时候用图形界面不起作用,这种情况下可以直接修改某些启动脚本或配置文件

Ubuntu系统进行网络配置涉及到几个配置文件1./etc/network/interfaces 2./etc/resolv.conf

操纵步骤:

1.打开ubuntu的/etc/network/interfaces文件默认的内容如下:

auto lo

iface lo inet loopback

动态获取的配置方法:

auto eth0

iface eth0 inet dhcp

静态分配的配置方法:

auto eth0

iface eth0 inet static

address 192.168.0.1

netmask 255.255.255.0

gateway 192.168.0.1

根据配置要求(是动态分配还是自动获取)修改该配置文件保存。

2.添加域名服务器:打开/etc/resolv.conf文件

添加这行:nameserver 202.99.166.4

3.重启下网络

$/etc/init.d/networking restart(这条命令是重启网卡)

或者

$ifdown eth0

$ifup eth0(这两条命令是有针对性的重启某个网络接口,因为一个系统可能有多个网络接口)

4.查看网络配置的参数是不是正确(每进行一次操作都可以查看一下是不是修改了网络配置)

$ifconfig

5.看看是不是能够ping通

ping不通网关说明网络配置有问题 ping不通域名说明dns有问题

有些时候需要修改网卡的硬件地址:

方法一:

$ifconfig eth0 hw ether XX:XX:XX:XX:XX:XX

$/etc/init.d/networking restart(重启网卡)

方法二:

以上只是暂时的修改硬件地址要永久修改,直接编辑 /etc/network/interfaces 文件,在 iface eth0
inet static 后面添加一行: pre-up ifconfig eth0 hw ether
xx:xx:xx:xx:xx:xx(要改成的MAC)

$ sudo /etc/init.d/networking restart(重启网卡)

③ SpringBoot 配置文件详解(告别XML)

快速学会和掌握 SpringBoot 的 核心配置文件的使用。

SpringBoot 提供了丰富的 外部配置 ,常见的有:

其中核心配置文件我们并不陌生,主要以Key-Value的形式进行配置,其中属性Key主要分为两种:

在 application.properties 添加配置如下:

① 添加数据源信息

在 application.propertis 添加配置如下:

① 添加认证信息,其中 socks.indentity.* 是自定义的属性前缀。

② 添加随机值,其中spring.test.* 是自定义的属性前缀。

使用方法: @ConfigurationProperties(prefix = "spring.datasource")

使用说明:提供 Setter方法 和 标记组件 Component

如何验证是否成功读取配置?答:这里可以简单做个验证,注入 MyDataSource ,使用 Debug 模式可以看到如下信息:

使用方法: @Value("spring.datasource.*")

使用说明:提供 Setter方法 和 标记组件 Component

注意事项:@Value不支持注入静态变量,可间接通过Setter注入来实现。

关于两者的简单功能对比:

显然,前者支持松绑定的特性更强大,所以在实际开发中建议使用@ConfigurationProperties来读取自定义属性。

SpringBoot 默认会加载这些路径加载核心配置文件,按优先级从高到低进行排列:具体规则详见 ConfigFileApplicationListener

如果存在多个配置文件,则严格按照优先级进行覆盖,最高者胜出:

举个简单的例子,例如再上述位置都有一个application.properties ,并且每个文件都写入了server.port=xx (xx分别是9001,9002,9003,9004),在启动成功之后,最终应用的端口为:9004。图例:

如果想修改默认的加载路径 或者 调改默认的配置文件名,我们可以借助命令行参数进行指定,例如:

YAML是JSON的一个超集,是一种可轻松定义层次结构的数据格式。

答: 因为配置文件这东西,结构化越早接触越规范越好。这里推荐阅读阮一峰老师写的 YAML语言教程 ,写的很简单明了。

引入依赖: 在POM文件引入 snakeyaml 的依赖。

使用说明: 直接在类路径添加 application.yml 即可。

例如下面这两段配置是完全等价的:

① 在 application.yml 配置数据源:

② 在 application.properties 配置数据源:

在项目的实际开发中,我们往往需要根据不同的环境来加载不同的配置文件。例如生产环境,测试环境和开发环境等。此时,我们可以借助 Profiles 来指定加载哪些配置文件。例如:

温馨提示:如果spring.profiles.active指定了多个配置文件,则按顺序加载,其中最后的优先级最高,也就是最后的会覆盖前者。

使用方法:
使用Maven插件打包好项目,然后在当前路径,执行DOS命令: java -jar demo.jar --server.port=8081 ,在控制台可看到应用端口变成了8081。

实现原理:
默认情况下,SpringBoot会将这些命令行参数转化成一个 Property ,并将其添加到 Environment 上下文。

温馨提示:
由于命令行参数优先级非常之高,基本高于所有常见的外部配置,所以使用的时候要谨慎。详见 PropertySource 执行顺序 。

关闭方法:
如果想禁用命令行属性,可以设置如下操作:springApplication.setAddCommandLineProperties(false)

④ 使用https访问http/https通信协议,需要哪些配置文件

项目里需要访问其他接口,通过http/https协议。我们一般是用HttpClient类来实现具体的http/https协议接口的调用。

// Init a HttpClient
HttpClient client = new HttpClient();
String url=http://www.xxx.com/xxx;

// Init a HttpMethod
HttpMethod get = new GetMethod(url);
get.setDoAuthentication(true);
get.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, new DefaultHttpMethodRetryHandler(1, false));

// Call http interface
try {
client.executeMethod(get);

// Handle the response from http interface
InputStream in = get.getResponseBodyAsStream();
SAXReader reader = new SAXReader();
Document doc = reader.read(in);
} finally {
// Release the http connection
get.releaseConnection();
}

以上代码在通过普通的http协议是没有问题的,但如果是https协议的话,就会有证书文件的要求了。一般情况下,是这样去做的。

// Init a HttpClient
HttpClient client = new HttpClient();
String url=https://www.xxx.com/xxx;

if (url.startsWith("https:")) {
System.setProperty("javax.net.ssl.trustStore", "/.sis.cer");
System.setProperty("javax.net.ssl.trustStorePassword", "public");
}

于是,这里就需要事先生成一个.sis.cer的文件,生成这个文件的方法一般是先通过浏览器访问https://,导出证书文件,再用JAVA keytool command 生成证书

# $JAVA_HOME/bin/keytool -import -file sis.cer -keystore .sis.cer

但这样做,一比较麻烦,二来证书也有有效期,过了有效期之后,又需要重新生成一次证书。如果能够避开生成证书文件的方式来使用https的话,就比较好了。

还好,在最近的项目里,我们终于找到了方法。

// Init a HttpClient
HttpClient client = new HttpClient();
String url=https://www.xxx.com/xxx;

if (url.startsWith("https:")) {
this.supportSSL(url, client);
}

用到了supportSSL(url, client)这个方法,看看这个方法是如何实现的。

private void supportSSL(String url, HttpClient client) {
if(StringUtils.isBlank(url)) {
return;
}
String siteUrl = StringUtils.lowerCase(url);
if (!(siteUrl.startsWith("https"))) {
return;
}

try {
setSSLProtocol(siteUrl, client);
} catch (Exception e) {
logger.error("setProtocol error ", e);
}
Security.setProperty( "ssl.SocketFactory.provider",
"com.tool.util.DummySSLSocketFactory");
}

private static void setSSLProtocol(String strUrl, HttpClient client) throws Exception {

URL url = new URL(strUrl);
String host = url.getHost();
int port = url.getPort();

if (port <= 0) {
port = 443;
}
ProtocolSocketFactory factory = new SSLSocketFactory();
Protocol authhttps = new Protocol("https", factory, port);
Protocol.registerProtocol("https", authhttps);
// set https protocol
client.getHostConfiguration().setHost(host, port, authhttps);
}

在supportSSL方法里,调用了Security.setProperty( "ssl.SocketFactory.provider",
"com.tool.util.DummySSLSocketFactory");
那么这个com.tool.util.DummySSLSocketFactory是这样的:
访问https 资源时,让httpclient接受所有ssl证书,在weblogic等容器中很有用
代码如下:
1. import java.io.IOException;
2. import java.net.InetAddress;
3. import java.net.InetSocketAddress;
4. import java.net.Socket;
5. import java.net.SocketAddress;
6. import java.net.UnknownHostException;
7. import java.security.KeyManagementException;
8. import java.security.NoSuchAlgorithmException;
9. import java.security.cert.CertificateException;
10. import java.security.cert.X509Certificate;
11.
12. import javax.net.SocketFactory;
13. import javax.net.ssl.SSLContext;
14. import javax.net.ssl.TrustManager;
15. import javax.net.ssl.X509TrustManager;
16.
17. import org.apache.commons.httpclient.ConnectTimeoutException;
18. import org.apache.commons.httpclient.params.HttpConnectionParams;
19. import org.apache.commons.httpclient.protocol.SecureProtocolSocketFactory;
20.
21. public class MySecureProtocolSocketFactory implements SecureProtocolSocketFactory {
22. static{
23. System.out.println(">>>>in MySecureProtocolSocketFactory>>");
24. }
25. private SSLContext sslcontext = null;
26.
27. private SSLContext createSSLContext() {
28. SSLContext sslcontext=null;
29. try {
30. sslcontext = SSLContext.getInstance("SSL");
31. sslcontext.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom());
32. } catch (NoSuchAlgorithmException e) {
33. e.printStackTrace();
34. } catch (KeyManagementException e) {
35. e.printStackTrace();
36. }
37. return sslcontext;
38. }
39.
40. private SSLContext getSSLContext() {
41. if (this.sslcontext == null) {
42. this.sslcontext = createSSLContext();
43. }
44. return this.sslcontext;
45. }
46.
47. public Socket createSocket(Socket socket, String host, int port, boolean autoClose)
48. throws IOException, UnknownHostException {
49. return getSSLContext().getSocketFactory().createSocket(
50. socket,
51. host,
52. port,
53. autoClose
54. );
55. }
56.
57. public Socket createSocket(String host, int port) throws IOException,
58. UnknownHostException {
59. return getSSLContext().getSocketFactory().createSocket(
60. host,
61. port
62. );
63. }
64.
65.
66. public Socket createSocket(String host, int port, InetAddress clientHost, int clientPort)
67. throws IOException, UnknownHostException {
68. return getSSLContext().getSocketFactory().createSocket(host, port, clientHost, clientPort);
69. }
70.
71. public Socket createSocket(String host, int port, InetAddress localAddress,
72. int localPort, HttpConnectionParams params) throws IOException,
73. UnknownHostException, ConnectTimeoutException {
74. if (params == null) {
75. throw new IllegalArgumentException("Parameters may not be null");
76. }
77. int timeout = params.getConnectionTimeout();
78. SocketFactory socketfactory = getSSLContext().getSocketFactory();
79. if (timeout == 0) {
80. return socketfactory.createSocket(host, port, localAddress, localPort);
81. } else {
82. Socket socket = socketfactory.createSocket();
83. SocketAddress localaddr = new InetSocketAddress(localAddress, localPort);
84. SocketAddress remoteaddr = new InetSocketAddress(host, port);
85. socket.bind(localaddr);
86. socket.connect(remoteaddr, timeout);
87. return socket;
88. }
89. }
90.
91. //自定义私有类
92. private static class TrustAnyTrustManager implements X509TrustManager {
93.
94. public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
95. }
96.
97. public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
98. }
99.
100. public X509Certificate[] getAcceptedIssuers() {
101. return new X509Certificate[]{};
102. }
103. }
104.
105. }

public class MySecureProtocolSocketFactory implements SecureProtocolSocketFactory {
static{
System.out.println(">>>>in MySecureProtocolSocketFactory>>");
}
private SSLContext sslcontext = null;

private SSLContext createSSLContext() {
SSLContext sslcontext=null;
try {
sslcontext = SSLContext.getInstance("SSL");
sslcontext.init(null, new TrustManager[]{new TrustAnyTrustManager()}, new java.security.SecureRandom());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (KeyManagementException e) {
e.printStackTrace();
}
return sslcontext;
}

private SSLContext getSSLContext() {
if (this.sslcontext == null) {
this.sslcontext = createSSLContext();
}
return this.sslcontext;
}

public Socket createSocket(Socket socket, String host, int port, boolean autoClose)
throws IOException, UnknownHostException {
return getSSLContext().getSocketFactory().createSocket(
socket,
host,
port,
autoClose
);
}

public Socket createSocket(String host, int port) throws IOException,
UnknownHostException {
return getSSLContext().getSocketFactory().createSocket(
host,
port

然后按如下方式使用HttpClient
Protocol myhttps = new Protocol("https", new MySecureProtocolSocketFactory (), 443);
Protocol.registerProtocol("https", myhttps);
HttpClient httpclient=new HttpClient();

⑤ 软件开发中,什么叫“配置文件”,一般配置文件里放什么

配置文件里放程序启动时需要对程序进行配置的信息,比如我们平时启动刚安装的一款软件时,会出现一些填写注册信息的控件,并询问您是否要勾选记住密码、下次自动登录等的复选框(比如QQ、微信),这些注册信息就被写进了相应程序的配置文件里,当程序下次在启动时就会自动读取配置文件,对程序进行配置,这样我们就不用每次都填写这些注册信息,程序就会自启动了。个人觉得这好像是配置文件在我们开发软件时的一个运用,由于能力有限,暂且只能回答到这。
在下曾经写过一个连接数据的程序,将数据库的连接信息写入一个配置文件中(.ini后缀文件或.xml后缀的文件),然后在程序中对这个配置文件进行读写,就可以达到自动连接数据库或修改数据库原有的连接信息的目的。
希望以上回答is helpful!

⑥ web.xml文件主要配置有哪些,都有什么含义

①web.xml文件是用来配置:欢迎页、servlet、filter等配置文件用的。当你的web工程没用到这些时,你可以不用web.xml文件来配置你的web工程

web.xml的模式文件中定义的标签并不是定死的,模式文件也是可以改变的,一般来说,随着web.mxl模式文件的版本升级,里面定义的功能会越来越复杂,

也即标签元素的种类会越来越多,但有些是不常用的,我们只需记住一些常用的就可以了。

首先是定义头和根元素

声明为xml文件,版本为1.0,编码为utf-8

声明该文件的内容可以使用xsi的标签库

声明标签的使用范围是被javaee的开发使用的

声明可以使用的标签库和对应的具体的标签库版本地址。

web.xml的模式(Schema)文件中定义了多少种标签元素,它就能拥有定义出来的那些功能

随着web.mxl模式文件的版本升级,里面定义的功能会越来越复杂,也即标签元素的种类会越来越多.

定义项目的名称.

项目名称

欢迎页面

servlet

配置springmvc DispatcherServlet( 前台控制器)-->example这个Servlet的名字是example,可以有多个DispatcherServlet,是通过名字来区分的。

async-supported

启动一个新的线程去处理你的请求,完成之后调用你指定的回调函数来完成整个异步操作。

一般的jsp是通过地址栏输入一个地址,或者提交表单的方式发送请求的,这样网页都会被刷新。但是如果你在jsp页面发送一个ajax请求的话,跟前两种不同,

后台会返回给jsp页面内容,页面不会直接刷新,这样可以把返回的数据写在页面的div中,这样就完成了页面的局部刷新。

举个例子,你做一个查询功能,页面上有查询条件和查询结果显示区域,你可以点查询按钮的时候通过ajax异步发送你的查询条件,

而你得到后台返回的查询结果后,更新你的jsp页面的查询结果,jsp的其他部分,比如查询条件,都没有更新,jsp没有刷新,而是更新了查询结果这一块内容

  url-pattern   默认匹配所有请求Servlet拦截匹配规则可以自已定义1、拦截*.do、*.htm, 例如:/user/add.do,这是最传统的方式,最简单也最实用。不会导致静态文件(jpg,js,css)被拦截。2、拦截/,例如:/user/add,可以实现现在很流行的REST风格。很多互联网类型的应用很喜欢这种风格的URL。弊端:会导致静态文件(jpg,js,css)被拦截后不能正常显示。

监听器

Listener获取的是Web应用ServletContext(application)的配置参数。-为Web应用配置Listener的两种方式: 使用@WebListener修饰Listener实现类即可 在web.xml文档中使用进行配置。我们选择web.xml这种配置方式,只有一个元素指定Listener的实现类.

②启动WEB项目的时候,Tomcat容器首先会去它的配置文件读取两个节点listener和context-param。

然后Tomcat会创建一个ServletContext(application),WEB项目所有部分都将共享这个上下文

将applicationContext.xml存入ServletContext中

Tomcat容器根据class类路径来创建监听

上面这些都是在web项目还没有完全启动起来就完成的工作,而servlet是在第一次发起请求时被实例化的

而且一般不会被容器销毁,并服务于多个用户的请求.

web.xml的加载顺序是: context-param-> listener -> filter -> servlet.

filter

Filter可认为是Servlet的“增强版”,因此Filter配置与Servlet的配置非常相似,需要配置两部分:配置Filter名称和Filter拦截器URL模式。区别在于Servlet通常只配置一个URL,而Filter可以同时配置多个请求的URL。配置Filter有两种方式:

在Filter类中通过Annotation进行配置。

在web.xml文件中通过配置文件进行配置。

①网络

②http://blog.csdn.net/believejava/article/details/43229361

1.在web.xml里配置监听器、过滤器、拦截器,书写顺序有没有什么要求?

根据网上资料来分析,应该是没有书写顺序的要求,容器会按照自己的加载方式去加载顺序.

2.监听器是必须要配置的吗?

不是必须要配置.

3假设配置了多个listener,那么会先加载哪个listener

如果有多个listener的情况下,我们可以根据自己的需要去手动设置先去加载哪个listener.

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

技能树.IT修真院

“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~

http://www.jnshu.com/login/1/14708688

PPT :  https://ptteng.github.io/PPT/PPT-java/Java-task2-webxml.html#/

⑦ 是否了解tomcat的调优工作,需要修改哪些配置文件实

Tomcat性能调优方案
一、操作系统调优
对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统运行速度越快。。
【适用场景】 任何项目。
二、Java虚拟机调优
应该选择SUN的JVM,在满足项目需要的前提下,尽量选用版本较高的JVM,一般来说高版本产品在速度和效率上比低版本会有改进。
JDK1.4比JDK1.3性能提高了近10%-20%,JDK1.5比JDK1.4性能提高25%-75%。
因此对性能要求较高的情况推荐使用 JDK1.6。
【适用场景】 任何项目。
三、Apache集成Tomcat
Web服务器专门处理HTTP请求,应用服务器是通过很多协议为应用提供商业逻辑。虽然Tomcat也可以作web服务器,但其处理静态html的速度比不上Apache,且其作为web服务器的功能远不如Apache,因此把Apache和Tomcat集成起来,将html和Jsp的功能部分进行明确分工,让Tomcat只处理Jsp部分,其他的由Apache,IIS等web服务器去处理,由此大大提高Tomcat的运行效率。
如果一个项目中大量使用了静态页面、大量的图片等,并有有较大的访问量,推荐使用Apache集成Tomcat的方式来提高系统的整体性能。
Apache和Tomcat的整合有三种方式,分别是JK、http_proxy和ajp_proxy.其中JK方式是最常见的方式,JK本身有两个版本分别是1和2,目前1最新版本是1.2.8,而版本2早已经废弃了。http_proxy是利用Apache自带的mod_proxy模块使用代理技术来连接Tomcat。Ajp_proxy连接方式其实跟http_proxy方式一样,都是由mod_proxy所提供的功能。只需要把配置中的http://换成ajp://,同时连接的是Tomcat的AJP Connector所在的端口。
相对于JK的连接方式,后两种在配置上比较简单的,灵活性方面也一点都不逊色。但就稳定性而言不像JK这样久经考验,所以建议采用JK的连接方式。
Apache+JK+Tomcat配置:
使用到的两个配置文件分别是:httpd.conf和mod_jk.conf。其中httpd.conf是Apache服务器的配置文件,用来加载JK模块以及指定JK配置文件信息。mod_jk.conf是到Tomcat服务器的连接定义文件。
【部署步骤】
1.安装Apache服务器
2.部署Tomcat
3.将mod_jk.so拷贝到moles目录下面
4.修改httpd.conf和mod_jk.conf
【适用场景】 大量使用静态页面的应用系统。
四、Apache和Tomcat集群
对于并发要求很高的系统,我们需要采取负载均衡的方式来分担Tomcat服务器的压力。负载均衡实现大概有四种:第一是通过DNS,但只能简单的实现轮流分配,不能处理故障;第二是基于MS IIS,windows 2003 server本身就带了负载均衡服务;第三是硬件方式,通过交换机功能或专门的负载均衡设备来实现;第四种是软件的方式,通过一台负载均衡服务器进行,上面安装软件。使用Apache Httpd Server做负载均衡器,Tomcat集群节点使用Tomcat就可以做到上述第四种方式,这种方式比较灵活,成本相对比较低,另外一个很大的优点就是可以根据应用情况和服务器的情况做一些灵活的配置。所以推荐使用Apache+Tomcat集群来实现负载均衡。
采用Tomcat集群可以最大程度的发挥服务器的性能,可以在配置较高的服务器上部署多个Tomcat,也可以在多台服务器上分别部署Tomcat,Apache和Tomcat整合的方式还是JK方式。经过验证,系统对大用户量使用的响应方面,Apache+3Tomccat集群> Apache+2Tomcat集群 > Apache集成Tomcat > 单个Tomcat。并且采用Apache+多Tomcat集群的部署方式时,如果一个Tomcat出现宕机,系统可以继续使用,所以在硬件系统性能足够优越的情况下,需要尽量发挥软件的性能,可以采用增加Tomcat集群的方式。
Apache+Tomcat集群的方式使用到得配置文件有httpd.conf、mod_jk.conf、workers.properties。其中mod_jk.conf是对JK信息的配置,包括JK的路径等,workers.properties配置文件是对Tomcat服务器的连接定义文件。
Apache需要调整运行参数,这样才能构建一个适合相应网络环境的web服务。其中可进行的优化配置如下:
1. 设置MPM(Multi Processing Moles多道处理模块)。ThreadPerChild,这个参数用于设置每个进程的线程数,在Windows环境下默认值是64,最大值是1920,建议设置为100-500之间,服务器性能高的话值大一些,反之小一些。MaxRequestPerChild表示每个子进程能够处理的最大请求数。这个参数的值更大程度上取决于服务器的内存,如果内存比较大的话可以设置为很大的参数,否则设置一个较小的值,建议值是3000.
2. 关闭DNS和名字解析 HostnameLookups off
3. 打开UseCanonicalName模块 UseCanonicalName on
4. 关闭多余模块 一般来说,不需要加载的模块有,mod_include.so、mod_autoindex.so、mod_access.so、mod_auth.so.
5. 打开KeepAlive支持
KeepAlive on, KeepAliveTimeout 15 MaxKeepAliveRequests 1000
根据实际经验,通过Apache和Tomcat集群的方式提高系统性能的效果十分明显,这种方式可以最大化的利用硬件资源,通过多个Tomcat的处理来分担单Tomcat时的压力。
【部署步骤】
1.安装Apache服务器
2.部署Tomcat集群,即多个相同的Tomcat。
3.将mod_jk.so拷贝到moles目录下面
4.修改httpd.conf、mod_jk.conf和workers.properties
【适用场景】 并发用户量及在线使用用户数量比较高的系统。
五、Tomcat自身优化
1. JVM参数调优:-Xms<size> 表示JVM初始化堆的大小,-Xmx<size>表示JVM堆的最大值。这两个值的大小一般根据需要进行设置。当应用程序需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。在catalina.bat中,设置JAVA_OPTS='-Xms256m -Xmx512m',表示初始化内存为256MB,可以使用的最大内存为512MB。
2. 禁用DNS查询
当web应用程序向要记录客户端的信息时,它也会记录客户端的IP地址或者通过域名服务器查找机器名转换为IP地址。DNS查询需要占用网络,并且包括可能从很多很远的服务器或者不起作用的服务器上去获取对应的IP的过程,这样会消耗一定的时间。为了消除DNS查询对性能的影响我们可以关闭DNS查询,方式是修改server.xml文件中的enableLookups参数值:
Tomcat4

<Connector className="org.apache.coyote.tomcat4.CoyoteConnector" port="80" minProcessors="5" maxProcessors="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" useURIValidationHack="false" disableUploadTimeout="true" />

Tomcat5

<Connector port="80" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" enableLookups="false" redirectPort="8443" acceptCount="100" debug="0" connectionTimeout="20000" disableUploadTimeout="true"/>
3. 调整线程数
通过应用程序的连接器(Connector)进行性能控制的的参数是创建的处理请求的线程数。Tomcat使用线程池加速响应速度来处理请求。在Java中线程是程序运行时的路径,是在一个程序中与其它控制线程无关的、能够独立运行的代码段。它们共享相同的地址空间。多线程帮助程序员写出CPU最大利用率的高效程序,使空闲时间保持最低,从而接受更多的请求。
Tomcat4中可以通过修改minProcessors和maxProcessors的值来控制线程数。这些值在安装后就已经设定为默认值并且是足够使用的,但是随着站点的扩容而改大这些值。minProcessors服务器启动时创建的处理请求的线程数应该足够处理一个小量的负载。也就是说,如果一天内每秒仅发生5次单击事件,并且每个请求任务处理需要1秒钟,那么预先设置线程数为5就足够了。但在你的站点访问量较大时就需要设置更大的线程数,指定为参数maxProcessors的值。maxProcessors的值也是有上限的,应防止流量不可控制(或者恶意的服务攻击),从而导致超出了虚拟机使用内存的大小。如果要加大并发连接数,应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。
在Tomcat5对这些参数进行了调整,请看下面属性:
maxThreads Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。
acceptCount 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。
connnectionTimeout 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
minSpareThreads Tomcat初始化时创建的线程数。

maxSpareThreads 一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。
最好的方式是多设置几次并且进行测试,观察响应时间和内存使用情况。在不同的机器、操作系统或虚拟机组合的情况下可能会不同,而且并不是所有人的web站点的流量都是一样的,因此没有一刀切的方案来确定线程数的值。
六、APR库使用
Tomcat中使用APR库,其实就是在Tomcat中使用JNI的方式来读取文件以及进行网络传输。可以大大提升Tomcat对静态文件的处理性能,同时如果你使用了HTTPS方式传输的话,也可以提升SSL的处理性能。
一般在Windows下,可以直接下载编译好的二进制版本的dll库文件来使Tomcat启用APR,一般建议拷贝库文件tcnative-1.dll到Tomcat的bin目录下。而在Linux下,可以直接解压和安装bin目录下的tomcat_native.tar.gz文件,编译之前要确保apr库已经安装。
怎么才能判断Tomcat是否已经启用了APR库呢?方法是通过看Tomcat的启动日志:
如果没有启用APR,则启动日志一般有这么一条:
org.apache.coyote.http11.Http11Protocol start
如果启用了APR,则这条日志就会变成:
org.apache.coyote.http11.Http11AprProtocol start
tcnative-1.dll 下载地址:http://tomcat.heanet.ie/native/
调优综述
根据以上分析,如果想要Tomcat达到最优的效果,首先要争取使得操作系统以及网络资源达到最优,并且最好使用高版本的JDK。对于有大量静态页面的系统,采用Apache集成Tomcat的方式,把静态页面交由Apache处理,动态部分交由Tomcat处理,能极大解放Tomcat的处理能力。使用ARP库也能极大的提高Tomcat对静态文件的处理能力。对于并发要求较高的系统,采用Apache加Tomcat集群的方式,将负载分别分担到多个Tomcat上,能很大的提高系统的性能,充分利用硬件资源。同时需要对Tomcat自身进行优化,包括增大内存、调节并发线程数等。

⑧ CA server需要配置哪些内容

需配置cas-theme-default.properties。系列messages_*.properties。default_views.properties和protocol_views.properties。log4j.xml。
cas-theme-default.properties:该文件存放的是css文件的路径,用户可以在这里指定使用的css文件为自定义的css文件,也可以更改配置文件中对应的css文件已更改默认的样式。
系列messages_*.properties:国际化支持对应的资源文件。
default_views.properties和protocol_views.properties:CasServer中使用到的视图配置文件,用于定义对应视图的处理类及其文件路径。
log4j.xml:log4j的配置文件。

⑨ java常用的配置文件有哪些

项目中经常会需要读取配置文件(properties文件),给你总结了配置文件读取方法如下:
1、通过java.util.Properties读取

Java代码

  • Propertiesp=newProperties();

  • //p需要InputStream对象进行读取文件,而获取InputStream有多种方法:

  • //1、通过绝对路径:InputStreamis=newFileInputStream(filePath);

  • //2、通过Class.getResourceAsStream(path);

  • //3、通过ClassLoader.getResourceAsStream(path);

  • p.load(InputStreamis);

  • is.close();

  • p.getString(String(key))


  • 2、通过java.util.ResourceBundle读取

  • Java代码

  • ResourceBundlerb=ResourceBundle.getBundle(packageName);

  • rb.getString(Stringkey);

⑩ supervisor配置文件(详细说明)

supervisor 安装启动

Windows-INI-style (python ConfigParser)类型文件,包含以 [header] 标记开头的模块和这个模块里一系列的key/value键值对

supervisord启动时使用的环境变量,用的是python %(ENV_X)s 字符串表达式语法格式

[unix_http_server] 模块下配置了需要监听UNIX domain socket的http服务的配置参数;如果在conf文件里没有配置这个模块,那需要监听UNIX domain socket的supervisorctl就不会被启动

  1. file : supervisor为HTTP/XML-RPC请求监听UNIX domain socket的路径(socket文件路径); supervisorctl 通过这个文件完成与supervisor的交流;这个选项可以用 %(here)s ,如果用 %(here)s 这个值,那么会直接扩展到supervisord的配置文件所在目录
   这个关键字默认不配置,也不是必须要配置的,但是要注意,如果 supervisor.sock 文件被删除或者没有配置,supervisorctl就不能连接到supervisord,也就不能用suepervisorctl控制进程了,例如下面这个错误:

  2. chmod : socket文件权限的指定,默认是0700
  3. chown : 改变socket文件的用户和组,默认使用启动supervisord的用户和用户组
  4. username : supervisorctl连接supervisord时的授权用户,默认无指定用户
  5. password : supervisorctl连接supervisord时的授权密码,默认无密码;密码既可以是纯文本密码,也可以是带有 {SHA} 前缀的SHA-1的哈希,例如: {SHA}

[unix_http_server] 这个模块配置是监听TCP socket的配置,如果.conf里面没有配置这个模块,inet的http服务就不会启动,那web server和remote supervisorctl就不能使用;
这个模块默认未开启状态 ,如果需要启用这个模块需要绝对信任的环境——应该绑定localhost或者只能通过一个可信赖的独立网络访问,inet的http服务不支持任何形式的加密,不能使用默认认证方式;
inet的http服务可以被supervisorctl远程控制,也可以通过web界面的方式控制子进程,查看log,但是不可以把inet的http服务暴露在公共网络里面

  1. port : 一个tcp的host:port配置,例如 127.0.0.1:9001 ,supervisorctl会通过这个端口和supervisord交流;无默认配置
  2. username 和 password : 与 [unix_http_server] 模块下的 username && password 作用相同

这个模块配置了supervisord进程有关的全局配置,这个默认可以不配置,但是不配置时,supervisord运行可能会出现问题

  1. logfile :默认值: $CWD/supervisord.log ,指定supervisord进程的log文件的路径,也可以直接用 %(here)s ;如果指定了log文件&&需要做log滚动(根据log大小限制生成新的log文件)的话,必须配置 logfile_maxbytes > 0
  2. logfile_maxbytes : 默认50MB,配置日志滚动的log字节数限制, KB/MB/GB 这些单位都是可以用的,如果配置为0,则认为log文件不限制大小,不做log滚动
  4. logfile_backups : 备份保留log个数,默认保留最近10个,如果设置为0就不做任何备份
  5. loglevel : log级别:默认记录info级别的日志,可选: critical||error||warn||info||debug||trace||blather ;如果指定日志记录为debug级别,supervisord 的log文件里会记录子进程的输入输出,也会记录进程状态改变的信息,在某个进程启动异常做调试的时候比较方便
  6. pidfile : supervisord的pid文件路径,默认 $CWD/supervisord.pid ,也可以使用 %(here)s
  7. umask : supervisord进程的文件权限掩码,默认 022
  8. nodaemon : 设置这个选项为 true 的时候,会在前台启动supervisor,默认flase
  8. minfds : supervisor启动前要求的最小空闲文件描述符数值,supervisord启动时对硬件和软件资源的要求,低于这个最低值,supervisor无法启动;如果supervisord基于root用户启动,硬件限制会有所提高,所以指定要求的资源限制最低值,可以确保程序运行过程中不会造成资源耗尽的情况,默认值是1024
  9. minprocs : supervisord启动时,系统中最小可用进程数的配置,低于当前数值,supervisord不会启动;默认值=200
  10. nocleanup : 默认false,如果想避免supervisord启动时“auto”路径下的清理子进程的log文件可以设置为true
  11. childlogdir : 子进程的“auto” log文件目录,默认取的是python的 tempfile.get_tempdir() 路径,也可以用 %(here)s
  12. user : 在做进程管理之前,supervisord需要转变用户使用指定的unix用户(默认是当前用户),支持这个配置的前提是supervisord使用root用户启动
  PS:3.3.4版本以后,如果supervisord不能转换到指定用户,会记录错误信息到log里然后立即退出;之前的版本会记 critical log,但是程序可以继续运行
  13. directory : supervisord作为守护进程的时候,会转换路径到这个dictionary,默认不配置,可以使用 %(here)s
  14. strip_ansi : 清除子进程log文件中的ANSI内容,默认不清除
  15. environment : supervisord进程启动环境中的环境变量配置,是 KEY="val",KEY2="val2" 这样一系列的key-value键值对,如果键值对的value值包含一些非标准字符,例如 KEY="val:123",KEY2="val,456" 这种一定要用""括起来,最好的话还是使用转义减少问题
  16. identifier : RPC交互使用的supervisor进程的声明,默认值= supervisor

使用supervisorctl和supervisord交互的配置

  1. serverurl : 访问supervisord服务的url: unix:///absolute/path/to/file.sock ;默认配置 http://localhost:9001
  2. username 和 password : 访问supervisord服务时的身份认证用户和密码, username 需要和supervisord的用户是同一个,默认是不配置的;需要注意的是,如果使用 password ,就必须设置密码为纯文本字符串,这里不支持SHA hash格式的密码
  3. prompt : supervisorctl 命令行标识符,默认 supervisor
  4. history_file : 历史文件的路径,如果启用这个配置指定文件路径,那么supervisorctl的历史命令会被保存在这个文件里面,并且可以命令查看之前supervisorctl session的历史记录,默认不配置

这个模块在配置文件中至少要有1个,是必须要有的模块,可以有多个,这个模块告诉supervisord 需要控制的服务项目有哪些;模块的头部是 program:接项目名 组成的,后面的名字就是supervisord控制的服务名,后面supervisorctl就是直接通过这个服务名称来做进程管理;
如果一个program没有指定名字,或者不是用 : 指定的,supervisod启动时会直接失败;
新版本(3.0)中,一个 [program:x] 将会被supervisor看做是一个同类进程组,这一系列进程组通过 numprocs 和 process_name 定义在配置文件中,当然默认情况下还是一个program就只是一个单独的进程,以便更好的兼容历史版本;

testMul这个program就是一个进程组,包含了相同命令启动的三个进程:testMul_00、testMul_01、testMul_02

以 [include] 开头的一个模块,这模块一旦配置,必须包含 files 这个配置,指定额外的配置文件要包含在当前配置中;
这个模块只有supervisord用,supervisorctl不会用到

   1. files : 一个隔离开来的文件系列,每个系列里的文件可以是独立的,也可以实现相互关联的,直接包含就可以了;这个所谓的一个系列,需要根据unix的使用规则指定一定的模式,然后用 *||?||[] 这种匹配模式去匹配,包含 host_node_name||here 的字符喜欢表达式也是可以的;
   没有默认值,启用模块必须配置

这个模块通常是做组进程管理的,将多个[program:x]放到一个进程中管理,为了把一组program作为一个整体进行管理,就要在配置[group:x]的时候,必须填好programs的配置项,指定你要绑定在一起的programs们;
模块命名与program一样的,header错误会导致启动失败
一个group模块下可以配置多个programs;

   1. programs : 成组的programs
   2. priority : 优先级

supervisor允许在配置文件里指定进程组(“事件监听池”)的,这些进程可能需要接受或者回应supervisor事件系统的事件提醒,eventlistener做的就是订阅这些事件做监听

   1. 支持 [program:x] 下除了stdout_capture_maxbytes的所有可选配置项
   2. buffer_size : 事件监听池里时间序列的缓存大小,当一个事件监听池发生溢出时,就会丢弃缓存中最旧的事件
   3. events : 逗号分隔的事件类型列表,只出需要监听的进程的的哪些事件
   4. result_handler : 一个python回调函数pkg_resources模块的入口,默认 supervisor.dispatchers:default_handler

只用于扩展supervisor额外的用户定制行为

热点内容
密码锁如何在里面开门 发布:2025-07-15 18:35:00 浏览:520
额温算法 发布:2025-07-15 18:18:14 浏览:727
ie客户端事件脚本执行异常 发布:2025-07-15 18:10:13 浏览:24
自制压缩兔粮 发布:2025-07-15 18:09:25 浏览:11
脚本病毒的危害 发布:2025-07-15 18:04:00 浏览:259
简单的解压 发布:2025-07-15 17:42:25 浏览:147
lol最强脚本 发布:2025-07-15 17:41:45 浏览:290
安卓手机测量工具在哪里 发布:2025-07-15 17:41:39 浏览:241
易语言灰鸽子源码 发布:2025-07-15 17:37:08 浏览:869
编程代码怎么写 发布:2025-07-15 17:30:45 浏览:121