nginx安装

一、安装准备

1.1 资源准备

  • 查看系统版本 lsb_release -a
  • 可以看到我这里的操作系统是Linux Centos 7.7

 1.2 官方下载安装包

具体操作系统按实际情况进行选择,

1.3关闭SElinux

vi /etc/selinux/config
修改:SELINUX=disabled

1.4检测是否已安装

# 查看是否安装nginx
rpm -qa | grep nginx
 
# 卸载前先停止nginx
systemctl stop nginx
 
#卸载
rpm -e nginx
 
#删除文件
rm -rf /etc/nginx/

二、依赖包安装

nginx安装依赖gcc-11.2.1、 g++-11.2.1、 perl-5.32.1、 pcre-8.44 、zlib-1.2.11 、openssl-3.0.1

2.1 yum安装

1、gcc 安装
安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装:
yum install gcc-c++
2、PCRE pcre-devel 安装
PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx也需要此库。命令:
yum install -y pcre pcre-devel
3、zlib 安装
zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 Centos 上安装 zlib 库。
yum install -y zlib zlib-devel
4、OpenSSL 安装
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。
nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 Centos 安装 OpenSSL 库。
yum install -y openssl openssl-devel
5、安装perl
yum install -y perl # 说明:perl安装成功后,会同时将g++、make等组件安装好,可以使用g++ -v命令测试。

2.2 rpm离线安装

1、安装gcc
下载地址:

官网:https://gcc.gnu.org/releases.html
阿里云镜像站:http://mirrors.aliyun.com/centos/7/os/x86_64/Packages/
CentOS 镜像站点:https://vault.centos.org/7.5.1804/os/x86_64/Packages/

只需下载如下依赖即可:
cpp-4.8.5-44.el7.x86_64.rpm
gcc-4.8.5-44.el7.x86_64.rpm
glibc-devel-2.17-317.el7.x86_64.rpm
glibc-headers-2.17-317.el7.x86_64.rpm
kernel-headers-3.10.0-1160.el7.x86_64.rpm
libmpc-1.0.1-3.el7.x86_64.rpm
mpfr-3.1.1-4.el7.x86_64.rpm
----------------------------------------------
gcc-c++-4.8.5-44.el7.x86_64.rpm
libstdc++-4.8.5-44.el7.x86_64.rpm
libstdc++-devel-4.8.5-44.el7.x86_64.rpm

安装

[root@CentOS-1 home]#rpm -ivh mpfr-3.1.1-4.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh libmpc-1.0.1-3.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh kernel-headers-3.10.0-862.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh glibc-headers-2.17-222.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh glibc-devel-2.17-222.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh cpp-4.8.5-28.el7.x86_64.rpm
[root@CentOS-1 home]#rpm -ivh gcc-4.8.5-28.el7.x86_64.rpm

或rpm -ivh *.rpm --nodeps --force

# 安装包以及依赖,需要大家提前准备好 gcc
-11.2.1-9.4.el9.x86_64.rpm cpp-11.2.1-9.4.el9.x86_64.rpm # 安装命令 rpm -Uvh gcc-11.2.1-9.4.el9.x86_64.rpm --nodeps --force rpm -Uvh cpp-11.2.1-9.4.el9.x86_64.rpm --nodeps --force # 使用下面命令验证gcc安装是否成功,如果看到对应的版本信息,表示安装成功
验证:
使用gcc-v和g++ -v命令查看版本

 

2.3 二进制安装

1、openss安装
wget http://www.openssl.org/source/openssl-fips-2.0.13.tar.gz
解压 tar -zxvf openssl-fips-2.0.13.tar.gz
安装openssl
./config --prefix=/usr/local/openssl
 make && make install

2、pcre安装
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.38.tar.gz 或 http://www.pcre.org/
解压 tar -zxvf pcre-8.38.tar.gz
安装pcre
./configure --prefix=/usr/local/pcre
  make && make install

