Linux 《Nginx 运维基础入门》实验报告

本文详细介绍了如何在Ubuntu上安装和配置LNMP环境,涉及nginx的安装、配置,PHP与MySQL的集成,流量限制、并发连接控制、访问控制及DDoS防御措施。通过实例演示了配置更改和安全测试的过程。
摘要由CSDN通过智能技术生成
WechatIMG750.jpeg

环境

  • Ubuntu 16.04.7 LTS

  • Nginx 1.10.3

  • Mysql 5.7.33

  • PHP 7.0.33

安装LNMP环境

  • 安装 nginx
# 方式一:apt-get 安装
$  apt-get update && apt-get install -y nginx

# 方式二:源码安装
$ wget http://nginx.org/download/nginx-1.9.9.tar.gz
$ tar -zxvf nginx-1.9.9.tar.gz -C /usr/local/src
  • 浏览器访问
621dd69619e62_621dd69619e5c.png
  • 修改 nginx 配置文件
$ vim /etc/nginx/sites-available/default
# 这个模块的作用就是让php和nginx一起工作
location ~ \.php$ {
    limit_req zone=one burst=5 nodelay;   # 加入这行
    include snippets/fastcgi-php.conf;

    # With php7.0-cgi alone:
    fastcgi_pass 127.0.0.1:9000;
    # With php7.0-fpm:
    fastcgi_pass unix:/run/php/php7.0-fpm.sock;
}
  • 测试 nginx 配置文件是否正确
$ nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
  • nginx 常用命令
# 方式一
$ /etc/init.d/nginx start
$ /etc/init.d/nginx stop
$ /etc/init.d/nginx restart

# 方式二
$ service nginx start
$ service nginx stop
$ service nginx restart
  • 安装 mysql
$ apt-get install mysql-server mysql-client
  • 启动 mysql
$ service mysql start
  • 安装 php
$ apt-get install -y php7.0-fpm
  • 安装 php7.0-mysql 模块
$ apt-get install php7.0-mysql
  • 启动 php7.0-fpm 服务
$ service php7.0-fpm start
  • 验证 php 是否支持 mysql
$ php -m | grep mysql
mysqli
mysqlnd
pdo_mysql

Nginx配置文件详解

# nginx的用户,因为PHP默认是以www-data用户运行的。
user www-data;

# worker进程数量,这个优化值受到包括CPU内核数、存储数据的磁盘数、负载值在内的许多因素的影响。设置为auto,将会尝试自动检测可用的值。
worker_processes auto;

# nginx运行的父级进程号。
pid /run/nginx.pid;

# events模块包括了Nginx中处理链接的全部设置。
events {
    # 设置了一个worker进程可以同时打开的链接数。
    worker_connections 768;
    
    # 开启后Nginx在收到新链接的请求通知时,尽可能接受链接。
    # multi_accept on;
}

# http模块是处理请求的核心。
http {

    ##
    # Basic Settings
    ##
    
    # 直接从磁盘上读取数据到操作系统缓冲,开着就好。
    sendfile on;
    
    # 配置 Nginx 在一个包中发送全部的头文件,而不是一个一个发送。
    tcp_nopush on;
    
    # 配置 Nginx 不要缓存数据,应该快速的发送小数据(这仅仅应该用于频繁发送小的碎片信息而无需立刻获取响应的,需要实时传递数据的应用中)。
    tcp_nodelay on;
    
    # 指定了与客户端的 keep-alive 链接的超时时间。服务器会在这个时间后关闭链接。我们可以降低这个值,以避免让 worker 过长时间的忙碌。
    keepalive_timeout 65;
    
    types_hash_max_size 2048;
    # 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 Settings
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;

    ##
    # Logging Settings
    ##

    # 确定了 Nginx 是否保存访问日志。将这个设置为关闭可以降低磁盘 IO 而提升速度。
    access_log /var/log/nginx/access.log;
    
    # 设置 Nginx 应当记录临界错误。
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    # 设置 nginx gzip 压缩发送的数据。这会减少需要发送的数据的数量。
    gzip on;
    
    # 为指定的客户端禁用 gzip 功能。
    gzip_disable "msie6";

    # gzip_vary on;
    
    # 允许或禁止基于请求、响应的压缩。设置为 any,就可以 gzip 所有的请求。
    # gzip_proxied any;
    
    # 设置了数据压缩的等级。等级可以是 1-9 的任意一个值,9 表示最慢但是最高比例的压缩。
    # gzip_comp_level 6;
    
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    
    # 设置进行 gzip 的类型。有下面这些,不过还可以添加更多。
    # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Virtual Host Configs
    ##

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
    limit_req_zone $binary_remote_addr zone=one:10m rate=1r/s;  # 加入这行
}

