lamp架构的搭建与配置

lamp架构的搭建与配置

扫码添加渲大师小管家,免费领取渲染插件、素材、模型、教程合集大礼包!

大家好,今天来介绍lamp架构的搭建与配置(如何搭建lamp环境,并检测php环境是否成功)的问题,以下是渲大师小编对此问题的归纳和整理,感兴趣的来一起看看吧!

lamp架构的搭建与配置

如何搭建LAMP环境

  • 首先为了搭建一个稳定的lamp的练习环境,确保你的虚拟机可以连网,这里我们使用的yum安装,它可以帮助我们解决软件自己的依赖关系.我还在后面加了postgresql数据库如果不需要的话可以去掉和postgresql的参数坦则.命令如下

    yum -y install httpd mysql mysql-server php php-mysql postgresql postgresql-server php-postgresql php-pgsql php-devel

  • 2

    yum安装过程,大概1-2分钟

  • 3

    启动apache服务并查看时候启动成功

    命令如下:(切记用root用户启动服务)

    启动:/etc/rc.d/init.d/httpd start

    检测启动结果:ps aux grep httpd

  • 4

    查看服务器的ip并进入网站根目录新建一个phpinfo.php的程序,用于查看php相关配置迅滚信息。

  • 5

    如果上述进让昌棚展顺利,那我们接下来进行mysql数据库的配置

    命令如下:

    启动: /etc/rc.d/init.d/mysqld start

    检查启动结果: netstat -tulnp grep :3306

    修改root密码: mysqladmin -u root password ‘你想设置的密码’

  • 6

    进入mysql数据库,创建demo库和用于测试的person表,并插入测试数据

  • 7

    最后编写php连接mysql的测试代码,检测mysql是否能正常配合php工作

    END

lamp架构提高服务器并发要注意哪些问题

对于大流量、大并发量的网站系统架构来说,除了硬件上使用高性能的服务器、负载均衡、CDN等之外,在软件架构上需要重点关注下面几个环节:使用高性能的操作系统(OS)、高性能的网页服务器(Web Server)、高性能的数据库(Databse)、高效率的编程语言等。下面我将从这几点对其一一讨论。
  操作系统
  Linux操作系统有很多个不同的发行版,如Red Hat Enterprise Linux、SUSE Linux Enterprice、Debian、Ubuntu、CentOS等,每一个发行版都有自己的特色,比如RHEL的稳定,Ubuntu的易用,基于稳定性和性能的考虑,操作系统选择CentOS(Community ENTerprise Operating System)是一个理想的方案。
  CentOS(Community ENTerprise Operating System)是Linux发行版之一,是RHEL/Red Hat Enterprise Linux的精简免费版,和RHEL为同样的源代码,不过,RHEL和SUSE LE等企业版,提供的升级服务均是收费升级,无法免费在线升级,因此要求免费的高度稳定性的服务器可以用CentOS替代Red Hat Enterprise Linux使用。

  LAMP网站架构图
  Web服务器、缓存和PHP加速
  Apache是LAMP架构最核心的Web Server,开源、稳定、模块丰富是Apache的优势。但Apache的缺点是有些臃肿,内存和CPU开销大,性能上有损耗,不如一些轻量级的Web服务器(例如nginx)高效,轻量级的Web服务器对于静态文件的响应能力来说远高于Apache服务器。
  Apache做为Web Server是负载PHP的最佳选择,如果流量很大的话,可以采用nginx来负载非PHP的Web请求。nginx是一个高性能的HTTP和反向代理服务器,Nginx以它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。Nginx不支持PHP和CGI等动态语言,但支持负载均衡和容错,可和Apache配合使用,是轻量级的HTTP服务器的首选。
  Web服务器的缓存也有多种方案,Apache提供了自己的缓存模块,也可以使用外加的Squid模块进行缓存,这两种方式均可以有效的提高Apache的访问响应能力。Squid Cache是一个Web缓存服务器,支持高效的缓存,可以作为网页服务器的前置cache服务器缓存相关请求来提高Web服务器的速度,把Squid放在Apache的前端来缓存Web服务器生启运成的动态内容,而Web应用程序只需要适当地设置页面实裤薯效时间即可。如访问量巨大则可考虑使用memcache作为分布式缓存。
  PHP的加速使用eAccelerator加速器,eAccelerator是一个自由开放源码PHP加速器,优化和动态内容缓存,提高了性悄纯梁能PHP脚本的缓存性能,使得PHP脚本在编译的状态下,对服务器的开销几乎完全消除。它还有对脚本起优化作用,以加快其执行效率。使PHP程序代码执效率能提高1-10倍。
  具体的解决方案有以下几种:
  1、squid + Apache + PHP + eAccelerator
  使用Apache负载PHP,使用squid进行缓存,html或图片的请求可以直接由squid返回给用户。很多大型网站都采用这种架构。
  2、nginx/Apache + PHP(fastcgi) + eAccelerator
  使用nginx或Apache负载PHP,PHP使用fastcgi方式运行,效率较高。
  3、nginx + Apache + PHP + eAccelerator
  此方案综合了nginx和Apache的优点,使用Apache负载PHP,nginx负责解析其他Web请求,使用nginx的rewrite模块,Apache端口不对外开放。
  数据库
  开源的数据库中,MySQL在性能、稳定性和功能上是首选,可以达到百万级别的数据存储,网站初期可以将MySQL和Web服务器放在一起,但是当访问量达到一定规模后,应该将MySQL数据库从Web Server上独立出来,在单独的服务器上运行,同时保持Web Server和MySQL服务器的稳定连接。
  当数据库访问量达到更大的级别,可以考虑使用MySQL Cluster等数据库集群或者库表散列等解决方案。
  总的来说,LAMP架构的网站性能会远远优于Windows IIS + ASP + Access(例如月光博客)这样的网站,可以负载的访问量也非常大,国内的大量个人网站如果想要支撑大访问量,采用LAMP架构是一个不错的方案。
  综上所述,基于LAMP架构设计具有成本低廉、部署灵活、快速开发、安全稳定等特点,是Web网络应用和环境的优秀组合。