3、zlib安装
wget http://zlib.net/zlib-1.2.8.tar.gz 
解压 tar -zxvf zlib-1.2.8.tar.gz
安装zlib
 ./configure --prefix=/usr/local/zlib
 make && make install
4、gcc安装
wget http://ftp.gnu.org/gnu/gcc/gcc-13.1.0/gcc-13.1.0.tar.gz
解压 gcc-13.1.0.tar.gz
安装gcc
参考:https://blog.csdn.net/fy291021851/article/details/121492888

三、离线安装

3.1 rpm离线安装

3.1.1 检查环境

  • 检查命令:rpm -ivh --test nginx-1.20.1-1.el7.ngx.x86_64.rpm
  • --test表示仅检查安装环境不实际安装,若正常,提示如下图:

 3.1.2安装

首次安装nginx,需要使用root用户进行安装、检查等操作后,最后再授权给nginx用户,安装命令:

rpm -ivh nginx-1.20.1-1.el7.ngx.x86_64.rpm

3.1.3 检查是否安装成功

rpm -qa | grep nginx

 3.1.4 配置nginx

1、配置权限

nginx的rpm安装包,其实就是一个很多文件的压缩包,使用root用户安装后,这些目录、文件很多都是root权限的,需要重新授权给nginx或者普通用户。

查看rpm安装包列表清单:rpm -qpl nginx-1.20.1-1.el7.ngx.x86_64.rpm

复制列表清单授权给nginx用户 授权格式:chown -R 用户名:用户组名 资源路径:

 

chown -R nginx:nginx /etc/logrotate.d/nginx
chown -R nginx:nginx /etc/nginx
chown -R nginx:nginx /etc/nginx/conf.d
chown -R nginx:nginx /etc/nginx/conf.d/default.conf
chown -R nginx:nginx /etc/nginx/fastcgi_params
chown -R nginx:nginx /etc/nginx/mime.types
chown -R nginx:nginx /etc/nginx/modules
chown -R nginx:nginx /etc/nginx/nginx.conf
chown -R nginx:nginx /etc/nginx/scgi_params
chown -R nginx:nginx /etc/nginx/uwsgi_params
chown -R nginx:nginx /usr/lib/systemd/system/nginx-debug.service
chown -R nginx:nginx /usr/lib/systemd/system/nginx.service
chown -R nginx:nginx /usr/lib64/nginx
chown -R nginx:nginx /usr/lib64/nginx/modules
chown -R nginx:nginx /usr/libexec/initscripts/legacy-actions/nginx
chown -R nginx:nginx /usr/libexec/initscripts/legacy-actions/nginx/check-reload
chown -R nginx:nginx /usr/libexec/initscripts/legacy-actions/nginx/upgrade
chown -R nginx:nginx /usr/sbin/nginx
chown -R nginx:nginx /usr/sbin/nginx-debug
chown -R nginx:nginx /usr/share/doc/nginx-1.20.1
chown -R nginx:nginx /usr/share/doc/nginx-1.20.1/COPYRIGHT
chown -R nginx:nginx /usr/share/man/man8/nginx.8.gz
chown -R nginx:nginx /usr/share/nginx
chown -R nginx:nginx /usr/share/nginx/html
chown -R nginx:nginx /usr/share/nginx/html/50x.html
chown -R nginx:nginx /usr/share/nginx/html/index.html
chown -R nginx:nginx /var/cache/nginx
chown -R nginx:nginx /var/log/nginx

 

2.目录变更

使用root用户基于rpm安装包安装完成后,切回nginx用户
为了方便后续的日志备份以及更灵活的部署前端静态资源,建议重新规划日志目录和静态资源目录
创建日志目录和静态资源目录
mkdir -p /usr/nginx/logs/nginx
mkdir -p /usr/nginx/nginx/html

将rpm安装包初始化的nginx欢迎页面,拷贝到静态资源路径下
cp /usr/share/nginx/html/50x.html /usr/nginx/nginx/html/50x.html
cp /usr/share/nginx/html/index.html /usr/nginx/nginx/html/index.html

 3.重要目录说明

