1.LAMP简介与概述
1.1 LAMP平台概述
LAMP架构是目前成熟的企业网站应用模式之一,指的是协同工作的一整台系统和相关软件,能够提供动态web站点服务及其应用开发环境
LAMP是一个缩写词,具体包括Linux操作系统,Apache网站服务器,MySQL数据库服务器,PHP(或perl,Python)网页编程语言
1.2 LAMP各组件作用
(平台)Linux:作为LAMP架构的基础,提供用于支撑Web站点的操作系统,能够与其他三个组件提供更好的稳定性,兼容性(AMP组件也支持Windows、UNIX等平台) 。
(前台)Apache:作为LAMP架构的前端,是一款功能强大,稳定性好的Web服务器程序,该服务器直接面向用户提供网站访问,发送网页,图片等文件内容。
(后台)MySQL:作为LAMP架构的后端,是一款流行的开源关系数据库系统。在企业网站、业务系统等应用中,各种账户信息、产品信息,客户资料、业务数据等都可以存储到MySQL数据库,其他程序可以通过SQL语句来查询,更改这些信息。
(中间连接)PHP/Perl/Python:作为三种开发动态网页的编程语言,负责解释动态网页文件,负责沟通Web服务器和数据库系统以协同工作,并提供Web应用程序的开发和运行环境。其中PHP是一种被广泛应用的开放源代码的多用途脚本语言,它可以嵌入到HTML中,尤其适合于Web应用开发。
1.3 构建LAMP平台顺序
在构建LAMP平台时,各组件的安装顺序依次为Linux,Apache,MySQL,PHP
其中Apache和MySQL的安装并没有严格的顺序要求,而PHP环境的安装一般放到最后,负责沟通web服务器和数据库系统以协同工作
2.编译安装Apache httpd服务
2.1 将所需软件安装包下载到/opt目录下
2.2 解压以下文件
<code style="margin-left:0">[root@localhost opt]#tar zxf apr-1.6.2.tar.gz [root@localhost opt]#tar zxf apr-util-1.6.0.tar.gz [root@localhost opt]#tar jxf httpd-2.4.29.tar.bz2</code>
2.3 移动两个文件并改名
<code style="margin-left:0">[root@localhost opt]#mv apr-1.6.2 httpd-2.4.29/srclib/apr [root@localhost opt]#mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util [root@localhost opt]#ls httpd-2.4.29/srclib/ apr apr-util Makefile.in</code>
2.4 安装一下小工具
<code style="margin-left:0">[root@localhost opt]#cd httpd-2.4.29/ [root@localhost httpd-2.4.29]#yum -y install \> gcc \ #C语言的编译器 > gcc-c++ \ #C++的编译器 > make \ > pcre-devel \ #perl的接口开发包 > expat-devel \ #用于支持网站解析HTML、XML文件 > perl #perl语言编译器</code>
2.5 编译安装
<code style="margin-left:0">##./configure编译 [root@localhost opt]#./configure \ --prefix=/usr/local/httpd \ #指定 httpd 服务程序的安装路径 --enable-so \ #启用动态加载核心模块支持,使 httpd 具备进一步扩展功能的能力 --enable-rewrite \ #启用网页地址重写功能,用于网站优化、防盗链及目录迁移维护 --enable-charset-lite \ #启动字符集支持,以便支持使用各种字符集编码的页面 --enable-cgi #启用CGI(通用网关接口)脚本程序支持,便于增强网站的外部扩展应用访问能力 #安装一下 [root@localhost opt]#make && make install -j4</code>
2.6 优化配置文件路径,并把httpd服务的可执行程序文件放入路径环境变量的目录中便于系统识别
<code style="margin-left:0">##复制 [root@localhost bin]#cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd ##修改脚本 [root@localhost bin]#vi /etc/init.d/httpd # chkconfig: 35 85 21 //35级别自动运行 第85个启动 第21个关闭 # description: Apache is a World Wide Web server #//将httpd加入到SERVICE管理器 [root@localhost bin]#chkconfig --add httpd ##修改配置文件 [root@localhost bin]#vi /usr/local/httpd/conf/httpd.conf 注释掉52行,修改第51行 #51行,监听地址为自己的ip地址 Listen 192.168.59.105:80 #197行 ServerName www.yxp.com:80</code>
2.7 做软链接,使文件可执行
<code style="margin-left:0">[root@localhost bin]#ln -s /usr/local/httpd/conf/httpd.conf /etc/ [root@localhost bin]#ln -s /usr/local/httpd/bin/* /usr/local/bin/</code>
2.8 关闭防火墙,并查看语法是否有问题并开启服务
<code style="margin-left:0">[root@localhost bin]#systemctl stop firewalld.service [root@localhost bin]#setenforce 0 [root@localhost bin]#httpd -t Syntax OK #说明语法没问题 #开启服务 [root@localhost bin]#service httpd start [root@localhost bin]#netstat -anpt | grep 80 tcp 0 0 192.168.59.105:80 0.0.0.0:* LISTEN 39007/httpd </code>
网页输入自己ip测试
2.编译安装mysql
2.1 安装依赖包并解压下载的mysql
<code style="margin-left:0">[root@localhost opt]#yum install -y ncurses-devel autoconf cmake [root@localhost opt]#tar zxf mysql-5.6.26.tar.gz </code>
2.2 编译安装
<code style="margin-left:0">[root@localhost opt]#cd mysql-5.6.26/ #切换解压后的至目录 [root@localhost mysql-5.6.26]#cmake \ > -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ > -DDEFAULT_CHARSET=utf8 \ #指定默认使用的字符集编码,如 utf-8 > -DDEFAULT_COLLATION=utf8_general_ci \ #指定默认使用的字符集校对规则 > -DEXTRA_CHARSETS=all \ #指定支持其他字符集编码 > -DSYSCONFIDIR=/etc \ #/etc/mysql --->系统中有一个默认的配置/etc/my.cnf > -DMYSQL_DATADIR=/home/mysql/ \ #数据文件 > -DMYSQL_UNIX_ADDR=/home/mysql/mysql.sock #指定连接数据库的通讯文件(启动数据库的时候会生成) [root@localhost opt]#make && make install -j4</code>
2.3 拷贝文件并授权
<code style="margin-left:0">[root@localhost mysql-5.6.26]#cp support-files/my-default.cnf /etc/my.cnf cp:是否覆盖"/etc/my.cnf"? y [root@localhost mysql-5.6.26]#cp support-files/mysql.server /etc/init.d/mysqld [root@localhost mysql-5.6.26]#chmod 755 /etc/init.d/mysqld [root@localhost mysql-5.6.26]#chkconfig --add /etc/init.d/mysqld [root@localhost mysql-5.6.26]#chkconfig mysqld --level 35 on</code>
2.4 设置环境变量,申明/宣告mysql命令便于系统识别
<code style="margin-left:0">[root@localhost mysql-5.6.26]#source /etc/profile [root@localhost mysql-5.6.26]#echo $PATH /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/mysql/bin</code>
2.5 创建普通用户管理mysql
<code style="margin-left:0">[root@localhost mysql-5.6.26]#useradd -s /sbin/nologin mysql useradd:用户“mysql”已存在 [root@localhost mysql-5.6.26]#ls /home/ test1 test8 zzq [root@localhost mysql-5.6.26]#chown -R mysql:mysql /usr/local/mysql/ [root@localhost mysql-5.6.26]#ll -d /usr/local/mysql/ drwxr-xr-x. 13 mysql mysql 213 12月 6 15:51 /usr/local/mysql/</code>
2.6 初始化数据库
<code style="margin-left:0">[root@localhost mysql-5.6.26]# /usr/local/mysql/scripts/mysql_install_db \ --user=mysql \ --ldata=/var/lib/mysql \ --basedir=/usr/local/mysql \ --datadir=/home/mysql</code>
2.7 修改配置文件并启动mysql
<code style="margin-left:0">#修改配置文件 [root@localhost mysql-5.6.26]#vim /etc/init.d/mysqld ##修改46,47行 basedir=/usr/local/mysql datadir=/home/mysql #启动mysql [root@localhost mysql-5.6.26]#service mysqld start Starting MySQL. SUCCESS! [root@localhost mysql-5.6.26]#ss -ntap|grep "3306" LISTEN 0 80 :::3306 :::* users:(("mysqld",pid=55337,fd=10)) [root@localhost mysql-5.6.26]#</code>
2.8 登录及登出mysql
<code style="margin-left:0">#给root账号设置密码 [root@localhost mysql-5.6.26]#mysqladmin -u root -p password "abc123" #登录mysql [root@localhost mysql-5.6.26]#mysql -u root -p mysql> show databases; #查看数据库的表 #登出mysql mysql> exit Bye</code>
3.安装PHP
3.1 安装工具
<code style="margin-left:0">[root@localhost mysql-5.6.26]# yum -y install \ gd \ #图像化处理的库 libpng \ #png格式图片的库 libpng-devel \ pcre \ #PCRE库支持正则表达式 pcre-devel \ #pcre-devel是使用PCRE做二次开发时所需要的开发库,也是编译安装需要的 libxml2-devel \ #解析xml标记语言的库 libjpeg-devel #jpeg格式图片的库</code>
3.2 切换至opt目录下解压PHP文件
<code style="margin-left:0">[root@localhost mysql-5.6.26]#cd /opt/ [root@localhost opt]#tar jxf php-5.6.11.tar.bz2 </code>
3.3 切换至php目录下,编译安装
<code style="margin-left:0">##编译 [root@localhost php-5.6.11]# yum -y install \ gd \ #图像化处理的库 libpng \ #png格式图片的库 libpng-devel \ pcre \ #PCRE库支持正则表达式 pcre-devel \ #pcre-devel是使用PCRE做二次开发时所需要的开发库,也是编译安装需要的 libxml2-devel \ #解析xml标记语言的库 libjpeg-devel #jpeg格式图片的库 ##安装 [root@localhost php-5.6.11]#make && make install -j4</code>
3.4 优化把php的可执行程序文件放入路径环境变量的目录中便于系统识别
<code style="margin-left:0">[root@localhost php-5.6.11]#ln -s /usr/local/php5/bin/* /usr/local/bin/</code>
3.5 修改Apache配置文件让Apache支持PHP
<code style="margin-left:0">[root@localhost php-5.6.11]#vim /etc/httpd.conf #添加index.php 255 <IfModule dir_module> 256 DirectoryIndex index.html index.php 257 </IfModule> #在392行下方插入一下内容,让Apache可以支持.php的网页文件 AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps</code>
3.6 创建网页
<code style="margin-left:0">[root@localhost php-5.6.11]#vim /usr/local/httpd/htdocs/index.php <?php phpinfo(); ?></code>
3.7 重启服务
<code style="margin-left:0">[root@localhost php-5.6.11]#service httpd stop [root@localhost php-5.6.11]#service httpd start</code>
3.8 在网页测试
在网页输入网址http://192.168.52.101/index.php
IP地址是自己的地址
4.安装论坛
4.1 创建一个数据库
<code style="margin-left:0">#登入数据库 [root@localhost php-5.6.11]#mysql -u root -p mysql> CREATE DATABASE bbs; #创建一个数据库 GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123'; #把bbs数据库里面所有表的权限授予给bbsuser,并设置密码// 所有访问来源/渠道 mysql> flush privileges; #刷新数据库 mysql> show databases; #查看数据库 mysql> exit #登出</code>
4.2 解压论坛文件并复制文件到指定目录
<code style="margin-left:0">[root@localhost opt]#unzip /opt/Discuz_X2.5_SC_UTF8.zip -d /opt/dis #切换至指定目录复制文件 [root@localhost opt]#cd dis/ [root@localhost dis]#ls readme upload utility [root@localhost dis]#cp -r upload/ /usr/local/httpd/htdocs/bbs</code>
4.3 给指定文件授权
<code style="margin-left:0">#切换至指定目录 [root@localhost httpd]#cd /usr/local/httpd/htdocs/bbs/ #授权 [root@localhost bbs]#chown -R daemon ./config [root@localhost bbs]#chown -R daemon ./data [root@localhost bbs]#chown -R daemon ./uc_client [root@localhost bbs]#chown -R daemon ./uc_server/data</code>
4.4 登录论坛测试
在网页输入网址http://192.168.52.101/bbs自己的地址
<code style="margin-left:0">#登入mysql [root@localhost bbs]#mysql -u root -p ##输入以下三个命令## mysql> select user,host from mysql.user; mysql> delete from mysql.user where user=''; mysql> flush privileges; mysql> exit #登出 Bye</code>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/181069.html原文链接:https://javaforall.cn
未经允许不得转载:木盒主机 » Lamp架构_公司网络架构与配置