Linux 编译安装 Nginx

目录

一、前言

Nginx 是一款轻量级的 Web 服务器、[反向代理]服务器,由于它的内存占用少,启动极快,高并发能力强,在互联网项目中广泛应用。本文介绍三种基于 linux 环境下的安装 nginx 的方法,安装版本为现阶段官网推出的最新稳定版本。在 Linux 上面安装Nginx 有四种安装方式,本次记录的是通过源码安装的方式,及安装过程中的一些踩坑记录。

二、四种安装方式介绍

  1. yum 安装: 简单方便,不易出错
  2. rpm 安装包安装: 便捷,方便
  3. 源码包安装: 有点繁琐,服务性能好
  4. docker 安装: 方便快捷

注意:其中 [yum]源码安装、docker 安装依赖互联网接入,rpm 可以离线安装。

三、本文安装方式:源码安装

Nginx 源码包安装步骤相比其他安装方法比较繁琐,但是操作不复杂,需要提前安装一些 Nginx 依赖库。

3.1、安装依赖库

  1. 安装 gcc 环境
SH 复制代码
yum -y install gcc gcc-c++ autoconf automake make
  1. 安装 pcre:提供 nginx 支持重写功能
SH 复制代码
yum -y install pcre pcre-devel
  1. 安装 zlib:zlib 库提供了很多压缩和解压缩的方式,nginx 使用 zlib 对 http 包内容进行 gzip 压缩
SH 复制代码
yum -y install zlib zlib-devel make libtool
  1. 安装 openssl:安全套接字层密码库,用于通信加密
SH 复制代码
yum -y install openssl openssl-devel

3.2、开始安装 Nginx

  1. 手动创建用户和用户组
SH 复制代码
groupadd nginx
SH 复制代码
useradd nginx -g nginx -s /sbin/nologin -M
  1. 官网下载 Nginx 的源码包:

https://nginx.org/download/nginx-1.20.2.tar.gz

可以直接下载通过 FTP 拖拽上去,也可以进入到下载目录,执行以下命令
进入安装目录

SH 复制代码
cd /usr/local/soft/Nginx

下载 Nginx

SH 复制代码
wget https://nginx.org/download/nginx-1.20.2.tar.gz
  1. 下载好了之后,执行下面的命令进行解压
SH 复制代码
tar -zxvf nginx-1.20.2.tar.gz
  1. 进入到解压后的目录
SH 复制代码
cd nginx-1.20.2
  1. 检查平台安装环境
SH 复制代码
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --user=nginx --group=nginx

参数解释

  • --prefix=/usr/local/nginx: #编译安装目录
  • --user=nginx: #所属用户
  • nginx --group=nginx: #所属组
  • nginx --with-http_stub_status_module: #该模块提供 nginx 的基本状态信息
  • --with-http_ssl_module: #支持 HTTPS
  1. 编译并且安装

编译源码

SH 复制代码
make

安装

SH 复制代码
make install

安装成功后,会把 Nginx 安装到 /usr/local/nginx 目录下面

SH 复制代码
cd /usr/local/nginx

进入该目录修改 nginx.conf 配置,以下配置的相关解释供参考

SH 复制代码
#定义Nginx运行的用户和用户组
user www www;
#
#nginx进程数,建议设置为等于CPU总核心数.
worker_processes 8;
#
#全局错误日志定义类型,[ debug | info | notice | warn | error | crit ]
error_log /var/log/nginx/error.log info;
#
#进程文件
pid /var/run/nginx.pid;
#
#一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀,所以建议与ulimit -n的值保持一致.
worker_rlimit_nofile 65535;

