LAMP架构部署和动态网站环境的配置
实验环境:
操作系统:centos7.5
服务器IP:192.168.10.5
运行用户:root
连接工具:xshell工具
web环境:Linux+apache+php+mariadb(LAMP架构)
大型动态应用系统平台主要是针对于大流量、高并发网站建立的底层系统架构。大型网站的运行需要一个可靠、安全、可扩展、易维护的应用系统平台做为支撑,以保证网站应用的平稳运行。这些东西都需要依靠web服务器来支撑,里面应用到的技术有单节点web服务器系统、负载均衡系统、数据集群系统、缓存系统、分布式存储系统、分布式服务器管理系统、代码发布系统等,现在企业一般都流行使用自动化系统部署,可以把web业务全部跑在docker容器中,简化了运维配置流程,下面我们简单的介绍下web服务器单节点的部署及使用。
本文属于原创,比较适合企业应用,具体详细的介绍可以参考《Linux就该这么学》里边教程的第20章,里面详细的介绍了LNMP架构,而我这里是介绍LAMP架构,LAMP、LNMP在企业都应用比较广泛,一般大型企业网站都会在Linux服务器上面跑,节约资源、提高web服务器性能及安全性。
单节点web服务器
通过系统自带的yum源安装,也可以通过本地镜像配置本地yum源,还可以通过rpm包或者tar.gz源码包编译后再安装;通过yum安装是比较方便的,安装过程会自动把依赖包自动安装上去;通过rpm包安装过程中需要根据提示寻找依赖包,这种安装方式比较麻烦;下面我们来通过yum源安装方式来演示给大家看。
apache是一款开源的web服务器,它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的Web服务器端软件之最,apache在企业应用也是比较广泛的。特别是结合Linux操作系统发挥最优的性能。
1、install apache
# yuminstall httpd.x86_64 httpd-devel.x86_64 -y //安装apache
[if !vml]
[endif]
# rpm -qahttpd //查看apache是否安装成功
[if !vml]
[endif]
# httpd-v //查看apache版本
Serverversion: Apache/2.4.6 (CentOS)
Serverbuilt: Jun 27 2018 13:48:59
# systemctlstart httpd.service //启动apache服务
# systemctlstatus httpd.service //查看apache服务状态
# systemctlstop httpd.service //停止apache服务
# systemctlenable httpd.service //设置开机自动启动apache服务
apache默认配置文件路径:/etc/httpd/
[if !vml]
[endif]
apache默认web路径:/var/www/html ,默认里面是空目录
[if !vml]
[endif]
PHP 是一种创建动态交互性站点的强有力的服务器端脚本语言;PHP 是开源的,并且使用非常广泛;同时,对于像微软asp、asp.net服务器脚本语言竞争者来说,PHP 无疑是另一种高效率的选项,PHP有点:开源性、处理快、易上手、跨平台,效率高、适用于大型网站架构,一般PHP都是结合Linuxapache nginx mysql;iis+php极少,配置复杂、性能差。下面就简单介绍下php的安装及配置。
2、install php
# yuminstall php php-common php-fpm php-gd php-soap php-json php-ldap php-mbstringphp-mysqlnd php-mysqld php-xml php-xmlrpc php-opcache php-simplexml php-bcmath-y
[if !vml]
[endif]
# rpm -qaphp* //查看安装的PHP模块
[if !vml]
[endif]
# php-v //查看php版本
[if !vml]
[endif]
# ll/etc/php.ini //php默认配置文件,配置文件里面详细参数这里就不一一介绍了。
[if !vml]
[endif]
MySQL最初也是开源的,后来被Oracle公司收购后5.5后的版本开始收费了,后来又有了MariaDB数据库,MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品,MariaDB开源、跨平台、性能强、易扩展、应用广。
3、install mariadb
# yuminstall mariadb.x86_64 mariadb-server.x86_64 mariadb-devel.x86_64 -y
[if !vml]
[endif]
# rpm -qamariadb //查看mariadb是否安装成功
[if !vml]
[endif]
# systemctlstart mariadb.service //启动数据库服务
# systemctlstop mariadb.service //停止数据库服务
# systemctlstatus mariadb.service //查看数据库服务状态
# systemctlenable mariadb.service //设置开机自动启动数据库服务
mariadb安装后启动服务,数据库root用户是没有密码的,需要进行初始化并设置密码,配置如下:
#mysql_secure_installation
NOTE:RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
In order tolog into MariaDB to secure it, we'll need the current
password forthe root user. If you've just installedMariaDB, and
you haven'tset the root password yet, the password will be blank,
so youshould just press enter here.
Entercurrent password for root (enter for none): //直接回车
OK,successfully used password, moving on...
Setting theroot password ensures that nobody can log into the MariaDB
root userwithout the proper authorisation.
Set rootpassword? [Y/n] y //y设置root用户密码
Newpassword: //输入密码
Re-enter newpassword: //确定密码
Passwordupdated successfully!
Reloadingprivilege tables..
... Success!
By default,a MariaDB installation has an anonymous user, allowing anyone
to log intoMariaDB without having to have a user account created for
them. This is intended only for testing, and tomake the installation
go a bitsmoother. You should remove them beforemoving into a
productionenvironment.
Removeanonymous users? [Y/n] y //y删除匿名用户
... Success!
Normally,root should only be allowed to connect from 'localhost'. This
ensures thatsomeone cannot guess at the root password from the network.
Disallowroot login remotely? [Y/n] y //y禁止root远程登录
... Success!
By default,MariaDB comes with a database named 'test' that anyone can
access. This is also intended only for testing, andshould be removed
beforemoving into a production environment.
Remove testdatabase and access to it? [Y/n] n //n不删除test数据库,根据自己需求定。
... skipping.
Reloadingthe privilege tables will ensure that all changes made so far
will takeeffect immediately.
Reloadprivilege tables now? [Y/n] y //刷新数据表
... Success!
Cleaningup...
Alldone! If you've completed all of theabove steps, your MariaDB
installationshould now be secure.
Thanks forusing MariaDB!
# mysql -h127.0.0.1 -u root -p //连接数据库
[if !vml]
[endif]
4、test web service,apache + php +mariadb安装启动服务后就开始测试。
4.1、通过浏览器访问web服务器出现如下解密说明apache安装成功。
http://192.168.10.5
[if !vml]
[endif]
4.2、测试apache+php
# vim/var/www/html/index.php
phpinfo();
?>
http://192.168.10.5/index.php
[if !vml]
[endif]
4.3、测试apache+php+mariadb
# vim/var/www/html/mysqld.php
$servername = "localhost";
$username = "root";
$password = "password";
// 创建连接
$conn = new mysqli($servername, $username, $password);
// 检测连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
echo "连接成功";
?>
http://192.168.10.5/mysqld.php
[if !vml]
[endif]