【网站架构部署与优化】源码编译安装LAMP
文章目录
- LAMP架构概述
- 各组件的主要作用
- 构建LAMP平台的安装顺序
- 编译安装Apache httpd服务指南
- 1. 准备工作
- 1.1 关闭防火墙并传输软件包
- 1.2 安装环境依赖包
- 2. 配置软件模块
- 2.1 解压软件包
- 2.2 移动apr组件包
- 2.3 配置httpd
- 3. 编译及安装
- 4. 优化配置
- 4.1 配置文件路径
- 4.2 添加httpd系统服务
- 方法一:使用init.d
- 方法二:使用systemd
- 5. 修改httpd服务配置文件
- 5.1 编辑httpd.conf
- 5.2 检查配置文件并重启服务
- 6. 浏览器访问验证
- 6.1 检查端口监听
- 6.2 添加hosts记录
- 6.3 访问测试
- 编译安装MySQL服务完整指南
- 一、前期准备
- 二、配置与编译
- 三、设置与启动
- 四、安全配置
- 注意事项
- 编译安装PHP解析环境及论坛搭建指南
- 一、编译安装PHP解析环境
- 二、安装论坛
- 注意
LAMP架构概述
LAMP架构是企业级网站应用开发中广泛采用的一种成熟模式,它代表了一套协同工作的系统和软件组合,专为提供动态Web站点服务及其应用开发环境而设计。LAMP是Linux、Apache、MySQL、PHP(或Perl、Python)四个组件首字母的缩写,每个组件都扮演着关键角色。
各组件的主要作用
- Linux(平台):
- 作为LAMP架构的基础,Linux提供了稳定且高效的操作系统环境,为Web站点提供坚实的支撑。其强大的兼容性和稳定性使得AMP组件(Apache、MySQL、PHP/Perl/Python)能够在其上顺畅运行,同时也支持跨平台部署,尽管AMP本身也兼容Windows、UNIX等平台。
- Apache(前台):
- 作为LAMP架构的前端,Apache是一款广受欢迎的Web服务器软件,以其强大的功能和卓越的稳定性著称。它直接面向用户,负责处理来自客户端的请求,发送网页、图片等文件内容,是用户与Web站点之间交互的桥梁。
- MySQL(后台):
- MySQL是LAMP架构中的数据库服务器组件,是一款开源的关系数据库管理系统。它负责存储网站和应用程序所需的各种数据,如账户信息、产品信息、客户资料、业务数据等。通过SQL语句,其他程序可以方便地查询、更新这些信息,实现数据的动态管理和交互。
- PHP/Perl/Python(中间连接):
- 这三种编程语言在LAMP架构中扮演着沟通Web服务器和数据库系统的关键角色。它们负责解释和执行动态网页文件,将用户请求的数据传递给数据库,并将数据库返回的结果以网页形式展示给用户。其中,PHP因其易于学习、广泛支持和与HTML紧密集成的特性,在Web应用开发中尤为受欢迎。
构建LAMP平台的安装顺序
在构建LAMP平台时,通常按照Linux、Apache、MySQL、PHP的顺序进行安装。虽然Apache和MySQL的安装顺序并不严格,但PHP环境的安装一般放在最后,以确保它能够正确地与Web服务器和数据库系统协同工作。这样的安装顺序有助于避免依赖性问题,并确保整个系统的稳定性和兼容性。
编译安装Apache httpd服务指南
1. 准备工作
1.1 关闭防火墙并传输软件包
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
将以下软件包传到/opt
目录下:
- httpd-2.4.29.tar.gz
- apr-1.6.2.tar.gz
- apr-util-1.6.0.tar.gz
1.2 安装环境依赖包
yum -y install gcc gcc-c++ make pcre pcre-devel expat-devel perl
2. 配置软件模块
2.1 解压软件包
cd /opt/
tar zxvf apr-1.6.2.tar.gz
tar zxvf apr-util-1.6.0.tar.gz
tar jxvf httpd-2.4.29.tar.bz2
2.2 移动apr组件包
mv apr-1.6.2 /opt/httpd-2.4.29/srclib/apr
mv apr-util-1.6.0 /opt/httpd-2.4.29/srclib/apr-util
2.3 配置httpd
cd /opt/httpd-2.4.29/
./configure --prefix=/usr/local/httpd --enable-so --enable-rewrite --enable-charset-lite --enable-cgi
3. 编译及安装
make
make install
4. 优化配置
4.1 配置文件路径
ln -s /usr/local/httpd/conf/httpd.conf /etc/
ln -s /usr/local/httpd/bin/* /usr/local/bin/
4.2 添加httpd系统服务
方法一:使用init.d
cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
chmod +x /etc/init.d/httpd
# 编辑/etc/init.d/httpd文件,添加以下内容:
#!/bin/bash
# chkconfig: 35 85 21
# description: Apache is a World Wide Web server
chkconfig --add httpd
systemctl start httpd.service
# 或
service httpd start
方法二:使用systemd
vim /lib/systemd/system/httpd.service
# 编辑httpd.service文件,添加或修改以下内容:
[Unit]
Description=The Apache HTTP Server
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/httpd/logs/httpd.pid
ExecStart=/usr/local/bin/apachectl $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
[Install]
WantedBy=multi-user.target
systemctl start httpd.service
systemctl enable httpd.service
5. 修改httpd服务配置文件
5.1 编辑httpd.conf
vim /etc/httpd.conf
# 修改以下行:
Listen 192.198.80.10:80
ServerName www.kgc.com:80
DocumentRoot "/usr/local/httpd/htdocs"
DirectoryIndex index.html
5.2 检查配置文件并重启服务
httpd -t # 或 apachectl -t
systemctl restart httpd.service
6. 浏览器访问验证
6.1 检查端口监听
netstat -anpt | grep 80
6.2 添加hosts记录
echo "192.168.80.10 www.kgc.com" >> /etc/hosts
6.3 访问测试
在浏览器中输入以下地址进行测试:
- http://192.168.80.10
- http://www.kgc.com
编译安装MySQL服务完整指南
一、前期准备
- 传输软件包
将以下软件包传输到/opt
目录下:mysql-5.7.17.tar.gz
boost_1_59_0.tar.gz
(支持C++的运行库)
- 安装环境依赖包
运行以下命令安装必要的编译工具和库:
gcc
gcc-c++
ncurses \ #字符终端下图形互动功能的动态库
ncurses-devel \ #ncurses开发包
bison \ #语法分析器
cmake #mysql需要用cmake编译安装yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake openssl-devel
二、配置与编译
-
解压软件包
tar zxvf mysql-5.7.17.tar.gz tar zxvf boost_1_59_0.tar.gz cd /opt mv boost_1_59_0 /usr/local/boost #重命名
-
配置CMake
进入MySQL源码目录并执行CMake配置:cd /opt/mysql-5.7.17/ cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #指定mysql的安装路径 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ #指定mysql进程监听套接字文件(数据库连接文件)的存储路径 -DSYSCONFDIR=/etc \#指定配置文件的存储路径 -DSYSTEMD_PID_DIR=/usr/local/mysql \#指定进程文件的存储路径 -DDEFAULT_CHARSET=utf8 \#指定默认使用的字符集编码,如 utf8 -DDEFAULT_COLLATION=utf8_general_ci \#指定默认使用的字符集校对规则 -DWITH_EXTRA_CHARSETS=all \#指定支持其他字符集编码 -DWITH_INNOBASE_STORAGE_ENGINE=1 \#安装INNOBASE存储引擎 -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ #安装ARCHIVE存储引擎 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ #安装BLACKHOLE存储引擎 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ #安装FEDERATED存储引擎 -DMYSQL_DATADIR=/usr/local/mysql/data \#指定数据库文件的存储路径 -DWITH_BOOST=/usr/local/boost \#指定boost的路径,若使用mysql-boost集成包安装则-DWITH_BOOST=boost -DWITH_SYSTEMD=1#生成便于systemctl管理的文件
注意:若CMake报错,删除CMakeCache.txt
后重试。
存储引擎选项:
MYISAM,MERGE,MEMORY,和CSV引擎是默认编译到服务器中,并不需要明确地安装。
静态编译一个存储引擎到服务器,使用-DWITH_engine_STORAGE_ENGINE= 1
可用的存储引擎值有:ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE (InnoDB), PARTITION (partitioning support), 和PERFSCHEMA (Performance Schema)
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
- 编译及安装
make && make install
三、设置与启动
-
创建MySQL用户
useradd -M -s /sbin/nologin mysql
-
修改MySQL配置文件
编辑/etc/my.cnf
文件,设置相关参数如端口、字符集、数据目录等。
vim /etc/my.cnf #删除原配置项,再重新添加下面内容
[client] #客户端设置
port = 3306
socket = /usr/local/mysql/mysql.sock
[mysql] #服务端设置
port = 3306
socket = /usr/local/mysql/mysql.sock
auto-rehash #开启自动补全功能
[mysqld] #服务全局设置
user = mysql #设置管理用户
basedir=/usr/local/mysql #指定数据库的安装目录
datadir=/usr/local/mysql/data #指定数据库文件的存储路径
port = 3306 #指定端口
character-set-server=utf8mb4 #设置服务器字符集编码格式为utf8
pid-file = /usr/local/mysql/mysqld.pid #指定pid 进程文件路径
socket=/usr/local/mysql/mysql.sock #指定数据库连接文件
bind-address = 0.0.0.0 #设置监听地址,0.0.0.0代表允许所有,如允许多个IP需空格隔开
skip-name-resolve #禁止域名解析,包括主机名,所以授权的时候要使用 IP 地址
max_connections=4096 #设置mysql的最大连接数
default-storage-engine=INNODB #指定默认存储引擎
max_allowed_packet=32M #设置在网络传输中一次消息传输量的最大值。系统默认值为 1MB,最大值是 1GB,必须设置 1024 的倍数。
server-id = 1 #指定服务ID号
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
sql_mode常用值如下:
NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
STRICT_TRANS_TABLES
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
NO_AUTO_CREATE_USER
禁止GRANT创建密码为空的用户
NO_AUTO_VALUE_ON_ZERO
mysql中的自增长列可以从0开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
NO_ZERO_IN_DATE
不允许日期和月份为零
NO_ZERO_DATE
mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
ERROR_FOR_DIVISION_BY_ZERO
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MySQL返回NULL
PIPES_AS_CONCAT
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
ANSI_QUOTES
启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符
[client]
port = 3306
socket=/usr/local/mysql/mysql.sock
[mysql]
port = 3306
socket = /usr/local/mysql/mysql.sock
auto-rehash
[mysqld]
user = mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
port = 3306
character-set-server=utf8mb4
pid-file = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
max_connections=4096
default-storage-engine=INNODB
max_allowed_packet=32M
server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
-
更改文件权限
chown -R mysql:mysql /usr/local/mysql/ chown mysql:mysql /etc/my.cnf
-
设置环境变量
echo 'export PATH=/usr/local/mysql/bin:$PATH' >> /etc/profile source /etc/profile
-
初始化数据库
cd /usr/local/mysql/bin/ ./mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
--initialize-insecure \ #生成初始化密码为空
--user=mysql \ #指定管理用户
--basedir=/usr/local/mysql \ #指定数据库的安装目录
--datadir=/usr/local/mysql/data #指定数据库文件的存储路径
- 添加系统服务
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ systemctl daemon-reload systemctl start mysqld.service systemctl enable mysqld netstat -anpt | grep 3306
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ #用于systemctl服务管理
systemctl daemon-reload #刷新识别
systemctl start mysqld.service #开启服务
systemctl enable mysqld #开机自启动
netstat -anpt | grep 3306 #查看端口
四、安全配置
- 修改登录密码
mysqladmin -u root password "abc123"
- 授权远程登录
登录MySQL并执行:mysql -u root -p grant all privileges on *.* to 'root'@'%' identified by 'abc123'; show databases;
grant all privileges on *.* to 'root'@'%' identified by 'abc123';
#授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限
show databases; #查看当前已有的数据库
注意事项
- 在生产环境中,请务必修改默认的root密码,并限制远程访问权限以提高安全性。
- 定期备份数据库以防数据丢失。
- 根据实际需求调整
my.cnf
中的配置参数。
编译安装PHP解析环境及论坛搭建指南
一、编译安装PHP解析环境
-
传输PHP软件包
将php-7.1.10.tar.bz2
传输到/opt
目录下。 -
安装依赖库
运行以下命令安装GD库及相关依赖:yum -y install gd libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel curl curl-devel openssl openssl-devel
-
配置PHP模块
cd /opt tar xf php-7.1.10.tar.bz2 cd /opt/php-7.1.10/ ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/httpd/bin/apxs --with-mysql-sock=/usr/local/mysql/mysql.sock --with-config-file-path=/usr/local/php/lib --with-mysqli --with-zlib --with-curl --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-openssl --enable-mbstring --enable-xml --enable-session --enable-ftp --enable-pdo --enable-tokenizer --enable-zip
cd /opt
tar xf php-7.1.10.tar.bz2
cd /opt/php-7.1.10/
./configure \
--prefix=/usr/local/php \ #指定将 PHP 程序的安装路径
--with-apxs2=/usr/local/httpd/bin/apxs \#指定Apache httpd服务提供的apxs 模块支持程序的文件位置
--with-mysql-sock=/usr/local/mysql/mysql.sock \#指定mysql 数据库连接文件的存储路径
--with-config-file-path=/usr/local/php/lib #设置 PHP 的配置文件 php.ini 将要存放的位置
--with-mysqli \ #添加 MySQL 扩展支持,mysqli扩展技术不仅可以调用MySQL的存储过程、处理MySQL事务,而且还可以使访问数据库工作变得更加稳定
--with-zlib \ #支持zlib功能,提供数据压缩
--with-curl \ #开启curl扩展功能,实现HTTP的Get下载和Post请求的方法
--with-gd \ #激活gd 库的支持
--with-jpeg-dir \ #激活jpeg 的支持
--with-png-dir \ #激活png 的支持
--with-freetype-dir \
--with-openssl \
--enable-mbstring \ #启用多字节字符串功能,以便支持中文等代码
--enable-xml \ #开启扩展性标记语言模块
--enable-session \ #会话
--enable-ftp \ #文本传输协议
--enable-pdo \ #函数库
--enable-tokenizer \#令牌解释器
--enable-zip #ZIP压缩格式
-
编译及安装PHP
make && make install
-
设置环境变量
创建符号链接以便系统识别PHP可执行程序:ln -s /usr/local/php/bin/* /usr/local/bin/ php -m # 查看加载的模块
-
配置PHP主文件
复制并修改php.ini
文件:cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini#在测试环境时使用php.ini-development文件,而在生产环境时使用php.ini-production文件 vim /usr/local/php/lib/php.ini # 修改mysqli.default_socket和date.timezone --1170行--修改 mysqli.default_socket = /usr/local/mysql/mysql.sock --939行--取消注释,修改 date.timezone = Asia/Shanghai
-
配置Apache支持PHP
编辑httpd.conf
文件以添加PHP类型支持并修改首页文件:vim /etc/httpd.conf # 插入AddType行并修改DirectoryIndex --393行--插入以下内容 AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps --255行--修改首页文件名设置 DirectoryIndex index.html index.php #---检查支持php7的模块是否存在------ LoadModule php7_module modules/libphp7.so
-
验证PHP测试页
创建index.php
文件并重启Apache服务,然后在浏览器中访问测试。rm -rf /usr/local/httpd/htdocs/index.html vim /usr/local/httpd/htdocs/index.php <?php phpinfo(); ?> systemctl restart httpd.service
浏览器访问
http://192.168.80.10(主机地址)
二、安装论坛
-
创建数据库并授权
登录MySQL创建数据库及用户,并授予权限:mysql -u root -p CREATE DATABASE bbs;#创建数据库 GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';#把bbs数据库里面所有表的权限授予给bbsuser,并设置密码admin123 flush privileges;#刷新数据库 show databases;
-
解压论坛压缩包
解压并将论坛文件复制到Apache的htdocs目录下:unzip /opt/Discuz_X3.4_SC_UTF8.zip -d /opt/dis cd /opt/dis/dir_SC_UTF8/ cp -r upload/ /usr/local/httpd/htdocs/bbs#上传站点更新包
-
更改论坛目录权限
根据论坛进程用户名修改相关目录权限:chown -R daemon ./config ./data ./uc_client ./uc_server/data
-
验证论坛访问
在浏览器中访问论坛页面及后台管理员页面进行验证。
论坛页面访问:
http://192.168.80.10/bbs
数据库服务器:localhost #本地架设就用localhost,如何不是在在本机上就要填写IP地址和端口号
数据库名字:bbs
数据库用户名:bbsuser
数据库密码:admin123
管理员账号:admin
管理员密码:admin123
论坛后台管理员页面
http://192.168.80.10/bbs/admin.php
注意
- 确保所有路径和配置文件中的设置正确无误。
- 根据实际环境调整数据库服务器地址、端口及登录凭证。
- 定期备份重要数据和配置文件以防丢失。
- 在生产环境中加强安全设置,如限制远程访问、使用强密码等。