nginx

1 nginx相对Apache优点

  1. 高并发响应性能非常好,官方 Nginx 处理静态文件并发 5w/s
  2. 反向代理性能非常强。(可用于负载均衡)
  3. 内存和 cpu 占用率低。(为 Apache 的 1/5-1/10)
  4. 对后端服务有健康检查功能。
    5) 支持 PHP cgi 方式和 fastcgi 方式。
  5. 配置代码简洁且容易上手。

2 nginx工作原理

Nginx 由内核和模块组成,其中,内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端请求映射到一个 location block(location 是 Nginx配置中的一个指令,用于 URL 匹配),而在这个 location 中所配置的每个指令将会启动不同的模块去完成相应的工作。
Nginx 的模块从结构上分为:

核心模块:HTTP 模块、 EVENT 模块和 MAIL 模块
基础模块: HTTP Access 模块、HTTP FastCGI 模块、HTTP Proxy 模块和 HTTP Rewrite模块,
第三方模块:HTTP Upstream Request Hash 模块、 Notice 模块和 HTTP Access Key模块。

Nginx 的高并发得益于其采用了 epoll 模型,与传统的服务器程序架构不同,epoll 是linux 内核 2.6 以后才出现的。 Nginx 采用 epoll 模型,异步非阻塞,而 Apache 采用的是select 模型

Select 特点:select 选择句柄的时候,是遍历所有句柄,也就是说句柄有事件响应时,
select 需要遍历所有句柄才能获取到哪些句柄有事件通知,因此效率是非常低。

epoll 的特点:epoll 对于句柄事件的选择不是遍历的,是事件响应的,就是句柄上事
件来就马上选择出来,不需要遍历整个句柄链表,因此效率非常高

3 MemCache 概述

MemCache虽然被称为”分布式缓存”,但是MemCache本身完全不具备分布式的功能

Memcache 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高了网站访问的速度。 MemCaChe是一个存储键值对的HashMap,在内存中对任意的数据(比如字符串、对象等)所使用的key-value存储,数据可以来自数据库调用、API调用,或者页面渲染的结果。MemCache设计理念就是小而强大,它简单的设计促进了快速部署、易于开发并解决面对大规模的数据缓存的许多难题,而所开放的API使得MemCache能用于Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序语言。

4MemCache 常用命令

  • add

    添加数据,将 value(数据值) 存储在指定的 key(键) 中

    命令格式
    add key flag expiretime bytes
    value
    
    • key : 给这个值设置一个名字
    • flag : 标志,是一个整数
    • expiretime : 有效期,以秒为单位,0表示没有延迟
    • bytes : 这是一个需要存储在memcached的数据的长度
    • value : 是一个需要存储的数据。数据需要将通过在新的一行后输入
    范例
    # 添加数据
    add name 0 1000 8
    kangvcar
    STORED
    # 如果bytes设置的长度和输入的value长度不符则出现一下错误
    add name 0 1000 8
    kangvcarrr
    CLIENT_ERROR bad data chunk
    

    set

    为一个新的或现有的键(key)设置一个值

    命令格式
    set key flag expiretime bytes
    value
    

    参数含义与 add 命令相同

    范例
    为已存在的key(name)设置一个新的值tom
    set name 0 1000 3
    tom
    STORED
    

    replace

    替换已存在的 key(键) 的 value(数据值)

    命令格式
    replace key flag expiretime bytes
    value
    

    参数含义与 add 命令相同

    范例
    replace name 0 1000 8
    memcache
    STORED
    

    append

    向已存在 key(键) 的 value(数据值) 后面追加数据

    命令格式
    append key flag expiretime bytes
    value
    

    参数含义与 add 命令相同

    范例
    # 添加数据123到现有键name的后面
    append name 0 1000 3
    123
    STORED
    # 查看键name的值
    get name
    VALUE name 0 11
    memcache123
    END
    

    prepend

    向已存在 key(键) 的 value(数据值) 前面追加数据

    命令格式
    prepend key flag expiretime bytes
    value
    

    参数含义与 add 命令相同

    范例
    prepend name 0 1000 3
    456
    STORED
    get name
    VALUE name 0 14
    456memcache123
    END
    

    gets / cas

    gets 获取带有 CAS 令牌的 value(数据值)
    cas 执行一个"检查并设置"的操作

    命令格式
    gets key
    cas key flags exptime bytes unique_cas_token [noreply]
    value
    
    • unique_cas_token : 通过 gets 命令获取的一个唯一的64位值
    范例
    # 缺少一个参数 unique_cas_token 
    cas name 0 1000 3
    ERROR
    # unique_cas_token 不正确
    cas name 0 1000 3 2
    sam
    NOT_FOUND
    # 通过 gets 命令获取唯一令牌 ==> 12
    gets name
    VALUE name 0 8 12
    kangvcar
    END
    # 使用 cas 命令更新数据
    cas name 0 1000 3 12
    sam
    STORED
    # 使用 get 命令查看数据是否更新
    get name
    VALUE name 0 3
    sam
    END
    

    get

    获取存储在 key(键) 中的 value(数据值)

    命令格式
    get key
    
    范例
    # 获取存储在键name的值
    get name
    VALUE name 0 14
    456memcache123
    END
    

    delete

    删除已存在的 key(键)

    命令格式
    delete key
    
    范例
    delete age
    DELETED
    

    incr / decr

    incr 与 decr 命令用于对已存在的 key(键) 的数字值进行自增或自减操作

    命令格式
    incr key increment_value`
     `decr key increment_value
    
    范例
    # 添加数据
    add age 0 1000 2
    15
    STORED
    # 对已存在的键(age)数字值进行自增
    incr age 5
    20
    # 获取键age的值
    get age
    VALUE age 0 2
    20
    END
    # 添加数据
    add age 0 1000 2
    15
    STORED
    # 对已存在的键(age)数字值进行自减
    incr age 5
    10
    # 获取键age的值
    get age
    VALUE age 0 2
    10
    END
    

    flush_all

    清理缓存中的所有数据

    命令格式
    flush_all [time]
    
    • time : (可选) 在指定时间后执行清理缓存操作
    范例
    flush_all
    OK
    

    stats / stats slabs / stats sizes / stats items

    stats 显示统计信息例如 PID(进程号)、版本号、连接数等
    stats slabs 显示各个slab的信息,包括chunk的大小、数目、使用情况等
    stats sizes 显示所有item的大小和个数
    stats items 显示各个 slab 中 item 的数目和存储时长

    命令格式
    stats`  `stats slabs`  `stats sizes`   `stats items
    
    范例
    stats
    STAT pid 19700
    STAT uptime 3054540758
    STAT time 269361355
    STAT version 1.4.4-14-g9c660c0
    STAT pointer_size 64
    ...
    stats slabs
    STAT 1:chunk_size 96
    STAT 1:chunks_per_page 10922
    STAT 1:total_pages 1
    STAT 1:total_chunks 10922
    ...
    stats sizes
    STAT 96 2
    END
    stats items
    STAT items:1:number 2
    STAT items:1:age 3054540037
    STAT items:1:evicted 0
    STAT items:1:evicted_nonzero 0
    STAT items:1:evicted_time 0
    STAT items:1:outofmemory 0
    STAT items:1:tailrepairs 0
    END
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值