linux系统离线安装nginx

本文详细介绍了如何下载、安装Nginx,以及检查并安装必要的环境依赖(如GCC、PCRE、Zlib和OpenSSL),最后配置Nginx开机自启动,确保高性能Web服务器的稳定运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

介绍:nginx是一个高性能的http和反向代理服务器,并发能力很强,一般用来做负载均衡比较多,日常开发中用作web服务器

说明:本文用到的所有资源,笔者已经打包上传了,需要下载的请于文章顶部下载

一、下载nginx

地址:nginx: download

我们下载这个稳定版本

 二、环境依赖检查

nginx安装需要很多外部依赖,先登录到linux服务器

2.1 gcc检查

gcc -v

 出现如下,说明gcc是安装了的

如果最后一行没有出现对应gcc版本信息,那就要去手动下载了 ,下面的部分是下载安装各种依赖

提供个阿里云镜像地址:centos-7-os-x86_64-Packages安装包下载_开源镜像站-阿里云

gcc 清单 

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

 一个个找到下载,小技巧:可以直接复制名字定位,ctrl+f

把下载好的gcc依赖统一上传到服务器的某个文件夹下,或者把笔者提供的zip包上传上去,解压即可,以下是几个解压相关的命令

如果没有安装unzip命令,可以通过以下命令在大多数Linux发行版中安装(需要连接网络): 

sudo apt install unzip # 对于基于Debian的发行版(如Ubuntu)
sudo yum install unzip # 对于基于RPM的发行版(如Fedora、CentOS)

1.解压缩zip文件到当前目录:

unzip file.zip

2.解压缩zip文件到指定目录:

unzip file.zip -d /path/to/directory 

3. 查看zip文件内容而不解压缩:

unzip -l file.zip 

不想安装unzip工具,那就把下载的几个依赖都单独上传到linux服务器同一个文件夹下即可,即不用压缩上传再解压

然后在这个文件夹下执行以下命令

rpm -Uvh *.rpm --nodeps --force

2.2 PCRE检查

以下是百度百科的介绍

PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括perl 兼容的正则表达式库。这些在执行正规表达式模式匹配时用与Perl 5同样的语法和语义是很有用的。Boost太庞大了,使用boost regex后,程序的编译速度明显变慢。测试了一下,同样一个程序,使用boost::regex编译时需要3秒,而使用pcre不到1秒。因此改用pcre来解决C语言中使用正则表达式的问题

为什么要这个库?因为nginx是使用C语言开发的,为了实现高性能,用到了这个库

在服务器上执行

rpm -qa | grep pcre

可以看到笔者的服务器已经安装了这个依赖 

如果没有出现这些信息说明没有安装,需要自行下载 

下载地址:https://www.pcre.org/

点进去有个版本介绍

翻译下:

PCRE库有两个主要版本。目前的版本PCRE2于2015年发布,目前为10.39版本。

较早但仍广泛部署的PCRE库最初于1997年发布,版本为8.45。这一版本的PCRE现在已经寿终正寝,不再积极维护。8.45版本预计将是旧的PCRE库的最终版本,新项目应该使用PCRE2。

 继续点击这个,外网有点慢

有很多版本,这里以最新版举例

 

下载下来后上传到linux服务器某个文件夹下(笔者已上传资源包)

执行解压命令

tar -xvf pcre2-10.43.tar.gz 

cd进入解压后的目录下依次执行

./configure (后面可加 --prefix=yourpath,安装到指定路径,一般不加,就安装到默认路径下)
make
make install

2.3 zlib检查

百度介绍:

zlib是一种用于数据压缩和解压缩的开源软件库。它使用的是压缩算法为DEFLATE,可以有效地压缩和解压缩大部分数据。

zlib可以被广泛应用于许多不同的场合,例如软件安装包的压缩、数据库文件的压缩、网络数据传输的压缩等。它的使用方法简单,支持多种编程语言,且具有较高的压缩率和解压率。

zlib的优点是可以有效地压缩和解压缩大部分数据,使用方法简单,支持多种编程语言,并且具有较高的压缩率和解压率。缺点是压缩率不如其他一些算法高,例如bzip2和LZMA。

zlib是一个轻量级的库,可以在不同的系统平台上使用。它的源代码可以在网络上免费下载,并且具有较高的可移植性。zlib支持的压缩格式为DEFLATE,可以有效地压缩和解压缩大部分数据。