/etc/nginx nginx默认配置文件的目录

nginx.conf nginx主配置文件,文件最后配置了自动加载conf.d下*.conf的配置
/etc/nginx/conf.d nginx的*.conf多个子配置存放目录

default.conf nginx子配置文件,主要用于端口端口、日志、负载均衡、反向代理等配置。
/usr/sbin/nginx 可执行二进制文件,nginx的启停等执行命令前缀

/usr/share/nginx/html 静态资源目录
本文这里已经改为/usr/nginx/nginx/html

/var/log/nginx 日志文件存放目录
本文这里已经改为/usr/nginx/logs/nginx

4.配置default.conf

  • 修改nginx监听端口,这里以10080端口为例,具体端口根据实际项目需要进行修改。
  • 创建10080.conf
cd /etc/nginx/conf.d
cp default.conf default.conf.bak
mv default.conf 10080.conf

修改10080.conf
主要修改对应的端口号日志路径静态资源路径,如下截图

 5.配置nginx.conf

  • 备份nginx.conf

 cd /etc/nginx/

cp nginx.conf nginx.conf.bak

  •  修改nginx.conf

同样主要修改日志路径nginx进程文件,如下截图:

 6.启动

  • 查看nginx运行进程 ps -ef|grep nginx
  1. 存在nginx的运行进程,表明nginx服务正在运行中
  • 如果nginx已经处于运行状态,那么不需要重启nginx,只需要刷新nginx配置即可,刷新配置前先检查下nginx配置是否正确,检查命令 nginx -t,配置正确则刷新nginx配置,刷新命令 nginx -s reload
  1. 如果nginx处于未运行状态,先检查下nginx配置是否正确,检查命令 nginx -t,配置正确则直接启动nginx,启动命令为 nginx或/usr/sbin/nginx
  2. –说明:
  3. 普通用户nginx,启动nginx时,可能会提示如下警告信息:
  4. nginx:[warn] ***
  5. 表示nginx: master process主进程只能对超级用户root生效即root启动nginx时生效,该
  6. 警告不影响nginx的正常使用。
  • nginx其他常用命令
  1. nginx -s stop 停止 nginx
  2. nginx -s reload 刷新nginx配置(不重启nginx的情况下,重新加载最新nginx配置文件)
  3. nginx -s reopen 新开nginx日志(不重启的情况下,当access.log等日志文件不存在时会新生成对应日志文件)

3.2二进制安装

3.2.1解压

依然是直接命令:

tar -zxvf nginx-1.20.1.tar.gz
cd nginx-1.20.1

3.2.2配置

1.使用默认配置

./configure

2.自定义配置(不推荐)

./configure \
--prefix=/usr/local/nginx \
--conf-path=/usr/local/nginx/conf/nginx.conf \
--pid-path=/usr/local/nginx/conf/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi

注:将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录

3.自定义配置2

 ./configure \
--with-pcre=/root/pcre-8.38 \ --with-zlib=/root/zlib-1.2.8 \
--with-openssl=/root/openssl-fips-2.0.13 \
--prefix=/usr/local/nginx \
--with-http_stub_status_module \
--with-http_ssl_module

注意 :

  • --with-后面的路径是对应的解压后的路径
  • 举例:--with-pcre=/root/pcre-8.38
  • /root/pcre-8.38 是pcre解压的目录
  • make 和 make install 推荐分开执行(上面所有的)
  • 注意--prefix,是nginx 安装的目录
  • -with-http_stub_status_module --with-http_ssl_module:安装ssl证书 添加两个模块

3.2.3编译安装

make
make install

查找安装路径:

whereis nginx

3.2.3检测nginx是否安装成功

cd  /usr/local/nginx/sbin
./nginx -t
出现成功提示

3.2.4判断配置文件是否正确