# 邮件模块
#mail {
#   # See sample authentication script at:
#   # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
#   # auth_http localhost/auth.php;
#   # pop3_capabilities "TOP" "USER";
#   # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
#   server {
#       listen     localhost:110;
#       protocol   pop3;
#       proxy      on;
#   }
#
#   server {
#       listen     localhost:143;
#       protocol   imap;
#       proxy      on;
#   }
#}

实现流量限制具体配置

  • 修改 /etc/nginx/sites-available/default 配置文件
location / {
    # First attempt to serve request as file, then
    # as directory, then fall back to displaying a 404.
    
    # 限制向客户端传送响应的速率限制。参数 rate 的单位是字节/秒,设置为 0 将关闭限速。nginx 按连接限速,所以如果某个客户端同时开启了两个连接,那么客户端的整体速率是这条指令设置值的 2 倍。
    limit_rate_after 3m;
    
    # 设置不限速传输的响应大小。当传输量大于此值时,超出部分将限速传送。
    limit_rate 20k;
    
    try_files $uri $uri/ =404;
}

传输量限制为 3m,速率限制为 20k/s。

  • 测试下载
$ wget http://121.5.206.236/music.m4a
--2022-03-01 15:04:53--  http://121.5.206.236/music.m4a
Connecting to 121.5.206.236:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 10506987 (10M) [audio/x-m4a]
Saving to: ‘music.m4a’

music.m4a            41%[=======>            ]   4.14M  28.0KB/s    eta 1m 55s

在 nginx 访问根目录放入文件大小大于3m的文件,看到传输量大于设定值的部分会受到限制。

实现并发连接数限制的具体配置

  • 修改 /etc/nginx/nginx.conf 配置文件
http {
    ......
    ......
    # 定义一个叫one的记录区,总容量为10M。
    limit_conn_zone  $binary_remote_addr  zone=one:10m;
    ......
    ......
}
  • 修改 /etc/nginx/sites-available/default 配置文件
location / {
    # First attempt to serve request as file, then
    # as directory, then fall back to displaying a 404.
    
    # 限制根目录下,一个会话只能进行一个连接。简单点说,一个IP只能发起一个连接,多过一个,一律503。
    limit_conn one 1;
    
    try_files $uri $uri/ =404;
}
  • 测试并发
621dcbe60ac0c_621dcbe60ac07.png
621dcbf5215db_621dcbf5215d4.png

访问控制配置

  • 修改 /etc/nginx/sites-available/default 配置文件
location / {
    # First attempt to serve request as file, then
    # as directory, then fall back to displaying a 404.
    
    # IPv4的网络中10.1.1.0/16和192.168.1.0/24 IP段拒绝访问,10.0.2.14 IP拒绝访问。
    deny  10.0.2.14;
    deny  192.168.1.0/24;
    deny  10.1.1.0/16;
    
    # 对于 IPv6 的网络,2001:0db8::/32 拒绝访问。
    deny 2001:0db8::/32;
    
    # 除了以上拒绝访问的,其他IP均可访问。
    allow all;
    
    try_files $uri $uri/ =404;
}
  • 测试访问
# 创建访问文件
$ echo "Hello World" > /var/www/html/index

$ curl 121.5.206.236/index
Hello World

$ curl 10.0.2.14/index
<html>
<head><title>403 Forbidden</title></head>
<body bgcolor="white">
<center><h1>403 Forbidden</h1></center>
<hr><center>nginx/1.10.3 (Ubuntu)</center>
</body>
</html>

DDOS预防配置

  • 修改 /etc/nginx/nginx.conf 配置文件
http {
    ......
    ......
    # 定义一个叫one的记录区,总容量为10M,限制频率为每秒10个请求。
    limit_conn_zone  $binary_remote_addr  zone=one:10m;
    ......
    ......
}
  • 修改 /etc/nginx/sites-available/default 配置文件