worker_shutdown_timeout 300s; # 配置为300s,shutting down状态的worker 300s之后自动退出。
#
#工作模式与连接数上限
events
{
    #参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ]; epoll模型是Linux 2.6以上版本内核中的高性能网络I/O模型,如果跑在FreeBSD上面,就用kqueue模型.
    use epoll;
    #单个进程最大连接数(最大连接数=连接数*进程数)
    worker_connections 1024;    #最大连接数,默认为512
}
#
#设定http服务器
http
{
    include mime.types; #文件扩展名与文件类型映射表
    default_type application/octet-stream; #默认文件类型
    #charset utf-8; #默认编码
    server_names_hash_bucket_size 128; #服务器名字的hash表大小
    client_header_buffer_size 32k; #上传文件大小限制
    large_client_header_buffers 4 64k; #设定请求缓
    client_max_body_size 8m; #设定请求大小 
      keepalive_timeout 65;  #连接超时时间,默认为75s,可以在http,server,location块。
    # 开启目录列表访问,合适下载服务器,默认关闭.
    autoindex on; # 显示目录
    autoindex_exact_size on; # 显示文件大小 默认为on,显示出文件的确切大小,单位是bytes 改为off后,显示出文件的大概大小,单位是kB或者MB或者GB
    autoindex_localtime on; # 显示文件时间 默认为off,显示的文件时间为GMT时间 改为on后,显示的文件时间为文件的服务器时间
    
    sendfile on; # 开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载.注意:如果图片显示不正常把这个改成off.
    tcp_nopush on; # 防止网络阻塞
    tcp_nodelay on; # 防止网络阻塞
    
    
    # FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度.下面参数看字面意思都能理解.
    fastcgi_connect_timeout 300; ## 链接
    fastcgi_send_timeout 300;  ##读取 是指nginx进程向fastcgi进程发送request的整个过程的超时时间
    fastcgi_read_timeout 300;  ##发请求 是指fastcgi进程向nginx进程发送response的整个过程的超时时间
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 128k;
    
    # gzip模块设置
    gzip on; #开启gzip压缩输出
    gzip_min_length 1k; #允许压缩的页面的最小字节数,页面字节数从header偷得content-length中获取.默认是0,不管页面多大都进行压缩.建议设置成大于1k的字节数,小于1k可能会越压越大
    gzip_buffers 4 16k; #表示申请4个单位为16k的内存作为压缩结果流缓存,默认值是申请与原始数据大小相同的内存空间来存储gzip压缩结果
    gzip_http_version 1.1; #压缩版本(默认1.1,目前大部分浏览器已经支持gzip解压.前端如果是squid2.5请使用1.0)
    gzip_comp_level 2; #压缩等级.1压缩比最小,处理速度快.9压缩比最大,比较消耗cpu资源,处理速度最慢,但是因为压缩比最大,所以包最小,传输速度快
    gzip_types text/plain application/x-javascript text/css application/xml;
    #压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn.
    gzip_vary on;#选项可以让前端的缓存服务器缓存经过gzip压缩的页面.例如:用squid缓存经过nginx压缩的数据
    
    #开启限制IP连接数的时候需要使用
    #limit_zone crawler $binary_remote_addr 10m;
    
    ##upstream的负载均衡,四种调度算法(下例主讲)##
    
#虚拟主机的配置
    server
    {
        # 监听端口
        listen 80;
        # 域名可以有多个,用空格隔开
        server_name 127.0.0.1 www.xxx.com;
        # HTTP 自动跳转 HTTPS
        rewrite ^(.*) https://www.baidu.com;
        deny 127.0.0.1;  #拒绝的ip
        allow 172.18.5.54; #允许的ip 
    }
    upstream myserver {   
      server 127.0.0.1:8080;
      server 192.168.24.189:8080 backup;  #热备
    }
    server
    {
        # 监听端口 HTTPS
        listen 443 ssl;
        server_name https://www.baidu.com;
        # alias /path/www/
        root /data/www/;
        # 配置域名证书
        ssl_certificate      C:\WebServer\Certs\certificate.crt;
        ssl_certificate_key  C:\WebServer\Certs\private.key;
        ssl_session_cache    shared:SSL:1m;
        ssl_session_timeout  5m;
        ssl_protocols SSLv2 SSLv3 TLSv1;
        ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
        ssl_prefer_server_ciphers  on;
    
        index index.html index.htm index.php;
        
        location /
          root /www/html; # 静态资源目录
          index index.html; # 目录的默认文件
          # try_files 用于指定文件的查找规则,可以配置多个规则,会按顺序执行查找规则,
          # 若找到文件则中断查找并返回文件,若找不到则返回404响应。
          try_files $uri $uri/ /index.html;
        }
        
        location ~ .*\.(php|php5)?$
        {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
        
        # 配置地址拦截转发,解决跨域验证问题
        location /oauth/{
            proxy_pass https://localhost:13580/oauth/;
            proxy_set_header HOST $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
        
        # 图片缓存时间设置
        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
            expires 10d;
        }
        
        # JS和CSS缓存时间设置
        location ~ .*\.(js|css)?$ {
            expires 1h;
        }

        # 日志格式设定
        log_format access '$server_name $remote_addr -$remote_user [$time_local] "$request"'
                  '$status $uptream_status $body_bytes_sent "$http_referer"'
                  '"$http_user_agent" "$http_x_forwarded_for" '
                  '$ssl_protocol $ssl_cipher $upstream_addr $request_time $upstream_response_time';
       # 定义本虚拟主机的访问日志
        access_log /var/log/nginx/access.log access;
        
        # 设定查看Nginx状态的地址.StubStatus模块能够获取Nginx自上次启动以来的工作状态,此模块非核心模块,需要在Nginx编译安装时手工指定才能使用
        location /NginxStatus {
            stub_status on;
            access_log on;
            auth_basic "NginxStatus";
            auth_basic_user_file conf/htpasswd;
            #htpasswd文件的内容可以用apache提供的htpasswd工具来产生.
        }
    }
}