1、判断配置文件是否正确 
/usr/local/nginx/sbin -t /usr/local/nginx/conf/nginx.conf
2、启动服务 -c 指定配置文件路径
/usr/local/nginx/sbin  -c /opt/nginx/conf/nginx.conf 
或 /usr/local/nginx/sbin -t -c /usr/local/nginx/conf/nginx.conf

 

3.2.5启动、停止nginx

cd /usr/local/nginx/sbin/
./nginx
./nginx -s stop
./nginx -s quit
./nginx -s reload

./nginx -s quit:此方式停止步骤是待nginx进程处理任务完毕进行停止。
./nginx -s stop:此方式相当于先查出nginx进程id再使用kill命令强制杀掉进程。

查询nginx进程:
ps aux|grep nginx

重启 nginx
1.先停止再启动(推荐):
对 nginx 进行重启相当于先停止再启动,即先执行停止命令再执行启动命令。如下:
./nginx -s quit
./nginx
2.重新加载配置文件:
当 ngin x的配置文件 nginx.conf 修改后,要想让配置生效需要重启 nginx,使用-s reload不用先停止 ngin x再启动 nginx 即可将配置信息在 nginx 中生效,如下:
./nginx -s reload

3.2.5开机自启动

第一步:进入到/lib/systemd/system/目录
[root@edge-01 ~]# cd /lib/systemd/system/

第二步:创建nginx.service文件,并编辑
# vim nginx.service
内如如下:
[Unit]
Description=nginx service
After=network.target 
   
[Service] 
Type=forking 
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true 
   
[Install] 
WantedBy=multi-user.target

说明:
[Unit]:服务的说明
Description:描述服务
After:描述服务类别
[Service]服务运行参数的设置
Type=forking是后台运行的形式
ExecStart为服务的具体运行命令
ExecReload为重启命令
ExecStop为停止命令
PrivateTmp=True表示给服务分配独立的临时空间
注意:[Service]的启动、重启、停止命令全部要求使用绝对路径
[Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3

保存退出。
第三步:加入开机自启动

# systemctl enable nginx   开机自启动
# systemctl disable nginx   取消开机自启动

第四步:服务的启动/停止/刷新配置文件/查看状态
# systemctl start nginx.service          启动nginx服务
# systemctl stop nginx.service           停止服务
# systemctl restart nginx.service        重新启动服务
# systemctl list-units --type=service     查看所有已启动的服务
# systemctl status nginx.service          查看服务当前状态
# systemctl enable nginx.service          设置开机自启动
# systemctl disable nginx.service         停止开机自启动

备注:启动提示“Warning: nginx.service changed on disk. Run 'systemctl daemon-reload' to reload units.”时,执行“systemctl daemon-reload"即可

3.2.6协助nginx

## 停止nginx服务
ps -ef|grep nginx
## 删除进程
kill 进程Id
/usr/local/nginx/sbin/nginx -s stop
## 删除ngxin文件
whereis nginx
find / -name nginx
rm -rf /usr/local/nginx
## 卸载nginx依赖
yum remove nginx

3.3 yum安装nginx

3.3.1添加Nginx到YUM源

vim /etc/yum.repos.d/nginx.repo

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true


[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1




说明:添加CentOS 7 Nginx yum资源库:rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

3.3.2检查yum源配置

yum list |grep nginx

3.3.3列出所以nginx版本

yum list nginx --showduplicates

3.3.4安装制定版本

安装指定的版本
yum -y install nginx-1.18.0-2.el7.ngx
查看nginx安装包信息 或者 nginx版本
rpm -qi nginx 或者 nginx -v

3.3.5配置文件

/usr/share/nginx/html 网站文件默认存放目录
/etc/nginx/conf.d/default.conf   默认站点配置 
/etc/nginx/conf.d/       自定义nginx站点配置文件目录
/etc/nginx/nginx.conf 全局配置

可以看一下全局配置都在这里面

3.3.6启动

systemctl start nginx.service
查看一下是否启动成功
ps -ef |grep nginx

 

 

 

 

 

posted on 2023-05-19 11:41  uestc2007  阅读(180)  评论(0编辑  收藏  举报

导航