location / {
    # First attempt to serve request as file, then
    # as directory, then fall back to displaying a 404.
    
    # 允许超过频率限制的请求数不多于5个,超时的请求不被延迟处理。
    limit_req zone=one burst=5 nodelay;
    
    try_files $uri $uri/ =404;
}
  • ab 压力测试
# 安装ab压测工具
$ apt install apache2-utils
# 其中-n代表每次并发量,-c代表总共发送的数量。这条命令表示10个请求一次并发出去。
$ ab -n 10 -c 10  http://localhost/index
  • 查看错误日志
$ tail /var/log/nginx/error.log
2022/03/01 16:07:43 [error] 17247#17247: *21 limiting requests, excess: 6.000 by zone "one", client: 127.0.0.1, server: 121.5.206.236, request: "GET /index HTTP/1.0", host: "localhost"
2022/03/01 16:07:43 [error] 17247#17247: *22 limiting requests, excess: 6.000 by zone "one", client: 127.0.0.1, server: 121.5.206.236, request: "GET /index HTTP/1.0", host: "localhost"
2022/03/01 16:07:43 [error] 17247#17247: *23 limiting requests, excess: 6.000 by zone "one", client: 127.0.0.1, server: 121.5.206.236, request: "GET /index HTTP/1.0", host: "localhost"
2022/03/01 16:07:43 [error] 17247#17247: *24 limiting requests, excess: 6.000 by zone "one", client: 127.0.0.1, server: 121.5.206.236, request: "GET /index HTTP/1.0", host: "localhost"

可以看到,并发了10条请求,有4条访问失败。

