nginx
以测试的角度去注意,nginx需要注意的地方:
nginx指定配置文件启动操作:
nginx -c /usr/local/nginx/conf/nginx.conf
Nginx相关配置修改之后生效,重新启动的命令:
nginx -s reload
nginx.conf总文件配置;
worker_processes 1; #默认为1
events {
worker_connections 1024; ##每个进程,支持的最大连接数,多了会等待或丢弃;默认512
}
http {
include mime.types; #文件扩展名与文件类型映射表
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65; #连接超时时间,默认为75s
server {
listen 80;
server_name localhost;
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
nginx对应服务的配置--对应具体微服务的配置,只有server块
server {
listen 20000;
server_name 192.168.0.0;
location / { ##处理静态文件请求 转发至本地文件系统根目录的XX下面
root /p/static/p-w-web;
index index.html;
expires 30d;#缓存时间
set $fallback_file /index.html;
if ($http_accept !~ text/html) {
set $fallback_file /null;
}
try_files $uri $fallback_file =404;
add_header Cache-Control no-cache always;
include cors_simple_params;
}
location /cc/ { ##通用规则,用来转发动态请求到后端应用服务器
proxy_pass http://192.168.0.0:9999/cc/;
proxy_set_header Host $http_host;
include cors_params;
client_max_body_size 10M;
}
location /w/w/ {
proxy_pass http://192.168.0.0:9993/w/w/;
proxy_set_header Host $host;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_hide_header Vary;
proxy_connect_timeout 4s;
proxy_read_timeout 7200s;
proxy_send_timeout 12s;
proxy_buffer_size 32k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
include cors_params;
}
}
Nginx调优:
主要从配置入手,针对Nginx特点,nginx一般处理html静态文件,图片,css,js等非动态文件,动态文件交给tomcat处理,这样的话可以减轻tomcat的压力。
如何区分前端是否做了动静态资源分离,主要看Nginx.conf文件中;location是否有如下字段。
动静分离理解:把动态请求和静态请求分开,不是将动态页面和静态页面物理分离,可以理解为nginx处理静态页面,tomcat处理动态页面
动静分离大致分为两种:一、纯粹将静态文件独立成单独域名放在独立的服务器上,也是目前主流方案;二、将动态跟静态文件混合在一起发布,通过nginx分开
调优手段:
1、worker_processes 数 #默认为1,auto---代表有多少核就自动匹配多少
2、worker_connections 1024; ##最大连接数,多了会等待或丢弃;默认512
nginx知识补充:反向代理和负载均衡
如何查看nginx反向代理设置,主要看nginx.conf文件中,proxy_pass地址
正向代理和反向代理理解:
正向代理:局域网中的电脑用户想要直接访问网络是不可行的,只能通过代理服务器来访问,这种代理服务就被称为正向代理。
反向代理:客户端无法感知代理,因为客户端访问网络不需要配置,只要把请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据,然后再返回到客户端,此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP地址
如何查看nginx负载均衡设置,主要看nginx.conf文件中,upstream 地址
实现效果:在浏览器URL栏中输入网址,负载均衡效果会将请求跳转到应用程序的不同端口,对应的相同程序上;
步骤、需要在nginx.conf配置http全局配置中增加upstream myserver{ server IP:PORT; server IP:PORT}; 在location块中配置反向代理proxy_pass http://myserver;
Tomcat
启动tomcat服务
方式一:直接启动 ./startup.sh
方式二:作为服务启动 nohup ./startup.sh & 后台运行,一般使用这种
方式三:控制台动态输出方式启动 ./catalina.sh run
关闭tomcat服务
方式一:使用脚本关闭 ./shutdown.sh
方式二:使用命令关闭 kill -9
server.xml配置文件
maxThreads: # Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。
acceptCount: # 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。
connnectionTimeout: # 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
minSpareThreads: # Tomcat初始化时创建的线程数。
maxSpareThreads: # 一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程
java应用服务器中Catalina.sh文件中可以配置堆大小。Xms起始最小值和XMx最大值;设置经验:
1、一般来说设置越大,性能越好;堆设置太小容易造成OOM现象
2、Xms=XMx,是为了避免GC完成之后,JVM重新调整堆的值