LAMP 通常表示 Linux + Apache + MySQL/MariaDB + Perl/PHP/Python,LAMP 的各个组件不是一成不变的,并不局限于它最初的选择。作为一个解决方案套件,LAMP 非常适合构建动态网站和网站应用程序。另外使用类似 Zabbix 这样的组件做监控也是网站必不可少的。

更好的阅读体验,可以点击此处

安装 LAMP

本文档的 LAMP 代指 Linux + Apache2 + MySQL + php5 且各示例步骤基于 Azure 环境下的 LINUX 虚拟机。本文档介绍三种方式来安装LAMP:1. 使用 Azure PowerShell 脚本; 2. 使用 Azure CLI; 3. 使用 SHELL 脚本。 安装 LAMP 过程中会在虚拟机上自动安装 Zabbix agent。

说明:
目前 Azure PowerShell 脚本和 Azure CLI 方式仅支持 CentOS(6.5, 6.6, 6.7, 7.0, 7.1, 7.2)。而 SHELL 脚本则有 CentOS, Ubuntu以及 SLES 三个版本。

参数使用注意事项:
DNSNamePrefix:必须小写,需保证唯一性,该参数将作为 DNS 前缀。
ZabbixServerIPAddress:可选项,指定 Zabbix 服务器地址。

Azure PowerShell 方式

PowerShell 脚本运行注意事项:
需要以管理员权限运行 PowerShell,使用之前需运行如下命令:

Set-ExecutionPolicy -ExecutionPolicy Unrestricted

如果您选择 Azure PowerShell 方式安装 LAMP,那么请按如何安装和配置 Azure PowerShell 中的说明在本地计算机上安装 Azure PowerShell。然后打开 Azure PowerShell 命令提示符,通过运行以下命令并遵循提示进行 Azure 帐户的交互式登录体验,来使用工作或学校 ID 登录

Login-AzureRmAccount -EnvironmentName AzureChinaCloud

然后您需要创建一个 Azure 资源组 (Resource Group),创建 Azure 虚拟机和安装LAMP都在该资源组中进行,运行以下命令创建 Azure 资源组:

New-AzureRmResourceGroup -Name "YOUR-RESOURCE-GROUP-NAME" -Location "China East"

您需要下载 PowerShell 脚本 single-lamp-deploy.ps1,按照以下示例运行 single-lamp-deploy.ps1 脚本,即可在资源组 rg1 中生成一台 CentOS 虚拟机,接着会在该虚机上安装 LAMP。其中 rg1 是在之前步骤中创建的资源组名字。

PS C:\> .\single-lamp-deploy.ps1 -ResourceGroupName rg1 -CentOSVersion 7.0 -AdminUserName azureuser -AdminPassword “YOUR-PASSWORD”  -MySqlPassword “YOUR-MYSQL-PASSWORD” -DNSNamePrefix “YOUR-DNS-PREFIX”

创建过程大概需要 20 分钟,运行成功后会出现如下提示, 这里我们直接去到下面访问网站的步骤去进行验证。

Deploy LAMP Server successfully.
To veriy the lamp server deployment, following below steps:
Open the URL http://<YOUR-DNS-PREFIX>.chinaeast.cloudapp.chinacloudapi.cn/mysql.php to check if php can connect to MySQL, if can do some insert operation, and finally it will return the result on the web page.
If you refresh the webpage, will insert another record into mysql db table.
We strongly recommend you to delete /var/www/html/mysql.php after you access the URL and see the successful result because mysql.php stores your mysql root password.
You can delete the inserted data by executing below commands:
mysql -uroot -p
drop database testdb;

Azure CLI 方式

如果您选择 Azure CLI 方式安装 LAMP,那么请安装 Azure CLI。然后请确保您是处于资源管理器模式下,可通过运行以下命令来验证:

azure config mode arm

现在,通过运行以下命令并遵循提示进行 Azure 帐户的交互式登录体验,来使用工作或学校 ID 登录

azure login -e AzureChinaCloud -u <your account>

然后您需要创建一个 Azure 资源组 (Resource Group),创建 Azure 虚拟机和安装 LAMP 都在该资源组中进行,运行以下命令创建 Azure 资源组:

azure group create "YOUR-RESOURCE-GROUP-NAME" "China East"

您需要在安装好 Azure CLI 的机器上,运行如下命令下载 azuredeploy.parameters.json 参数配置文件:

wget http://msmirrors.blob.core.chinacloudapi.cn/single-lamp/azuredeploy.parameters.json -O azuredeploy.parameters.json

接着修改 azuredeploy.parameters.json 参数配置文件:

vi azuredeploy.parameters.json

需修改 "adminPassword", "dnsNamePrefix" 以及 "mySqlPassword" 的值即可,其他参数值可以保持默认不变。然后运行如下命令即可安装 CentOS 虚拟机和 LAMP,创建过程大概需要 20 分钟,其中 rg1 是之前步骤中创建的资源组名字:

$TemplateUri="http://msmirrors.blob.core.chinacloudapi.cn/single-lamp/azuredeploy.json"
azure group deployment create rg1 DeployLAMP --template-uri $TemplateUri -e azuredeploy.parameters.json

使用 SHELL 脚本方式

如果您已经建好了 LINUX 虚拟机,就可以直接运行 SHELL 脚本来安装 LAMP.

如果您还没有 Azure 下的 LINUX 虚拟机,请参考 Azure Linux VM tutorial. 创建 LINUX 虚拟机。

连接到您的 LINUX 虚拟机。如果这是您第一次使用 Azure 的 LINUX 虚拟机,请参考 Azure Linux VM tutorial 连接到虚拟机。

不同的 LINUX 发行版在安装 LAMP 时有少许的不同。请根据您的 LINUX 版本选择对应的步骤。

Redhat base Linux: (以 CentOS 7.0, 64-bit system, MySQL Server 5.6, apache 2.4, php5 为例)

下载SHELL脚本:

$sudo wget http://msmirrors.blob.core.chinacloudapi.cn/single-lamp/install_single_lamp.sh

然后执行下面命令。注意:其中的 mySqlPassword 指的是您的 MySQL root 密码,请根据您的具体情况设置;insertValue 指的是您要往 MySQL 测试表中写入的值,这个值在访问 http://yourwebsite/mysql.php 会显示出来。

比如您运行 sudo bash install_single_lamp.sh s3cret jack 那么 s3cret 就是您的 MySQL root 密码,jack 就是要写入 MySQL 测试表中的值。

$sudo bash install_single_lamp.sh mySqlPassword insertValue

Ubuntu Linux: (以 Ubuntu 14.04, 64-bit system, MySQL 5.5, apache 2.4, php5 为例)

下载SHELL脚本:

$sudo wget http://msmirrors.blob.core.chinacloudapi.cn/single-lamp/install_single_lamp_Ubuntu.sh

然后执行下面命令。注意:其中的 mySqlPassword 指的是您的 MySQL root 密码,请根据您的具体情况设置;insertValue 指的是您要往 MySQL 测试表中写入的值,这个值在访问 http://yourwebsite/mysql.php 会显示出来。 比如您运行 sudo bash install_single_lamp_Ubuntu.sh s3cret jack 那么 s3cret 就是您的 MySQL root 密码,jack 就是要写入 MySQL 测试表中的值。

$sudo bash install_single_lamp_Ubuntu.sh mySqlPassword insertValue

SUSE Linux: (以 SLES 12, 64-bit system, MySQL Server 5.6, apache 2.4, php5 为例)

下载 SHELL 脚本:

$sudo wget http://msmirrors.blob.core.chinacloudapi.cn/single-lamp/install_single_lamp_SLES.sh

然后执行下面命令。注意:其中的 mySqlPassword 指的是您的 MySQL root 密码,请根据您的具体情况设置;insertValue 指的是您要往 MySQL测试表中写入的值,这个值在访问 http://yourwebsite/mysql.php 会显示出来。

比如您运行 sudo bash install_single_lamp_SLES.sh s3cret jack 那么 s3cret 就是您的 MySQL root 密码,jack 就是要写入MySQL 测试表中的值。

$sudo bash install_single_lamp_SLES.sh mySqlPassword insertValue

  

05-26 18:30