安装Centos Nginx服务器系统,学习Nginx的配置文件的实践

简介: 安装Centos Nginx服务器系统,学习Nginx的配置文件的实践

hello.大家好,我来自内蒙古师范大学的恐龙小灰灰,通过同学介绍了解到飞天加速计划·高校学生在家实践活动。很高兴使用阿里云服务器环境来测试我的学习和应用。希望我的实践能够给大家带来帮助。

实践目的:
架设和配置安装Centos Nginx服务器环境,以及学习Nginx相关命令实践

使用系统:
服务器系统:Centos Nginx一个功能非常强大的web服务器

Centos Nginx系统安装:
服务器系统的安装,阿里云提供了很多傻瓜式的安装。购买阿里云的时候可以在系统一栏选择Nginx,如果购买时候选错了。不用急,也可以通过实例的控制面板可以快速选择到各版本的Centos Nginx,只需填写一个手机短信验证码一键完成安装自己想要得Nginx。安装完后要记得修改登陆密码。

链接Centos Nginx系统
我的客户端是windos系统,得使用SSH远程登录工具登陆系统。

学习Nginx的配置文件
nginx的配置信息在nginx.conf文件中,查看该文件,由以下模块组成:
1、main模块
2、event 模块
3、http模块
4、 基础配置
5、server模块
6、location模块

每个模块力具体配置选项的注释一并写到了代码里,大家认真学习哦

学习main模块的内容:

#main:全局信息的配置
#user nobody nobody;#user用来指定nginx worker进程运行用户以及用户组,默认nobody账号运行
worker_processes 8;#worker_processes指定nginx要开启的子进程数量,运行过程中监控每个进程消耗内存(一般几M~几十M不等)根据实际情况进行调整,通常数量是CPU内核数量的整数倍
# error_log G:/nginx-1.20.2/logs/error.log #error_log定义错误日志文件的位置及输出级别【debug / info / notice / warn / error / crit】
# error_log G:/nginx-1.20.2/logs/error.log notice
#error_log G:/nginx-1.20.2/logs/error.log info
# pid G:/nginx-1.20.2/logs/nginx.pid #pid用来指定进程id的存储文件的位置
#worker_rlimit_nofile 1024; #worker_rlimit_nofile用于指定一个进程可以打开最多文件数量的描述

学习event 模块

events {
    worker_connections  1024;#worker_connections 指定最大可以同时接收的连接数量,这里一定要注意,最大连接数量是和worker processes共同决定的。
    multi_accept on;#multi_accept 配置指定nginx在收到一个新连接通知后尽可能多的接受更多的连接
    use epoll;#use epoll 配置指定了线程轮询的方法,如果是linux2.6+,使用epoll,如果是BSD如Mac请使用Kqueue
}

学习http模块
这个模块是web应用,我主要用这个运行我的项目。需要重点掌握配置

http:用于进行http协议信息的一些配置

