安装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;    
    }
相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
8月前
|
缓存 负载均衡 JavaScript
Nginx:高性能Web服务器与反向代理利器
Nginx:高性能Web服务器与反向代理利器
386 110
|
8月前
|
缓存 负载均衡 前端开发
Nginx:高性能的Web服务器与反向代理利器
Nginx:高性能的Web服务器与反向代理利器
421 99
|
6月前
|
监控 关系型数据库 MySQL
在CentOS系统中,如何统计哪个进程打开了文件描述符?
利用上述方法,你可以有效地监控和统计CentOS系统中的进程打开的文件描述符数量,以帮助排查错误或优化系统配置。通过组合使用各种工具和命令,可以获得对系统状态和行为的深入了解,进而做出相应的调整和
290 5
|
8月前
|
缓存 负载均衡 前端开发
Nginx:高性能Web服务器的核心引擎
Nginx:高性能Web服务器的核心引擎
270 47
|
7月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
401 18
|
7月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
663 17
|
缓存 关系型数据库 MySQL
百度搜索:蓝易云【CentOS8服务器安装MySQL报错:no match mysql-community-server】
现在,你已经成功安装了MySQL服务器并解决了"no match mysql-community-server"的报错问题。祝你使用愉快!
507 1
|
Linux 数据库管理 Python
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
CentOS7编译安装Python3.10(含OpenSSL1.1.1安装),创建虚拟环境,运行Django项目(含sqlite版本报错)
2413 4
|
网络协议 Linux
CentOS7 yum安装报错“Could not resolve host: mirrorlist.centos.org;"之解决办法(换源)
CentOS7 yum安装报错“Could not resolve host: mirrorlist.centos.org; Name or service not known“之解决办法(换源)
|
缓存 Linux 编译器
【C++】CentOS环境搭建-安装log4cplus日志组件包及报错解决方案
通过上述步骤,您应该能够在CentOS环境中成功安装并使用log4cplus日志组件。面对任何安装或使用过程中出现的问题,仔细检查错误信息,对照提供的解决方案进行调整,通常都能找到合适的解决之道。log4cplus的强大功能将为您的项目提供灵活、高效的日志管理方案,助力软件开发与维护。
681 0