一. 网络服务

  web服务器和web框架的关系

web服务器(nginx):接收HTTP请求(例如www.baidu.com)并返回数据

web框架(django,flask):开发web应用程序,处理接收到的数据

  nginx

# 面试技巧
支持高并发,能支持几万并发连接
资源消耗少,在3万并发连接下开启10个nginx线程消耗的内存不到200M
可以做http反向代理和负载均衡
支持异步网络i/o事件模型epoll

二 . Tengine

Tengine是由淘宝网发起的web服务器项目,在nginx基础上支持高并发,并且性能非常的稳定.  

  安装Tengine

# 1. 检测是否在Linux上是否通过yum安装了nginx(只有用yum安装才能用下面方法检测)
rpm -qi nginx
# 如果有返回值就证明安装了,然后删除它
yum remove nginx -y
# 2. 安装nginx依赖包
yum install gcc patch libffi-devel python-devel zlib-devel bzip2-devel openssl-devel
  ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel openssl openssl-devel -y
# 3.源代码编译安装tenginx
1.下载淘宝nginx的源代码包
wget http://tengine.taobao.org/download/tengine-2.3.0.tar.gz
2.解压缩源代码
tar -zxvf tengine-2.3.0.tar.gz
3.切换进入nginx源代码目录 进行编译安装
cd tengine-2.3.0
4.释放编译文件,指定安装路径
./configure --prefix=/opt/s18tngx/
5.开始编译且安装
make && make install
6.查看nginx的安装目录有哪些东西
[root@localhost s18tngx]# ls
# conf 存放nginx的配置文件目录的
# html 存放前端文件的地儿
# logs 存放nginx日志文件的目录
# sbin 存放nginx的可执行命令
7.配置nginx的环境变量,支持快捷启动
[root@localhost sbin]# vim /etc/profile 把sbin的绝对路径加到path里
8.使其生效
source /etc/profile
9.启动nginx
直接输入nginx命令
10.修改nginx的首页文件
存放nginx安装目录下的html文件夹中,名为index.html的文件
11.vim index.html
写入想要展示的页面

三 . nginx配置文件学习

Nginx主配置文件/etc/nginx/nginx.conf是一个纯文本类型的文件,整个配置文件是以区块的形式组织的。一般,每个区块以一对大括号{}来表示开始与结束

  nginx主配置文件解析

    coreModule核心模块

user www;                       #Nginx进程所使用的用户
worker_processes 1; #Nginx运行的work进程数量(建议与CPU数量一致或auto)
error_log /log/nginx/error.log #Nginx错误日志存放路径
pid /var/run/nginx.pid #Nginx服务运行后产生的pid进程号

    event事件模块

events {
worker_connections //每个worker进程支持的最大连接数
use epoll; //事件驱动模型, epoll默认
}

    http内核模块

# 公共的配置定义在http{}
http { #http层开始
...
gzip on; # 开启压缩图片功能
# 使用Server配置网站, 每个Server{}代表一个网站(简称虚拟主机)
'server' {
listen 80; #监听端口, 默认80
server_name localhost; # 提供服务的域名或主机名
access_log host.access.log # 访问日志
# 控制网站访问路径
'location' / {
root /opt/share/nginx/html; # 存放网站代码路径
index index.html index.htm; # 服务器返回的默认页面文件
}
# 指定错误代码, 统一定义错误页面, 错误代码重定向到新的Locaiton
error_page 500 502 503 504 /50x.html;
}
}

  nginx功能学习

# 1. C:\Windows\System32\drivers\etc\hosts   用notepad++打开
修改windows的hosts文件,就是写一个假的域名
# 2.写入测试域名,如下
192.168.81.130 www.s18lol.com (格式必须是这样)
然后输入www.s18.lol.com 就访问的是192.168.81.130

  配置nginx多虚拟主机实战, 其实就是修改nginx.conf,写入多个server标签,支持多个虚拟主机

