个人亲历运维面试 - web服务器部分
WEB服务器
Nginx
1. Nginx的优点
- 轻量级,同样是web服务器,比apache占用更好的资源
- 抗并发,nginx处理请求是异步非阻塞,而apache是阻塞型的,在高并发下nginx能保持低资源低消耗高性能
- 高度模块化设计
- 社区活跃
- 适合处理静态请求
2. Nginx怎么优化
- 优化进程个数:worker_processes 1一般调整到与CPU的颗数相同
# 查看LinuxCPU的个数及总核数 grep processor /proc/cpuinfo|wc -l # 查看CPU的个数 grep 'physical id' /proc/cpuinfo|sort|uniq|wc -l # 通过执行top命令,然后按数字1,即可显示所有的CPU核数 top 按1键就会显示第一个的信息 Cpu0 : 0.0%us, 0.0%sy, 0.0%ni,100.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0
- 绑定不同的nginx进程跑到不同的CPU上:默认情况下,nginx进程跑在某一个CPU上或某一核上,本次优化是不同的nginx进程给不同的CPU处理
# 四核cpu配置 worker_processes 4; worker_cpu_affinity 0001 0010 0100 1000; # 双核配置 worker_processes 2; worker_cpu_affinity 0101 1010;
- 调整nginx单个进程允许最大连接数
events { worker_connections 1024; #一个worker进程的并发 }
- 配置nginx worker进程最大打开文件数
worker_rlimit_nofile 65535;
- gzip压缩实现性能优化,gzip压缩模块提供了压缩文件内容的功能,用户请求的内容在发送给客户端之前,nginx服务器会根据一些具体的策略实施压缩,以节省网站出口带宽,同时加快了数据传输效率,提升了用户的访问体验。
gzip on; #表示开启压缩功能 gzip_min_length 1k; #表示允许压缩的页面最小字节数,页面字节数从header头的Content-Length中获取。默认值是0,表示不管页面多大都进行压缩,建议设置成大于1K。如果小于1K可能会越压越大 gzip_buffers 4 32k; #压缩缓存区大小 gzip_http_version 1.1; #压缩版本 gzip_comp_level 9; #压缩比率 gzip_types text/css text/xml application/javascript; #指定压缩的类型 gzip_vary on; #vary header支持 完美配置:
3. Nginx的常用模块有哪些
ngx_http_gzip_module 文件的压缩功能
ngx_http_fastcgi_module 将客户端对php的请求以fastcgi协议转发至指定服务器
ngx_http_rewrite_module 重定向模块,解析和处理rewrite请求
server {
server_name www.a.com;
root /data/web3/;
location /bbs {
rewrite ^/bbs(.*)$ /forum$1 last; #正则表达式后向引用
}
}
效果:
http://www.a.com/bbs
--> http://www.a.com/forum/
永久重定向:http跳转到https
server{ listen 80; listen 443 ssl; server_name www.c.com; root /data/web3/; ssl on; ssl_certificate /etc/nginx/conf.d/b.crt; ssl_certificate_key /etc/nginx/conf.d/bb.key; ssl_session_cache shared:sslcache:20m; ssl_session_timeout 10m; location / { if ($scheme = http ){ rewrite / https://www.c.com/ permanent; } } }
ngx_http_upstream_module 负载均衡模块,提供服务器分组转发、权重分配、状态监测、调度算法等高级功能
upstream mysqlsrvs{ ip_hash; #源地址hash调度方法 写了backup就不可用 server 172.18.99.1:80 weight=2; #weight权重 server 172.18.99.2:80; #标记down,配合ip_hash使用,实现灰度发布 server 172.18.99.3:80 backup; #backup将服务器标记为“备用”,即所有服务器均不可用时才启用 } } server{ server_name www.a.com; proxy_cache proxycache; proxy_cache_key $request_uri; proxy_cache_valid 200 302 301 1h; proxy_cache_valid any 1m; location / { proxy_pass http://mysqlsrvs; } }
Tomcat
1. tomcat优化
- 线程池优化
maxThreads="1500"
- 压缩优化
compression="on" 打开压缩功能
export JAVA_OPTS="-server -d64 -Xms2g -Xmx20g -XX:PermSize=1g -XX:MaxPermSize=4g -XX:-UseGCOverheadLimit -Djava.util.Arrays.useLegacyMergeSort=true"
- 设置session的过期时间
<session-config>
<session-timeout>30</session-timeout>
</session-config>
Apache
1. apache的优点
- rewrite,比nginx的rewrite强大
- 模块丰富
- 少bug,nginx的bug相对较多
- 超稳定
- 适合处理动态请求
php+apache 和 php+nginx的区别
apache是通过mod_php来解析php nginx是通过php-fpm(fast-cgi)来解析php
1. PHP 解释器是否嵌入 Web 服务器进程内部执行mod_php 通过嵌入 PHP 解释器到 Apache 进程中,只能与 Apache 配合使用,而 cgi 和 fast-cgi 以独立的进程的形式出现,只要对应的Web服务器实现 cgi 或者 fast-cgi 协议,就能够处理 PHP 请求。mod_php 这种嵌入的方式最大的弊端就是内存占用大,不论是否用到 PHP 解释器都会将其加载到内存中,典型的就是处理CSS、JS之类的静态文件是完全没有必要加载解释器。
2. 单个进程处理的请求数量mod_php 和 fast-cgi 的模式在每个进程的生命周期内能够处理多个请求(fast-cgi可以根据需要来调整进程的多少),而 cgi 的模式处理一个请求就马上销毁进程,在高并发的场景下 cgi 的性能非常糟糕。 每一个Web请求PHP都必须重新解析php.ini、重新载入全部dll扩展并重初始化全部数据结构。使用FastCGI,所有这些都只在进程启动时发生一次
综上,如果对性能有极高的要求,可以将静态请求和动态请求分开,这时 Nginx + php-fpm 是比较好的选择。
PS: cgi、fastcgi 通常指 Web 服务器与解释器通信的协议规范,而 php-fpm 是 fastcgi 协议的一个实现。
nginx可用来干什么?
1、静态HTTP服务器
2、反向代理服务器
3、负载均衡
4、虚拟主机
5、邮件代理服务器
加油,你们是最棒的!