3.3、Nginx 相关操作

PS:下面的命令不要无脑复制,请根据自己的需求按需复制使用。

  1. 启动 nginx 服务
SH 复制代码
/usr/local/nginx/sbin/nginx

如果发现报错:nginx: [emerg] getpwnam("nginx") failed

那是因为没有创建 nginx 用户,执行下面命令进行创建

设置shell不能登陆,不创建home目录

SH 复制代码
useradd -s /bin/nologin -M nginx
  1. 重新加载 nginx 服务
SH 复制代码
usr/local/nginx/sbin/nginx -s reload
  1. 停止 nginx 服务
SH 复制代码
/usr/local/nginx/sbin/nginx -s stop
  1. 查看 nginx 进程
SH 复制代码
ps -ef | grep nginx

如上图所示,表示启动成功。还可以通过下面的命令来验证是否启动成功

IP替换成自己服务器的 IP,内网,外网都可以

SH 复制代码
curl IP

或者打开浏览器,输入自己服务器的 IP,出现以下页面,说明安装成功

  1. 查看 Nginx 的版本信息,可以通过以下命令来查询安装的 nginx 版本信息
SH 复制代码
/usr/local/nginx/sbin/nginx -V

3.4、把 Nginx 注册成系统服务

目前 nginx 都是通过命令执行的,在 nginx 运行过程中,需要 nginx 作为系统的服务运行。以 systemctl 命令运行服务

  1. 新建一个配置文件,命名为 nginx.servic
SH 复制代码
vi /lib/systemd/system/nginx.service
  1. 复制下面的配置信息
SH 复制代码
[Unit]
Deion=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

按 ESC,输入 :wq 保存文件

  1. 创建服务
SH 复制代码
systemctl enable nginx.service
  1. 启动该服务
SH 复制代码
systemctl status nginx

四、结尾

如果你觉得本文对你有帮助,不妨给笔者点个免费的小赞支持一下下吧。

欢迎访问笔者的自建小站 依琴の小站 如果需要添加友联,不妨给我留个言吧。

相关推荐
奔跑中的小象2 分钟前
低版本 Linux 系统通过二进制方式升级部署高版本 Docker
linux·docker
极客代码9 分钟前
Linux IPC:System V共享内存汇总整理
linux·c语言·开发语言·并发·共享内存·通信·system v
Dusk_橙子12 分钟前
在运维工作中,Lvs、nginx、haproxy工作原理分别是什么?
运维·nginx·lvs
小wanga25 分钟前
【Linux】网络层、数据链路层、DNS、ICMP协议、NAT技术
linux·运维·网络
火车叼位1 小时前
命令`ls **/*.exe`遗漏本目录下文件?Bash的globstar配置了解一下
linux·shell
IT成长日记1 小时前
Ansible运行原理揭秘:如何用YAML脚本掌控数服务器?
运维·服务器·ansible·架构与原理
千羽星弦1 小时前
Jenkins在Windows上的使用(二):自动拉取、打包、部署
运维·windows·jenkins
Ashmcracker1 小时前
Jenkins链接私有仓库Failed to connect to repository,stderr: No ECDSA...的问题
运维·jenkins·devops
嵌入式-老费2 小时前
Linux上位机开发实战(x86和arm自由切换)
linux·运维·arm开发
猪猪侠|ZZXia2 小时前
# linux有哪些显示服务器协议、显示服务器、显示管理器、窗口管理器?有哪些用于开发图形用户界面的工具包?有哪些桌面环境?
linux·服务器