server {
listen 80;
server_name www.s18dnf.com;
location / {
root /opt/s18dnf/; # 需要建这个文件夹
index index.html index.htm;
}
#第二个虚拟主机 lol网址
server {
listen 80;
server_name www.s18lol.com;
location / {
root /opt/s18lol/; # 需要建这个文件夹
index index.html;
}
}

  新建所需要的文件夹

mkdir -p /opt/s18dnf/   /opt/s18lol/
# 在这两个文件夹下分别:
touch index.html # 然后去copy网页

  nginx多虚拟主机的两个概念

1.如果没有域名,写ip地址的话,虚拟主机是自上而下的加载顺序 ,
2.如果有域名,nginx会基于域名区分虚拟主机

  测试语法是否正确

[root@localhost conf]# nginx -t

  改完配置,重新加载nginx,平滑重启

nginx -s reload 

四 . 学习nginx的状态模块功能

  1.修改nginx.conf的配置文件

# 找到一个server虚拟主机,写入如下配置 (一定写在server里面)
location /status {
stub_status on;
}

  2.重启nginx,加载status状态模块

nginx -s reload 

  3.通过ab压测命令,去给网站发n多个请求

# 安装ab压测命令工具
yum -y install httpd-tools

  4.给服务器nginx发10000个请求

ab -kc 1000 -n 10000 http://192.168.81.130/

六 . nginx的access.log访问日志功能

# 编辑nginx.conf打开如下配置参数
打开如下注释
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; access_log logs/access.log main;
access_log "pipe:rollback logs/access_log interval=1d baknum=7 maxsize=2G" main; 重启nginx查看logs下的日志文件,检测用户请求信息
# cd 到 logs(这样才能执行下面的命令)
tail -f logs/access.log

七 . nginx的404页面

修改nginx.conf的404错误页面优化
找到如下配置
#当错误状态码是 40x系列就返回,nginx目录下的40x.html
error_page 404 403 402 400 401 /40x.html; cd /opt/s18lol/
vim 40x.html
# 写入想要的页面 重启nginx 查看404页面

八 . nginx限制ip访问功能

# 找到nginx.conf修改如下代码
location / {
#禁止192.168.226.0/24 这个地址段所有的ip访问
# 192.168.226.0/24 # 0就是0-255字段,24是子网掩码 # 禁止 192.168.226.1 这个ip访问
deny 192.168.226.1 ;
root /opt/s18dnf;
index index.html index.htm;
}

九 . 实现nginx反向代理功能

# 环境准备
准备2台机器
一个是真实资源文件 192.168.81.130 就理解为房东 ,提供dnf的资源界面
一个是反向代理服务器 192.168.81.131 理解为中介,当我们访问中介,就访问到dnf的网站资源 1.分别在2台机器,安装nginx 2.资源服务器已经配置好,返回dnf页面 3.反向代理服务器配置如下 vim编辑nginx.conf 找到第一个server虚拟主机
修改配置如下
server_name 192.168.81.131; location / {
proxy_pass http://192.168.226.130;
} 4.重启nginx,查看反向代理效果

Linux -- nginx的更多相关文章

  1. linux nginx 启动脚本

    linux nginx 启动脚本 [root@webtest76 ~]# vi /etc/init.d/nginx #!/bin/bash # nginx Startup script for the ...

  2. Linux nginx日志按天分割实例

    Linux nginx日志按天分割实例   nginx的日志有个小缺点,日志文件一直就是一个,不会自动地进行切割,如果访问量很大的话,将导致日志文件非常大,不便于管理这就需要我们自己来实现了,按日期每 ...

  3. linux+nginx+tomcat负载均衡,实现session同步

    linux+nginx+tomcat负载均衡,实现session同步 花了一个上午的时间研究nginx+tomcat的负载均衡测试,集群环境搭建比较顺利,但是session同步的问题折腾了几个小时才搞 ...

  4. MacOS + Linux + Nginx

    Asp.Net Core 发布和部署( MacOS + Linux + Nginx ) 前言 在上篇文章中,主要介绍了 Dotnet Core Run 命令,这篇文章主要是讲解如何在Linux中,对 ...

  5. PHP 的解压缩ZipArchive中的extractTo()方法 LINUX+nginx环境中解压zip时文件丢失的问题

    在项目中要用ZipArchive解压ZIP文件,起初測试环境在WINDOWS平台中,測试通过,换到 LINUX+nginx 的环境中时 就出问题了(ZIP包中有文件和目录一共3百多个文件,大部分是带汉 ...

  6. linux+nginx+mysql+php

    LNMP(linux+nginx+mysql+php)服务器环境配置   一.简介 Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为 “engine X”, 是一个高性能的 ...

  7. Linux Debian 7部署LEMP(Linux+Nginx+MySQL+PHP)网站环境

    我们在玩VPS搭建网站环境的时候,都经常看到所谓的LAMP.LNMP.LEMP,LAMP, 其中的A代表APECHE WEB驱动环境,LNMP中的N代表NGINX驱动环境,只不过海外的叫法NGINX ...

  8. LNMP(Linux+Nginx+Mysql+PHP---源码)环境搭建

    LNMP(Linux+Nginx+Mysql+PHP(Perl)) Linux:[root@dep5 mysql]# cat /etc/issueRed Hat Enterprise Linux Se ...

  9. 阿里云服务器部署php的laravel项目,在阿里云买ECS 搭建 Linux+Nginx+Mysql+PHP环境的

    在阿里云买ECS的时候选择自己习惯的镜像系统,我一般都是使用Linux Ubuntu,所以,以下的配置都是在Ubuntu 14.04稳定支持版的环境中搭建Linux+Nginx+Mysql+PHP环境 ...

  10. Asp.net Core 打包发布 (Linux+Nginx)

    如果你觉得如下这些文章对你有帮助,请点击链接支持作者原创 http://www.cnblogs.com/savorboard/ .Net Core SDK 命令介绍   前言 本篇主要介绍 asp.n ...

随机推荐

  1. STM32-FreeRTOS快速学习之总结1

    1. 基础知识注意:在RTOS中是优先值越高则优先级越高(和ucos/linux的相反) 在移植的时候,主要裁剪FreeRTOS/Source/portable文件夹,该文件夹用来针对不同MCU做的一 ...

  2. Elasticsearch单机双节点集群部署实战

    一.安装第一个ElasticSearch(主节点) 1.创建es用户,启动es不能使用root用户 useradd es passwd es12 root用户进入/home/es目录下 2.获取Ela ...

  3. vs2013中集成Git

    一:为什么不用2013中自带的? 我的2013自带的没法用,连最基本的克隆都用不了,网上看着下  好像说都不能用:不知道各位的如何. 二:如何自己讲Git集成到vs2013中? 需要的工具:     ...

  4. JavaScript(三)

    本文转载自:https://blog.csdn.net/xiaogeldx/article/details/85455011 JavaScript的math对象 math方法 sqrt:开方 abs: ...

  5. Xamarin 学习笔记 - Page(页面)

    本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1226447/Xamarin-Notes-Xamarin-Forms-Pages 转载 ...

  6. 【图解】FlexGrid Explorer 全功能问世

    前言 在去年的时候,我们推出了FlexGrid Demo,包含了FlexGrid的常用功能,如分组.滚动.冻结.自定义单元格类型.搜索面板.表格过滤器.树形结构.合并单元等,目前我们又在里面添加很多了 ...

  7. ionic3 Modal组件

     Modal组件主要用来弹出一些临时的框,如登录,注册的时候用 弹出页面html页面 <button ion-button small outline color="he" ...

  8. Android 启动APP时黑屏白屏的解决方案

    在开发中,我们在启动app的时候,屏幕会出现一段时间的白屏或者黑屏,不同设备时间长短不同.很影响用户体验. 首先分析一下,产生这个现象的原因,当我们在启动一个应用时,系统会去检查是否已经存在这样一个进 ...

  9. Git:五、操作远程仓库

    0.一般流程 1)自己新写:GitHub创建有README的库 -> clone到本地 2)修改已有:GitHub上fork别人的仓库 -> clone自己账号下的库到本地 1.创建库 右 ...

  10. Oracle 12c RAC 安装文档

    参考文档: https://docs.oracle.com/en/database/oracle/oracle-database/12.2/cwlin/index.html https://docs. ...