nginx部署及简单优化

时间:2023-03-09 06:30:53
nginx部署及简单优化

研究nginx优化时反复安装清理nginx,为方便做了一个简单部署脚本,用的最新稳定版1.14.0,默认路径,加入systemd系统进程管理中,可以通过systemd管理nginx的启动、终止、重载、状态、开机自启等.

 #!/bin/bash

 yum -y install gcc pcre pcre-devel
sleep
cd ~
tar -zxvf ~/zlib-1.2..tar.gz
cd ~/zlib-1.2. && ./configure && make && make install
cd ~
tar -zxvf ~/nginx-1.14..tar.gz
cd ~/nginx-1.14. && ./configure && make && make install
cd ~
#/usr/local/nginx/sbin/nginx
firewall-cmd --set-default-zone=trusted
touch /lib/systemd/system/nginx.service
echo "[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx reload
ExecStop=/usr/local/nginx/sbin/nginx quit
PrivateTmp=true [Install]
WantedBy=multi-user.target" > /lib/systemd/system/nginx.service systemctl enable nginx.service
systemctl restart nginx.service echo "nginx done"

需要再次覆盖nginx时,用awk找到nginx的进程然后kill掉,再次执行安装脚本就行.

 kill - $`ps aux | grep 'nginx' | awk 'NR==2{print $2}'`

二、nginx优化

nginx优化配置集中在nginx.conf文件的main和events段.

main段中worker配置,可以通过work_cpu_affinity选项,按任务类型:CPU密集型或者IO密集型,根据实际业务情况绑定每个worker进程运行在哪个CPU核心上,(前提是系统必须为多核心CPU),例如

 # 4核心CPU中,开启4个worker,每个worker分别对应cpu0/cpu1/cpu2/cpu.
worker_processes ;
worker_cpu_affinity ; # 4核心CPU中,也可以只开启2个worker,第一个worker对应cpu0/cpu2,第二个worker对应cpu1/cpu3.
worker_processes ;
worker_cpu_affinity ;

envents段中开启集中一次性接入连接请求和串行方式接入新连接

events {
worker_connections ; # 每个worker最大连接数.
multi_accept on; # 是否集中接入监听到的连接请求,默认为off,关闭时一次只接收一个连接.
accept_mutex on # 默认为on,表示以串行方式接入新连接,off时,将通报给所有worker.

其它的,例如HTTP段优化,sendfile、keepalive_timeout、gzip是nginx中必做.

相关文章