题目名称 linux实验-基本指令1 题目关键字 linux实验-基本指令1 题目录入时间 2013-4-1 22:36:02 题目内容 1、root帐号登录,查看/tmp目录,如果/tmp目录下没有子目录myshare,则建立该目录。 2、创建帐号testuser。 3、把myshare目录及其目录下的所有文件和子目录的拥有者该为testuser,工作组改为users。 4、切换至testuser帐号。进入/tmp/myshare目录,采用vim编辑器编写以上程序,程序名称为hello.sh: #!/bin/bash echo "app start" echo -e func (){ echo "hello world!" } func echo -e echo "app end" 5、保存hello.sh后,给予hello.sh拥有者可读、可写和可执行的权限,同组可读可执行,其他人可执行权限。 6、输入./hello.sh,观察程序输出的效果。 7、进入testuser的用户主目录,在这个目录下创建hello.sh的软链接,同时拷贝hello.sh到该目录下并改名为hello.sh.bak,要求拷贝时保留文件属性值。 8、退出testuser帐号,回到root帐号,从/开始查找后缀名为.conf的所有文件,把输出结果重定向到testuser帐号的主目录下的output.txt文件。 9、在上一步操作的.conf文件中找出文件容量最大的和最小那个,并把这两个文件的容量大小输出到output.txt文件中。 10、统计出系统中有多少个用户帐号,把数量输出到output.txt文件中。 11、把output.txt文件转换为windows记事本可正规打开的格式。 12、tar打包压缩testuser帐号主目录下的所有文件。 13、用U盘把上一步打包压缩文件拷贝到U盘上。 14、执行userdel -r testuser,执行rm -fr myshare 题目创建人 题目注释 把打包压缩文件提交即可。 题目名称 linux-课题练习1 题目关键字 linux-课题练习1 题目录入时间 2013-4-15 12:21:53 题目内容 1、创建组testgroup; 2、创建用户a2012,先采用默认设置创建,然后使该用户加入testgroup组。 3、创建用户a2013,其用户主目录为/tmp/a2013,其主组为testgroup,附加组为users。 4、用id命令显示a2012和a2013用户信息,并且把这些信息记录到日志文件/tmp/test.log中。 5、参考书本98-99页crontab命令内容,使用root执行crontab -e,编写时程表,完成每隔5分钟把当前时间追加进/tmp/test.log中。 6、执行crontab -l,把输出内容追加进/tmp/test.log。 7、待完成2次时间记录追加后,执行crontab -r删除当前的时程表。 8、把/tmp/test.log拷贝到windows中(注意文本格式的转换),采用记事本打开,看是否看到完整内容。 题目创建人 题目注释 课题练习,做完后直接把test.log文件提交上来。 题目名称 linux课后作业1 题目关键字 linux课后作业1 题目录入时间 2013-5-6 10:23:32 题目内容 完成课本实验6第一题:菜单驱动程序。 题目创建人 题目注释 本题为当天提交,把程序文件以附件形式提交即可。 题目名称 linux shell程序设计实验1 题目关键字 linux shell程序设计实验1 题目录入时间 2013-5-6 10:25:36 题目内容 完成课本实验6的第2题,要有输入错误处理。 题目创建人 题目注释 把程序文件以附件形式提交即可。 题目名称 linux shell程序设计实验2 题目关键字 linux shell程序设计实验2 题目录入时间 2013-5-6 10:26:43 题目内容 按要求完成课本实验7。 题目创建人 题目注释 把3个程序文件打包提交即可。 题目名称 linux gcc实验 题目关键字 linux gcc实验 题目录入时间 2013-5-20 14:27:52 题目内容 课本实验8第2题 题目创建人 题目注释 请提交Makefile文件 题目名称 LinuxMYSQL操作 题目关键字 MYSQL实验 题目录入时间 2015-4-15 11:19:01 题目内容 1、在Linux下检查是否有mysql,如果没有,请安装。版本上必须是5.5以上,越新越好! 2、在mysql下创建数据库,名称为 testdb,内有表 linuxtest,表字段如下: userid (自己的学号),varchar 50,关键字 mysql_version (当前mysql版本号), varchar 50 linux_version (当前发行版的uname -a 返回值),varchar 100 eth0_HW (eth0物理地址),varchar 50 3、insert对应的数据到表 linuxtest 4、导出该数据库的sql文件,命名为 学号.sql 5、提交该sql文件 题目创建人 题目注释 题目名称 Linux网络实验1-wget+lynx 题目关键字 Linux网络实验1-wget+lynx 题目录入时间 2015-4-20 21:46:19 题目内容 1、让你的linux接入互联网,如果你是虚拟机安装,可以采用桥接本地网卡的方式上网(课堂上有介绍该方法)。如果你是独立安装linux请自行解决。配置好IP地址和网关,DNS设置两个(8.8.8.8和114.114.114.114)。 2、已root登录系统,创建目录webtest,进入webtest目录,分别把ifcfg-eth0文件及resolv.conf文件内容追加至result.txt,。 3、执行echo "1234567890这是分隔线0987654321" >> result.txt traceroute www.scau.edu.cn >> result.txt 4、执行wget http://www.baidu.com 5、以源码方式安装lynx 官方网站:http://lynx.isc.org/ 下载地址:http://lynx.isc.org/current/ 请选择最新版本 安装示例: wget http://lynx.isc.org/current/lynx2.8.8rel.2.tar.gz 解压lynx2.8.8rel.2.tar.gz 进入解压后的目录 依次执行 ./configure make make install 6、echo "1234567890这是分隔线0987654321" >> result.txt 7、执行whereis lynx >> result.txt 8、echo "1234567890这是分隔线0987654321" >> result.txt 9、lynx -dump http://www.baidu.com >> result.txt 10、提交result.txt文件 题目创建人 题目注释 题目名称 GTK+实验 题目关键字 GTK+实验 题目录入时间 2015-5-24 13:47:12 题目内容 GTK+实验,完成课本实验9,最后打包上传(程序源代码+可运行文件) 题目创建人 题目注释 题目名称 决战Linux(1) 题目关键字 LAMP LNMP 题目录入时间 2015-4-28 22:16:03 题目内容 在LAMP、LNMP等环境下,任意挑选下列2种或以上动态网页语言,写出一个页面,读取MYSQL实验中的数据表数据。 (PHP,JSP,Perl,Python,Ruby,Go,ASP.NET) 注意:不同的动态网页语言,所要求的具体环境有可能不同,需要自行搭建。 该实验为综合性实验,最终需要提交综合性实验报告。报告提纲大致如下: 1、实验步骤描述(有图有真像) (1)第一种动态语言 a、实验环境描述 b、系统架构图 c、相关配置总结 d、核心代码总结 e、页面效果截图 (2)第二种动态语言 (3)第三种动态语言 以下同。 2、实验总结(有对比有分析有感想) 题目创建人 题目注释
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值