前言
前面的文章中说过LAMP架构包括:linux操作系统,Apache网站服务器,MySQL数据库,Perl、php或者Python编程语言,而今天要说的LNMMP 和LAMP类似,只是作为Web服务器的不再是Apache而是高性能的Nginx,同时引进Memcached加速缓存效率,用于加快访问速度 。
Memcached是一款开源、高性能、分布式内存对象缓存系统,可应用各种需要缓存的场景,其主要目的是通过降低对数据库的访问来加速Web应用程序 。它是一个基于内存的“键值对”存储,用于存储数据库调用、API调用或页面引用结果的直接数据,如字符串、对象等 。
实现过程
实验拓扑
文章插图
实验环境
系统环境:centos6.6
web服务器:172.16.10.123 nginx-1.6.3
PHP服务器:172.16.10.110 php-5.4.26
数据库服务器:172.16.10.211 MariaDB-5.5.36
Memcached服务器:172.16.10.212 memcached-1.4.24
工作原理
利用nginx的高性能特点做前端反向代理服务器,分发用户请求,静态请求直接返回结果,动态请求交给后端php处理,php查询数据库返回处理结果,并将结果缓存至Memcached,当接收新请求时,php首先在Memcached查询,Memcached有结果直接返还给nginx,没结果再查询数据库,依次类推 。
安装配置nginx
#解决依赖关系[root@node1 ~]# yum groupinstall "Development Tools" "Server Platform Deveopment" -y[root@node1 ~]# yum install openssl-devel pcre-devel -y[root@node1 ~]# groupadd -r nginx[root@node1 ~]# useradd -r -g nginx nginx[root@node1 ~]# tar xf nginx-1.6.3.tar.gz [root@node1 ~]# cd nginx-1.6.3[root@node1 nginx-1.6.3]# ./configure > --prefix=/usr/local/nginx > --sbin-path=/usr/sbin/nginx > --conf-path=/etc/nginx/nginx.conf > --error-log-path=/var/log/nginx/error.log > --http-log-path=/var/log/nginx/access.log > --pid-path=/var/run/nginx/nginx.pid > --lock-path=/var/lock/nginx.lock > --user=nginx > --group=nginx > --with-http_ssl_module > --with-http_flv_module > --with-http_stub_status_module > --with-http_gzip_static_module > --http-client-body-temp-path=/usr/local/nginx/client/ > --http-proxy-temp-path=/usr/local/nginx/proxy/ > --http-fastcgi-temp-path=/usr/local/nginx/fcgi/ > --http-uwsgi-temp-path=/usr/local/nginx/uwsgi > --http-scgi-temp-path=/usr/local/nginx/scgi > --with-pcre[root@node1 nginx-1.6.3]# make && make install为nginx提供SysV init脚本
[root@node1 ~]# vim /etc/rc.d/init.d/nginx #新建文件/etc/rc.d/init.d/nginx,内容如下:#!/bin/sh## nginx - this script starts and stops the nginx daemon## chkconfig: - 85 15 # description: Nginx is an HTTP(S) server, HTTP(S) reverse # proxy and IMAP/POP3 proxy server# processname: nginx# config: /etc/nginx/nginx.conf# config: /etc/sysconfig/nginx# pidfile: /var/run/nginx.pid # Source function library.. /etc/rc.d/init.d/functions # Source networking configuration.. /etc/sysconfig/network # Check that networking is up.[ "$NETWORKING" = "no" ] && exit 0 nginx="/usr/sbin/nginx"prog=$(basename $nginx) NGINX_CONF_FILE="/etc/nginx/nginx.conf" [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx lockfile=/var/lock/subsys/nginx make_dirs() { # make required directories user=`nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=([^ ]*).*//g' -` options=`$nginx -V 2>&1 | grep 'configure arguments:'` for opt in $options; do if [ `echo $opt | grep '.*-temp-path'` ]; then value=https://www.isolves.com/it/rj/czxt/linux/2019-06-06/`echo $opt | cut -d "=" -f 2` if [ ! -d "$value" ]; then # echo "creating" $value mkdir -p $value && chown -R $user $value fi fi done} start() { [ -x $nginx ] || exit 5 [ -f $NGINX_CONF_FILE ] || exit 6 make_dirs echo -n $"Starting $prog: " daemon $nginx -c $NGINX_CONF_FILE retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval} stop() { echo -n $"Stopping $prog: " killproc $prog -QUIT retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval} restart() { configtest || return $? stop sleep 1 start} reload() { configtest || return $? echo -n $"Reloading $prog: " killproc $nginx -HUP RETVAL=$? echo} force_reload() { restart} configtest() { $nginx -t -c $NGINX_CONF_FILE} rh_status() { status $prog} rh_status_q() { rh_status >/dev/null 2>&1} case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart|configtest) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 ;; *) echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" exit 2esac为脚本赋予执行权限
[root@node1 ~]# chmod +x /etc/rc.d/init.d/nginx添加至服务管理列表,并让其开机自动启动
推荐阅读
- API网关的背景、架构以及落地方案
- 用SQL语句实现随机抽奖,小函数包含大智慧
- Python入门:4段简短代码实现Excel读写
- 产品架构图到底是怎么“画”出来的?
- 在MySQL中实现Rank高级排名函数
- 实现扫码登陆的最简单方案与原理
- 飞碟飞行原理是什么?我们有可能实现吗? 飞碟原理
- js实现继承的方法以及优缺点
- go语言网络编程之session的实现
- 如何做高并发架构设计!