http {
    # 基础配置
    sendfile on;#配置on让sendfile发挥作用,将文件的回写过程交给数据缓冲去去完成,而不是放在应用中完成,这样的话在性能提升有有好处
    tcp_nopush on;#让nginx在一个数据包中发送所有的头文件,而不是一个一个单独发
    tcp_nodelay on;#让nginx不要缓存数据,而是一段一段发送,如果数据的传输有实时性的要求的话可以配置它,发送完一小段数据就立刻能得到返回值
    keepalive_timeout 65;#给客户端分配连接超时时间,服务器会在这个时间过后关闭连接。一般设置时间较短,可以让nginx工作持续性更好
    types_hash_max_size 2048;#混淆数据,影响三列冲突率,值越大消耗内存越多,散列key冲突率会降低,检索速度更快;值越小key,占用内存较少,冲突率越高,检索速度变慢
    # server_tokens off;
    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;
    #include /etc/nginx/mime.types;
    default_type application/octet-stream;
    # SSL证书配置
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;
    # 日志配置
    access_log G:/nginx-1.20.2/logs/ULife/access.log;# 日志配置
    error_log G:/nginx-1.20.2/logs/ULife/error.log;# 日志配置
    # Gzip 压缩配置
    gzip on;#是告诉nginx采用gzip压缩的形式发送数据。这将会减少我们发送的数据量。
    gzip_disable "msie6";#为指定的客户端禁用gzip功能。我们设置成IE6或者更低版本以使我们的方案能够广泛兼容。
    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/javascript
    #text/xml application/xml application/xml+rss text/javascript;#设置需要压缩的数据格式。上面例子中已经有一些了,你也可以再添加更多的格式。
    # 虚拟主机配置
    #include /etc/nginx/conf.d/*.conf;
    #include /etc/nginx/sites-enabled/*;

文件缓存配置模块
open_file_cache 打开缓存的同时也指定了缓存最大数目,以及缓存的时间。

open_file_cache_valid 在open_file_cache中指定检测正确信息的间隔时间。

open_file_cache_min_uses 定义了open_file_cache中指令参数不活动时间期间里最小的文件数。

open_file_cache_errors 指定了当搜索一个文件时是否缓存错误信息,也包括再次给配置中添加文件。我们也包括了服务器模块,这些是在不同文件中定义的。如果你的服务器模块不在这些位置,你就得修改这一行来指定正确的位置。

server模块配置信息如下:

server:一个虚拟主机的配置,一个http中可以配置多个server

server_name:用力啊指定ip地址或者域名,多个配置之间用空格分隔

root:表示整个server虚拟主机内的根目录,所有当前主机中web项目的根目录

index:用户访问web网站时的全局首页

charset:用于设置www/路径中配置的网页的默认编码格式

access_log:用于指定该虚拟主机服务器中的访问记录日志存放路径

error_log:用于指定该虚拟主机服务器中访问错误日志的存放路径

location模块

#location:用于进行访问路由的配置
        location / { #匹配访问根目录
            root   html; #用于指定访问根目录时,访问虚拟主机的web目录
            index  index.html index.htm; #在不指定访问具体资源时,默认展示的资源文件列表
            proxy_pass   https://www.baidu.com/;
        }

**upstream模块**
    upstream Ufile {
    ip_hash;#指定请求调度算法,默认是weight权重轮询调度,可以指定
    server 192.168.1.8:80 down;#分发服务器的列表配置
    server 192.168.1.8:81 ;
    server 192.168.1.8:82 max_fails=3;
    server 192.168.1.8:83 fail_timeout=20s;
    server 192.168.1.8:84 max_fails=3 fail_timeout=20s;    
    }
相关实践学习
通过日志服务实现云资源OSS的安全审计
本实验介绍如何通过日志服务实现云资源OSS的安全审计。
相关文章
|
5月前
|
存储 分布式计算 Linux
安装篇--CentOS 7 虚拟机安装
VMware 装 CentOS 7 不知道从哪下手?这篇超详细图文教程手把手教你在 VMware Workstation 中完成 CentOS 7 桌面系统的完整安装流程。从 ISO 镜像下载、虚拟机配置,到安装图形界面、设置用户密码,每一步都有截图讲解,适合零基础新手快速上手。装好之后无论你是要搭 Hadoop 集群,还是练 Linux ,这个环境都够你折腾一整天!
2233 4
|
5月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
386 18
|
5月前
|
安全 关系型数据库 MySQL
CentOS 7 yum 安装 MySQL教程
在CentOS 7上安装MySQL 8,其实流程很清晰。首先通过官方Yum仓库来安装服务,然后启动并设为开机自启。最重要的环节是首次安全设置:需要先从日志里找到临时密码来登录,再修改成你自己的密码,并为远程连接创建用户和授权。最后,也别忘了在服务器防火墙上放行3306端口,这样远程才能连上。
1148 16
|
5月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
419 15
|
存储 Ubuntu Linux
HPE SPP 2025.09.00.00 - HPE 服务器固件、驱动程序和系统软件包 (Released Oct 2025)
HPE SPP 2025.09.00.00 - HPE 服务器固件、驱动程序和系统软件包
198 0
|
6月前
|
域名解析 运维 监控
阿里云轻量服务器的系统镜像和应用镜像的区别
轻量应用服务器是阿里云推出的易用型云服务器,支持一键部署、域名解析、安全管理和运维监控。本文介绍其系统镜像与应用镜像的区别及选择建议,助您根据业务需求和技术能力快速决策,实现高效部署。
|
6月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
535 10
|
6月前
|
存储 Ubuntu Linux
VMware-安装CentOS系统教程及安装包
虚拟机相当于是一个独立于你电脑的环境,在这个环境上面,你可以安装Linux、Windows、Ubuntu等各个类型各个版本的系统,在这个系统里面你不用担心有病读等,不用担心文件误删导致系统崩溃。 虚拟机也和正常的电脑系统是一样的,也可以开关机,不用的时候,你关机就可以了,也不会占用你的系统资源,使用起来还是比较方便 这里也有已经做好的CentOS 7系统,下载下来解压后直接用VMware打开就可以使用
1241 69
|
6月前
|
Ubuntu Linux 索引
Centos 7、Debian及Ubuntu系统中安装和验证tree命令的指南。
通过上述步骤,我们可以在CentOS 7、Debian和Ubuntu系统中安装并验证 `tree`命令。在命令行界面中执行安装命令,然后通过版本检查确认安装成功。这保证了在多个平台上 `tree`命令的一致性和可用性,使得用户无论在哪种Linux发行版上都能使用此工具浏览目录结构。
565 78
|
7月前
|
Linux 网络安全 Apache
针对在Centos/Linux安装Apache过程中出现的常见问题集锦
以上每个问题的解决方案应深入分析错误日志、系统消息和各种配置文件,以找到根本原因并加以解决。务必保持系统和Apache软件包更新到最新版本,以修复已知的bugs和安全漏洞。安装和管理Web服务器是一项需要细致关注和不断学习的任务。随着技术的发展,推荐定期查看官方文档和社区论坛,以保持知识的更新。
316 80