zlib提供了一组简单的函数来实现数据的压缩和解压缩。它支持多种编程语言,例如C、C++、Java、Python等,可以方便地在这些语言中使用。zlib提供的函数包括压缩数据的compress函数和解压缩数据的uncompress函数。这两个函数的使用方法非常简单,只需要提供待压缩或解压缩的数据和目标缓冲区的地址即可。

zlib还提供了一些高级的函数,可以支持更复杂的压缩和解压缩操作。例如,可以使用deflateInit、deflate和deflateEnd函数来进行流式压缩,可以使用inflateInit、inflate和inflateEnd函数来进行流式解压缩。

总的来说,zlib是一种非常方便的数据压缩和解压缩工具,它可以有效地压缩和解压缩大部分数据,并且使用方法简单,支持多种编程语言。

在服务器上执行

rpm -qa | grep zlib 

笔者所在linux系统已经安装zlib 

没有如上信息,要下载安装

地址:zlib Home Site

zlib是这两位开发的,前者写压缩算法,后者写解压缩算法

往下划 ,找到这个点击下载

下载好后上传到服务器某文件夹下

执行解压命令

tar -zxvf zlib.tar.gz

再cd 到解压后的zlib目录顺序执行

./configure (后面可加 --prefix=yourpath,安装到指定路径,一般不加,就安装到默认路径下)
make
make install 

2.4  openssl检查

服务器上输入

openssl version

很抱歉,笔者的服务器也已经安装了openssl,你如果没有出现对应信息,需要自己下载安装

下载地址:[ Downloads ] - /source/index.html 

这里举例下载的是这个最新版

下载好后,同样的上传到服务器某个文件夹下解压

执行命令

tar -zxvf openssl-3.3.0.tar.gz 

然后进入解压目录依次执行如下

 ./configure (后面可加 --prefix=yourpath,安装到指定路径,一般不加,就安装到默认路下)
make
make install

三、安装nginx 

以上外部依赖都准备好后,可以安装nginx了

首先把下载的nginx压缩包上传到服务器某文件下,笔者这里上传到/opt/nginx下

依次执行如下命令 

cd /opt/nginx

tar -zxvf nginx-1.24.0.tar.gz

cd nginx-1.24.0/

进入解压后的文件夹下执行如下,这里配置安装到/usr/local下

./configure  (--prefix=/usr/local/nginx,这是指定安装到某个路径下,如果不指定,则默认也是安装到这个路径下,没有nginx文件夹会自动创建)
make
make install

我这里执行完第一句报错了,我重新安装下PCRE库(按照上述pcre流程来)

安装好后再进入nginx的解压目录

执行这个./configure

make

make install

四、启动nginx

接着启动nginx

cd /usr/local/nginx/sbin/

./nginx

 nginx的默认启动端口是80

输入以下命令查看端口80

sudo lsof -i :80

可以看到80端口被nginx监听了 

 把80端口的访问权限打开

-- 开通 80 端口 访问权限

sudo firewall-cmd --permanent --add-port=80/tcp

-- 重载防火墙

sudo firewall-cmd --reload

浏览器访问下:192.168.19.16:80 ,说明nginx启动成功了

修改端口,比如改成8081(注意先把8081端口的防火墙开启,命令参考上面)

cd /usr/local/nginx/conf

vim nginx.conf 

按 i 键,把监听端口改成8081

esc 退出,输入:wq 保存

再执行以下命令

cd /usr/local/nginx/sbin/

./nginx

这时候浏览器访问 192.168.19.16:8081,修改成功了

这里有个问题,之前的端口80,nginx服务我没有停用,浏览器打开192.168.19.16:80,还是可以访问的

 

服务器查看80和8081端口,发现都被nginx监听了 

既然修改了端口,那原先的不应该再监听了,杀死80端口对应nginx的pid

kill 22698

发现80端口不再被nginx监听,释放出来了,浏览器也无法访问 

 到这里nginx 已经启动好了

五、设置开机自启动

这里采用Systemd方式,把nginx作为系统服务,设置开机自启动

首先执行以下命令

sudo vim /etc/systemd/system/nginx.service

创建一个nginx系统服务文件,按 i 键并输入以下内容,esc键退出,:wq保存

注意 /usr/local/nginx要替换成自己的nginx的安装路径(不是解压路径)

nginx -s quit # 这种方法较stop相比就比较温和,需要进程完成当前工作后再停止。

nginx -s stop # 立即停止服务 这种方法比较强硬,无论进程是否在工作,都直接停止进程

