ubuntu/centos下载、安装与配置nginx

本文涉及的产品
云防火墙,500元 1000GB
简介: ubuntu/centos下载、安装与配置nginx

1.版本区别

常用版本分为四大阵营:

2.安装nginx

2.1 下载安装包

🏠 访问:Tags · nginx/nginx (github.com)

2.2 上传至 linux

2.3 解压缩

sudo tar zxvf nginx-release-1.21.6.tar.gz
# 可以查看到一个 nginx-release-1.21.6 目录
sudo ls -l
# 进入该目录
cd nginx-release-1.21.6/

2.4 环境配置

🍀 ubuntu下的配置

sudo apt update
# 安装一系列软件包,包括gcc,g++,和make。
sudo apt install build-essential
sudo apt-get install libpcre3 libpcre3-dev
sudo apt-get install zlib1g-dev 

🍀 Centos下的配置

yum install -y gcc
yum install -y pcre pcre-devel
yum install -y zlib zlib-devel

2.5 编译安装

# 用 configure 脚本安装,并放到 /usr/local 下
sudo ./auto/configure --prefix=/usr/local/nginx
sudo make
sudo make install

2.4 校验安装成功

# 在 /usr/local 目录下有 nginx 文件夹
sudo ls -l /usr/local/
# 在 nginx 文件夹下有 conf,html,logs,sbin
sudo ls -l /usr/local/nginx/

3.启用nginx

3.1 防火墙打开80端口

🍀 ubuntu下的打开

sudo apt update
sudo apt install ufw
# 打开防火墙,输 y(关闭防火墙:sudo ufw disable)
sudo ufw enable
# 允许80端口访问(tcp/udp)
sudo ufw allow 80
# 重启生效
sudo ufw reload

🍀 Centos下的打开

# 允许80端口访问
firewall-cmd --zone=public --add-port=80/tcp --permanent、
# 重启防火墙生效
systemctl restart firewall.service

3.2 启动

# 进入安装好的目录 /usr/local/nginx/sbin
cd /usr/local/nginx/sbin
# 修改配置文件
sudo vim /usr/local/nginx/conf/nginx.conf

将 pid 的注释取消:

# 【需要执行一下】指定配置目录,该命令会同时启动nginx,因此如果再 sudo ./nginx 会报端口已被占用
sudo ./nginx -c /usr/local/nginx/conf/nginx.conf
# 启动
sudo ./nginx 
# 快速停止
sudo ./nginx -s stop
# 优雅关闭,在退出前完成已经接受的连接请求
sudo ./nginx -s quit
# 重新加载配置
sudo ./nginx -s reload 

3.3 访问测试

🏠 访问:http://【Linux 的 IP】:80/

4.安装成系统服务

必须先将nginx服务停止,原命令与系统服务脚本会有冲突:

/usr/local/nginx/sbin/nginx -s stop

4.1 创建服务脚本

sudo vim /usr/lib/systemd/system/nginx.service

服务脚本内容:

# 主要用于设置该服务单元的描述和启动顺序
[Unit]
# 描述了该服务单元的作用
Description=nginx - web server
# 表示该服务单元依赖于哪些其他服务单元
After=network.target remote-fs.target nss-lookup.target
# 主要用于设置该服务单元的启动参数和命令
[Service]
# 指定该服务单元的类型
Type=forking
# 指定该服务单元的进程 ID 文件所在位置
PIDFile=/usr/local/nginx/logs/nginx.pid
# 表示在服务单元启动前需要执行的命令,该命令在启动服务前会检查配置文件的正确性。
ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
# 表示启动服务的命令
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
# 表示重新加载配置文件的命令
ExecReload=/usr/local/nginx/sbin/nginx -s reload
# 表示停止服务的命令,等待正在处理的请求完成后再停止服务
ExecStop=/usr/local/nginx/sbin/nginx -s stop
# 表示停止服务的命令,不等待正在处理的请求完成后再停止服务
ExecQuit=/usr/local/nginx/sbin/nginx -s quit
# 表示是否为该服务单元创建私有的临时文件系统。
PrivateTmp=true
# 主要用于设置该服务单元的启动级别
[Install]
# 指定该服务单元所属的启动级别,这里指定为 multi-user.target,表示在多用户模式下启动该服务单元
WantedBy=multi-user.target

4.2 重新加载系统服务

sudo systemctl daemon-reload

4.3 服务指令

# 停止服务
sudo systemctl stop nginx.service
# 启动服务
sudo systemctl start nginx.service
# 开机启动
sudo systemctl enable nginx.service
# 关闭开机自启动
sudo systemctl disable nginx.service
# 重启服务
sudo systemctl restart nginx.service
# 查看nginx状态
sudo systemctl status nginx.service


相关文章
|
12天前
|
Ubuntu Linux Docker
Ubuntu 18.04 安装Docker实战案例
关于如何在Ubuntu 18.04系统上安装Docker的实战案例,包括安装步骤、配置镜像加速以及下载和运行Docker镜像的过程。
81 3
Ubuntu 18.04 安装Docker实战案例
|
12天前
|
Linux
CentOS 7.x时间同步服务chrony配置详解
文章详细介绍了在CentOS 7.x系统中如何安装和配置chrony服务,以及它与ntpd服务的对比,强调了chrony在时间同步方面的高效性和准确性。
30 1
CentOS 7.x时间同步服务chrony配置详解
|
12天前
|
Ubuntu 网络安全 开发工具
Ubuntu19.04的安装过程详解以及操作系统初始化配置
本文详细介绍了Ubuntu 19.04操作系统的安装过程、初始化配置、网络设置、软件源配置、SSH远程登录以及终端显示设置。
36 1
Ubuntu19.04的安装过程详解以及操作系统初始化配置
|
11天前
|
Ubuntu Oracle 关系型数据库
Oracle VM VirtualBox之Ubuntu 22.04LTS双网卡网络模式配置
这篇文章是关于如何在Oracle VM VirtualBox中配置Ubuntu 22.04LTS虚拟机双网卡网络模式的详细指南,包括VirtualBox网络概述、双网卡网络模式的配置步骤以及Ubuntu系统网络配置。
38 3
|
11天前
|
Ubuntu 开发工具 虚拟化
MacOS系统基于VMware Fusion配置Ubuntu 22.04LTS环境
这篇文章介绍了如何在MacOS系统上使用VMware Fusion虚拟化软件配置Ubuntu 22.04 LTS环境,包括自定义VMware Fusion网段、Ubuntu系统安装、配置root用户登录、设置静态IP地址、修改默认网卡名称、配置PS1变量、设置登录界面为字符界面、修改软件源和进行vim基础优化等步骤。
33 2
|
12天前
|
Ubuntu NoSQL
ubuntu上安装某个程序的符号表和源码包
ubuntu上安装某个程序的符号表和源码包
|
12天前
|
Ubuntu
在树莓派4B上安装ubuntu系统
在树莓派4B上安装ubuntu系统
|
12天前
|
Ubuntu
树莓派 —— ubuntu上通过netplan配置网络
树莓派 —— ubuntu上通过netplan配置网络
|
12天前
|
Ubuntu
使用dpkg在ubuntu上安装软件包遇到依赖包的问题
使用dpkg在ubuntu上安装软件包遇到依赖包的问题
|
9天前
|
存储 Ubuntu 网络安全
在Ubuntu系统下通过Caddy实现LXD的安装与部署
通过上述步骤,您可以在Ubuntu系统下通过Caddy实现LXD的安装与部署。这种方法不仅可以提高容器管理的效率,还可以借助Caddy的自动SSL管理功能提升安全性。
9 0