搭建lamp环境apache和php在一台服务器mysql在另一台服务器

先回答你在一台服务器上安装lamp和在两台服务器上分别安装lamp的区别。
只要是为了安全性,其次是考虑均衡服务器性能。
一般有点规模的网站,都会做如下考虑,将网站应用层,数据层和图片附件等剥离。
应用层,你可以理解为放你的php程序的服务器,应用服务器是直接面对访问者的,一般如果被黑客攻击的话,主要是攻击他。
数据层,就是一台服务器上,仅仅安装mysql,其他什么php,apache什么的,什么都不安装,并且和应用层等组成局域网,
也就是要访问数据库,必须先通过应用层服务器。
图片和附件服务器,应为数据量巨大,需要独立为一台服务器,当然,这个回答已经超过你问题的范畴了。
多台服务器,还可以利用他们自己相互备份,比如数据库服务器,定时拷贝应用服务器的内容,应用服务器,同事拷贝数据库服务器的内容如茄培。
这样,无论哪个服务器的硬盘损坏,都可以将最近的备份立刻调出,甚至此时将某个服务器直接安装lamp,先顶一顶,做到服务不间断。

另外,应用服务器和数据库服务器对硬件的要求是不一样的,如果你经常接触网络程序和服务器,可以发现,程序的短板一般都是数据库。
数据库对服务器的内存要求非常高,而程序对cpu的要求比较高,我见过最贵的数据库服务器售价是36万(去年),和他配套的应用服务器是1万元的。
每天顶100万pv左右的访问。

然后回答你如何配置,其实很简单,如果服务器托管,你让机房帮你搞定(免费的,你可以提出要求)。
如果在本地调试,进入mysql,命令界面,输入用户名和密码,输入以下代码

CREATE USER 'username'@'%' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON * . * TO 'username'@'%' IDENTIFIED BY 'password'
WITH GRANT OPTION MAX_QUERIES_PER_HOUR 0 MAX_CONNECTIONS_PER_HOUR 0 MAX_UPDATES_PER_HOUR 0 MAX_USER_CONNECTIONS 0 ;

以上代码生成一个用户名是 username ,密码是 password 的远程用户。
你可以查一下mysql grant语句的使用方法。
一个很简单的方法是,在应用层服务器上安装一个phpmyamdin,然后在config.default.php 文件中,将所有的localhost,改成装有mysql数据库的ip地址。
然后就很简单了,就像操作本地数据库一样,就这么渣唯简单。

希望对你有用。
=============================================================
你追问的问题应该是这纳空样的。
mysql中建立一个可以远程访问的用户名和密码。
php程序中,将连接数据库的代码中的,localhost,改为mysql所在服务器的IP。

lamp架构中请问apachemysqlphp之间是依靠哪几个文件以及哪几个配置文件中的哪些语句连接起来的

apache php

apache配置文件中需要载入PHP程序里的modules/libphp5.so模块。以及添加
AddType application/颤迅x-httpd-php .php 就可以了。
至于mysql,mysql的默认端口是3306,php与mysql协同工作穗斗的时候,只要在php项目中配置mysql的用猜洞磨户名和密码,以及端口,就可以访问数据。

分享到 :
相关推荐

rvm用什么软件打开(navisworks怎么打开rvm文件)

1、rvm用什么软件打开RVM(RubyVersionManager)是一个用[&h...

修改文件创建时间会被发现吗(new file time)

大家好,今天来介绍修改文件创建时间会被发现吗(word的创建日期和最后修改日期)的问...

苹果怎么删除cookie(如何删除cookie删除历史记录)

1、苹果怎么删除cookie苹果是一款备受欢迎的设备,无论是iPhone、iPad[...

IFRAme的onloadIE11支持吗(iframe标签会阻塞页面的加载)

1、IFRAme的onloadIE11支持吗IFRame的onloadIE11支持[...

发表评论

您的电子邮箱地址不会被公开。 必填项已用*标注