如果想温和退出nginx,ExecStop换成如下

ExecStop=/usr/local/nginx/sbin/nginx -s quit

[Unit]
Description=The nginx HTTP and reverse proxy server
After=network.target

[Service]
Type=forking
ExecStartPre=/usr/local/nginx/sbin/nginx -t
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop

[Install]
WantedBy=multi-user.target

以上保存退出后依次执行以下命令

先把之前启动的nginx服务进程杀掉

刷新配置

sudo systemctl daemon-reload

允许nginx自启动

sudo systemctl enable nginx.service

启动nginx

sudo systemctl start nginx.service

查看开机自启动的服务列表

systemctl list-units --type=service

查看nginx服务的状态

sudo systemctl status nginx.service

 浏览器输入 192.168.19.16:8081 是可以访问的

停止nginx服务

sudo systemctl stop nginx.service 

reboot重启验证nginx是否开机自启动

### AS608指纹传感器与STM32的集成 AS608是一款广泛使用的光学指纹传感器,通常通过串口(UART)接口与微控制器通信。对于STM32平台,可以通过标准库或HAL库实现其驱动程序开发。 #### UART配置 在STM32中,AS608主要依赖于UART模块进行数据传输。以下是UART初始化的一个基本示例: ```c #include "stm32f1xx_hal.h" void MX_USART1_UART_Init(void) { huart1.Instance = USART1; huart1.Init.BaudRate = 9600; // 默认波特率设置为9600bps huart1.Init.WordLength = UART_WORDLENGTH_8B; huart1.Init.StopBits = UART_STOPBITS_1; huart1.Init.Parity = UART_PARITY_NONE; huart1.Init.Mode = UART_MODE_TX_RX; huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE; HAL_UART_Init(&huart1); } ``` 此部分代码用于初始化USART1外设,确保它能够以指定参数运行[^2]。 #### 数据包结构解析 AS608的数据交互基于特定命令帧格式完成。每一帧由起始字节、地址码、指令码以及校验和组成。发送给AS608的每条命令都需要遵循该协议。 以下是一个简单的函数模板用来构建并发送这些命令至传感器: ```c #define FINGERPRINT_STARTCODE (uint16_t)0xEF01 #define FINGERPRINT_ADDR ((uint8_t[]){0xFF, 0xFF, 0xFF, 0xFF}) // 发送命令到AS608 int sendFingerprintCommand(uint8_t cmdPacket[], uint16_t packetLen){ int i=0; while(i<packetLen){ HAL_UART_Transmit(&huart1,&cmdPacket[i],1,100); i++; } return i; } // 构建完整的命令包 void buildAndSendCmd(uint8_t commandCode,uint8_t paramCount,uint8_t params[]){ uint8_t cmdPacket[12]; uint16_t checksum=0; memcpy(cmdPacket,FINGERPRINT_ADDR,sizeof(FINGERPRINT_ADDR)); cmdPacket[sizeof(FINGERPRINT_ADDR)]=(FINGERPRINT_STARTCODE>>8)&0xFF; cmdPacket[sizeof(FINGERPRINT_ADDR)+1]=FINGERPRINT_STARTCODE&0xFF; cmdPacket[sizeof(FINGERPRINT_ADDR)+2]=(paramCount+4)>>8 & 0xFF ; cmdPacket[sizeof(FINGERPRINT_ADDR)+3]=(paramCount+4) & 0xFF ; cmdPacket[sizeof(FINGERPRINT_ADDR)+4]=commandCode; for(int j=0;j<paramCount;j++){ cmdPacket[sizeof(FINGERPRINT_ADDR)+5+j]=params[j]; checksum+=params[j]; } checksum +=(paramCount+4)+(commandCode+FINGERPRINT_STARTCODE); cmdPacket[sizeof(FINGERPRINT_ADDR)+5+paramCount]=(checksum >>8 )&0xFF; cmdPacket[sizeof(FINGERPRINT_ADDR)+5+paramCount+1]=checksum &0xFF; sendFingerprintCommand(cmdPacket,sizeof(cmdPacket)); } ``` 以上代码片段展示了如何创建一个通用的方法来封装向AS608发出的各种请求操作[^3]。 #### 接收响应处理 当接收到来自AS608的消息时,则需按照相同的帧格式对其进行解码分析。这一步骤同样重要,因为只有正确理解返回的结果才能进一步采取行动。 ---
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值