博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在Ubuntu Server下搭建LAMP环境
阅读量:4977 次
发布时间:2019-06-12

本文共 3281 字,大约阅读时间需要 10 分钟。

1 LAMP的安装

LAMP通常是指Linux+Apache+MySQL+PHP组合形成的一套可以运行PHP程序的体系,并不是一个软件的名称。没有安装MySQL的服务器依然可以在其它条件完备的情况下运行不涉及MySQL数据库读写操作的PHP程序,另外PHP并非只支持MySQL一种数据库产品,还支持其他的数据库产品。并非只有Apache可以通过扩展支持PHP的解析,Nginx,LightHttpd等其它软件同样可以。

Ubuntu一键安装LAMP环境的命令:
sudo apt-get install apache2 php5 mysql-server php5-mysql
或者使用tasksel安装LAMP套件:
sudo apt-get update && sudo apt-get install tasksel && sudo tasksel install lamp-server
给PHP添加常用扩展:
sudo apt-get install php5-gd curl libcurl3 libcurl3-dev php5-curl
安装完需要重启apache:
sudo service apache2 restart
Ubuntu系统LAMP环境配置
在Ubuntu系统中,通过apt-get工具安装的软件配置文件均放置在/etc下,并为每个软件建立一个以软件名称为名的文件夹用于区分不同软件的配置文件。
通过apt-get安装的LAMP组件的配置文件也在/etc目录下:
- Apache /etc/apache2
- MySQL /etc/mysql
- PHP /etc/php5

 

2 虚拟主机(Virtual-Host)原理

Apache通过Virtual-Host配置功能可以实现,一台服务器上可以同时放多个服务的网站,用户使用不同的域名访问不同的网站。

在Apache中配置虚拟主机的方法:
(1) 通过修改客户端hosts文件(/etc/hosts)来模拟DNS解析。
例如:
127.0.0.1 a.gerryyang.com
127.0.0.1 b.gerryyang.com
(2) 进入/etc/apache2/sites-available目录,将000-default.conf作为模板,分别复制两份,然后修改部分内容。
cp 000-default.conf a.conf
cp 000-default.conf b.conf
vi a.conf打开后:
添加ServerName:ServerName a.gerryyang.com
修改DocumentRoot:DocumentRoot /var/www/html/gerry_data
同理,对b.conf做同样操作。
然后,再进入/etc/apache2/sites-enabled目录,分别创建../sites-available/a.conf和../sites-available/b.conf两个配置文件的软链接:
ln -s ../sites-available/a.conf a.conf
ln -s ../sites-available/b.conf b.conf
最后,重启Apache2,sudo service apache2 restart
(3) 测试方法
curl  "a.gerryyang.com/index.html"
curl  "b.gerryyang.com/index.html"

3 MySQL数据存储目录迁移方法

(1) 停止MySQL服务

sudo service mysql stop
(2) 创建新的迁移目录,以及访问权限和之前的目录相同(MySQL的数据存储目录在/var/lib/mysql中
sudo mkdir /mysqldata
sudo chown -vR mysql:mysql /mysqldata/
sudo chmod -vR 700 /mysqldata/
sudo cp -av /var/lib/mysql/* /mysqldata/
(3) 修改MySQL的配置
sudo vim /etc/mysql/my.cnf
将datadir = /var/lib/mysql修改为:
datadir = /mysqldata
(4) Ubuntu还需要修改apparmor的配置文件
sudo vi /etc/apparmor.d/usr.sbin/mysqld
将:
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,
注释,然后添加新目录的访问权限:
/mysqldata/ r,
/mysqldata/** rwk,
保存退出。
(5) 分别重启apparmor和mysql服务
sudo service apparmor reload
sudo service mysql restart
(6) 测试方法
建立一个新的数据库,MySQL会在数据存储目录建立一个与数据库同名的文件夹。
create database db_gerry;
show databases;
exit;
cd /mysqldata/ && ll
小结:
Apache支持virtual-host虚拟主机,可以将多个指向同一服务器的域名分别指定根目录以及权限配置并且互不干扰。通过apt-get安装的MySQL,其数据存储目录可以改变,以便更加符合数据安全的需求,但在迁移数据后需要修改apparmor中与MySQL相关的目录访问权限。默认情况下,出于安全的考虑,MySQL在初始状态下不允许远程连接,只允许服务器内部应用的本地连接。

4 安装phpmyadmin

phpmyadmin是非常流行的mysql管理工具。

两种安装方式:
(1) apt-get方式(/etc/phpmyadmin/)
sudo apt-get install phpmyadmin
sudo ln -s /usr/share/phpmyadmin/ /var/www/pma
(2) 手动上传方式
先下载好phpmyadmin的安装包,然后通过ftp工具FileZilla上传到服务器。

5 开启MySQL的remote access

默认情况下MySQL只允许本地访问,而不允许远程访问(remote access)

(1) 第一步,修改vi /etc/mysql/my.cnf(针对整个服务器而言)
bind-address = 127.0.0.1
注释并退出。
(2) 第二步,修改user用户表
使用phpmyadmin添加一个新的用户,允许用公网IP来访问
(3) 因为修改过my.cnf配置,所以需要重启MySQL服务
sudo service mysql restart
(4) 测试
通过外网使用phpmyadmin或者Navicat进行访问测试

6 服务器集群介绍

一种简单的LAMP集群 (读写分离)
一大波用户请求到来 -> 负载均衡Nginx (分发请求) -> Apache+PHP (写入) -> MySQL#1 (同步) -> MySQL#2...#3
一大波用户请求到来 -> 负载均衡Nginx (分发请求) -> Apache+PHP (读取) -> MySQL#2...#3
国内外著名的巨型服务器集群
TTC - Tencent Table Cache (腾讯)
TFS - Taobao File System (阿里巴巴)
BAE - Baidu Application Engine (百度)
SAE - Sina Application Engine (新浪)
GFS - Google File System (谷歌)

转载于:https://www.cnblogs.com/xiaorenwu702/p/6285251.html

你可能感兴趣的文章
Java多线程(二)
查看>>
发个招聘信息
查看>>
如何在terminal中使用gcc编译objective-c
查看>>
个人博客
查看>>
VS部署中的ProductCode问题
查看>>
linux 下C++查询mysql数据库
查看>>
ASM 1——概念简介
查看>>
HDU 1754 I Hate It(线段树区间求最值)
查看>>
SQL 理论知识总结
查看>>
Effective java笔记3--类和接口2
查看>>
properties 的生成与解析配置文件
查看>>
零基础小白怎么用Python做表格?
查看>>
oracle 按照时间间隔进行分组
查看>>
doGet & doPost
查看>>
jQuery动画
查看>>
Windows Phone 7 和 Iphone 联系人带头像同步方案
查看>>
jquery判断两次密码不一致
查看>>
三、oneinstack
查看>>
ASP.NET数据格式的Format-- DataFormatString
查看>>
1.3 将临时变量内联化
查看>>