目录
一、Apache网站服务
Apache起源
主要特点
编译安装的优点
安装过程
安装Apache
安装MYSQL
安装PHP
安装论坛
源于A Patchy Server,著名的开源Web服务软件
1995年时,发布Apache服务程序的1.0版本后续还开发了1.1--2.0版本
由Apache软件基金会 (ASF) 负责维护
最新的名称为“Apache HTTP Server
官方站点: http://httpd.apache.orgl
处理的是静态页面,如果是动态页面会交给PHP处理
开放源代码、跨平台应用兼容性好(Linux windows mac OS)
支持多种网页编程语言
模块化设计、运行稳定、良好的安全性
可扩展,支持插件式架构 能够方便扩展新的模块
软件版本
1.X
目前最高版本是1.3,运行稳定
向下兼容性较好,但缺乏一些较新的功能
2.X
目前最高版本是2.4
具有更多的功能特性
与1.X相比,配置管理风格存在较大差异
具有较大的自由度,功能可定制
可及时获得最新的软件版本
普遍适用于大多数Linux版本,便于移植使用
获得Apache服务器的源码包
参考地址:Download - The Apache HTTP Server Project
tar xf apr-1.6.2.tar.gz
tar xf apr-util-1.6.0.tar.gz
tar xf httpd-2.4.29.tar.bz2
mv apr-1.6.2 httpd-2.4.29/srclib/apr
mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util
tar xf apr-1.6.2.tar.gz
:解压缩名为 apr-1.6.2.tar.gz
的压缩包,该压缩包包含了 Apache Portable Runtime(APR)库的源代码。
tar xf apr-util-1.6.0.tar.gz
:解压缩名为 apr-util-1.6.0.tar.gz
的压缩包,该压缩包包含了 APR-util 库的源代码。
tar xf httpd-2.4.29.tar.bz2
:解压缩名为 httpd-2.4.29.tar.bz2
的压缩包,该压缩包包含了 Apache HTTP 服务器的源代码。
mv apr-1.6.2 httpd-2.4.29/srclib/apr
:将解压缩后的 apr-1.6.2
目录移动到 httpd-2.4.29/srclib/apr
目录下,以便 Apache HTTP 服务器的编译过程中能够使用 APR 库。
mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util
:将解压缩后的 apr-util-1.6.0
目录移动到 httpd-2.4.29/srclib/apr-util
目录下,以便 Apache HTTP 服务器的编译过程中能够使用 APR-util 库。
这些命令的作用是为了安装 Apache HTTP 服务器所需的依赖库。其中,APR 是 Apache HTTP 服务器所依赖的一个库,而 APR-util 则是 APR 库的一个扩展库,提供了一些额外的功能。这些命令的执行顺序很重要,必须按照上述顺序依次执行,以确保 Apache HTTP 服务器能够正常编译和运行。
yum -y install \
gcc \
gcc-c++ \
make \
pcre-devel \
expat-devel \
perl
yum
:这是一个 Linux 发行版中用于管理软件包的命令行工具,可以用于安装、更新和删除软件包。
-y
:这是 yum
命令的一个选项,表示在安装软件包时自动回答“yes”,即默认选择“是”。
install
:这是 yum
命令的一个子命令,用于安装指定的软件包。
gcc
:这是 GNU C 编译器(GNU Compiler Collection)的一个前端,用于编译和链接 C 语言程序。
gcc-c++
:这是 GNU C++ 编译器的一个前端,用于编译和链接 C++ 语言程序。
make
:这是一个工具集,用于自动化编译和构建程序。
pcre-devel
:这是一个 PCRE 库的开发包,包含了 PCRE 库的头文件和库文件,可用于编译和链接使用 PCRE 库的程序。
expat-devel
:这是一个 Expat 库的开发包,包含了 Expat 库的头文件和库文件,可用于编译和链接使用 Expat 库的程序。
perl
:这是一种通用的脚本语言,常用于文本处理、系统管理和网络编程等领域。
这个命令的作用是安装 Apache HTTP 服务器所需的一些开发工具和依赖库,包括 C/C++ 编译器、自动化构建工具、PCRE 库、Expat 库和 Perl 解释器等。这些工具和库是 Apache HTTP 服务器编译和运行所必需的,通过使用 yum
命令安装可以方便地获取和安装这些依赖项。
cd httpd-2.4.29
cd /opt/httpd-2.4.29/
./configure \
--prefix=/usr/local/httpd \
--enable-so \
--enable-rewrite \
--enable-charset-lite \
--enable-cgi
cd /opt/httpd-2.4.29/
:进入 /opt/httpd-2.4.29/
目录,该目录是 Apache HTTP 服务器的源代码目录。./configure
:运行 configure
脚本,该脚本用于生成编译 Apache HTTP 服务器所需的 Makefile 文件。--prefix=/usr/local/httpd
:指定 Apache HTTP 服务器的安装路径为 /usr/local/httpd
,即安装后的 Apache HTTP 服务器程序和文件将位于该目录下。--enable-so
:启用 Apache HTTP 服务器的动态共享对象(DSO)支持,允许在运行时加载和卸载模块。--enable-rewrite
:启用 Apache HTTP 服务器的 URL 重写模块,允许在服务器端对 URL 进行重写和重定向。--enable-charset-lite
:启用 Apache HTTP 服务器的字符集支持,允许在服务器端对字符集进行转换和处理。--enable-cgi
:启用 Apache HTTP 服务器的 CGI 支持,允许在服务器端执行 CGI 脚本。这个命令的作用是根据指定的参数配置 Apache HTTP 服务器的编译选项,以便生成适合当前系统的 Apache HTTP 服务器程序。需要注意的是,这个命令需要在 Apache HTTP 服务器的源代码目录中执行,并且需要在执行 make
和 make install
命令之前完成。
make -j 4 && make install-j 4表示使用4个线程来加速编译过程,这样可以更快地编译出程序。
优化配置文件路径,并把httpd服务的可执行程序文件放入路径环境变量的目录中便于系统识别
ln -s /usr/local/httpd/conf/httpd.conf /etc/
:创建 /etc/httpd.conf
符号链接,使 Apache HTTP 服务器能够读取和加载配置文件。ln -s /usr/local/httpd/bin/* /usr/local/bin/
:将 Apache HTTP 服务器的可执行文件创建符号链接到 /usr/local/bin/
目录下,以便在系统中任何位置都可以直接执行这些命令。便于service管理 centos6 7 systemctl
cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
vim /etc/init.d/httpd
# chkconfig: 35 85 21 //35级别自动运行 第85个启动 第21个关闭
# description: Apache is a World Wide Web server
---》wq
chkconfig --add httpd //将httpd加入到系统管理器
service httpd start
#可使用service或者systemctl进行管理
systemctl start httpd.service
结束后可用httpd -t 来验证httpd配置是否正确
安装mysql服务内存必须4G以上
yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake
yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake
:这个命令使用 yum
工具安装了一些软件包,包括 C/C++ 编译器(gcc
和 gcc-c++
)、控制台屏幕输出库(ncurses
和 ncurses-devel
)、语法分析器(bison
)和编译工具(cmake
)。这些软件包是在安装 MySQL 数据库时需要用到的开发工具和依赖库,通过使用 yum
命令安装可以方便地获取和安装这些依赖项。
创建程序用户管理
useradd -s /sbin/nologin mysql
cd到opt目录下
tar zxvf mysql-5.7.17.tar.gz -C /opt
tar zxvf boost_1_59_0.tar.gz -C /usr/local/
mv /usr/local/boost_1_59_0 /usr/local/boost
tar zxvf mysql-5.7.17.tar.gz -C /opt
:这个命令解压缩了 MySQL 数据库的压缩包 mysql-5.7.17.tar.gz
,并将解压缩后的文件夹放在了 /opt
目录下。tar
是解压缩命令,z
表示使用 gzip 压缩算法,x
表示解压缩,v
表示显示详细信息,f
表示指定要解压缩的文件。-C
表示指定解压缩的目标目录。tar zxvf boost_1_59_0.tar.gz -C /usr/local/
:这个命令解压缩了 Boost 库的压缩包 boost_1_59_0.tar.gz
,并将解压缩后的文件夹放在了 /usr/local/
目录下。tar
是解压缩命令,z
表示使用 gzip 压缩算法,x
表示解压缩,v
表示显示详细信息,f
表示指定要解压缩的文件。-C
表示指定解压缩的目标目录。mv /usr/local/boost_1_59_0 /usr/local/boost
:这个命令将 /usr/local/
目录下的 boost_1_59_0
文件夹移动到 /usr/local/boost
目录下。mv
是移动命令,/usr/local/boost_1_59_0
是要移动的文件夹,/usr/local/boost
是移动的目标目录。cd /opt/mysql-5.7.17/
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 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=/usr/local/boost \
-DWITH_SYSTEMD=1 \
-DWITH_EMBEDDED_SERVER=OFF
cmake
:这是一个跨平台的编译工具,用于自动生成 Makefile 文件和编译程序。-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
:这个选项指定 MySQL 数据库的安装路径为 /usr/local/mysql
。-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
:这个选项指定 MySQL 数据库的 Unix 套接字文件路径为 /usr/local/mysql/mysql.sock
。-DSYSCONFDIR=/etc
:这个选项指定 MySQL 数据库的配置文件路径为 /etc
。-DSYSTEMD_PID_DIR=/usr/local/mysql
:这个选项指定 MySQL 数据库的 PID 文件路径为 /usr/local/mysql
。-DDEFAULT_CHARSET=utf8
:这个选项指定 MySQL 数据库的默认字符集为 UTF-8。-DDEFAULT_COLLATION=utf8_general_ci
:这个选项指定 MySQL 数据库的默认排序规则为 UTF-8 的 general_ci
。-DWITH_EXTRA_CHARSETS=all
:这个选项指定 MySQL 数据库安装时包含所有可用的字符集。-DWITH_INNOBASE_STORAGE_ENGINE=1
:这个选项指定 MySQL 数据库安装时包含 InnoDB 存储引擎。-DWITH_ARCHIVE_STORAGE_ENGINE=1
:这个选项指定 MySQL 数据库安装时包含 Archive 存储引擎。-DWITH_BLACKHOLE_STORAGE_ENGINE=1
:这个选项指定 MySQL 数据库安装时包含 Blackhole 存储引擎。-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
:这个选项指定 MySQL 数据库安装时包含 Performance Schema 存储引擎。-DMYSQL_DATADIR=/usr/local/mysql/data
:这个选项指定 MySQL 数据库的数据文件路径为 /usr/local/mysql/data
。-DWITH_BOOST=/usr/local/boost
:这个选项指定 MySQL 数据库编译时使用的 Boost 库路径为 /usr/local/boost
。-DWITH_SYSTEMD=1
:这个选项指定 MySQL 数据库编译时启用 systemd 支持。-DWITH_EMBEDDED_SERVER=OFF
:这个选项指定 MySQL 数据库编译时不包含嵌入式服务器。注意:部署mysql报错基本都是内存不足造成
可以试下 echo 1 > /proc/sys/vm/drop_caches #清除缓存
如果在CMAKE的过程中有报错,当报错解决后,需要把源码目录中的CMakeCache.txt文件删除,然后再重新CMAKE,否则错误依旧
创建普通用户管理mysql
useradd -s /sbin/nologin mysql
:这个命令创建了一个用户名为 mysql
的用户账号,-s /sbin/nologin
选项指定该账号不能登录系统,即禁止使用该账号登录系统。这个账号是 MySQL 数据库的运行用户,用于运行 MySQL 服务进程。chown -R mysql:mysql /usr/local/mysql/
:这个命令将 /usr/local/mysql/
目录及其子目录下的所有文件和目录的所有者和所属组都修改为 mysql:mysql
,即 MySQL 数据库的运行用户。chown
是修改文件或目录的所有者和所属组的命令行工具,-R
选项表示递归修改目录及其子目录下的所有文件和目录的所有者和所属组。这个命令的作用是保证 MySQL 数据库在运行时有足够的权限访问和修改自己的数据文件和配置文件。更改管理主/组chown mysql:mysql /etc/my.cnf
修改配置文件
vim /etc/my.cnf 删除原配置项,再重新添加下面内容
[client] #客户端设置
port = 3306
socket=/usr/local/mysql/mysql.sock
[mysqld] #服务全局设置
user = mysql #设置管理用户
basedir=/usr/local/mysql #指定数据库的安装目录
datadir=/usr/local/mysql/data #指定数据库文件的存储路径
port = 3306 #指定端口
character-set-server=utf8 #设置服务器字符集编码格式为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 #禁用DNS解析
max_connections=2048 #设置mysql的最大连接数
default-storage-engine=INNODB #指定默认存储引擎
max_allowed_packet=16M #设置数据库接收的数据包大小的最大值
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
wq!保存退出
设置环境变量,申明/宣告mysql命令便于系统识别
echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
source /etc/profile
初始化数据库
cd /usr/local/mysql/bin/
./mysqld \
--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 #查看端口
#给root账号设置密码
mysqladmin -u root -p password "123456"
直接回车
进入后查看表格
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
安装GD库和GD库关联程序,用来处理和生成图片
cd /opt
tar zxvf php-7.1.24.tar.gz
cd /opt/php-7.1.24/
./configure \
--prefix=/usr/local/php7 \ #指定将 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/php7 #设置 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压缩格式
make -j 4 && make install
#复制模板文件,并进行修改
cp /opt/php-7.1.24/php.ini-development /usr/local/php7/php.ini
vim /usr/local/php7/php.ini
--1170行--修改
mysqli.default_socket = /usr/local/mysql/mysql.sock
--939行--取消注释,修改
date.timezone = Asia/Shanghai
#优化把PHP 的可执行程序文件放入路径环境变量的目录中便于系统识别
ln -s /usr/local/php7/bin/* /usr/local/bin/
#修改Apache配置文件让Apache支持PHP
vim /etc/httpd.conf
#添加index.php
255
256 DirectoryIndex index.html index.php
257
#在392行下方插入一下内容,让Apache可以支持.php的网页文件
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
##检查156行默认支持php7的模块是否存在
LoadModule php7_module modules/libphp7.so
wq!保存退出
创建、编辑php页面文件
rm -rf /usr/local/httpd/htdocs/index.html
vim /usr/local/httpd/htdocs/index.php
phpinfo();
?>
systemctl restart httpd.service
在网页测试“http://192.168.190.10/index.php”(输入自己的本机ip即可)
1.创建一个数据库
mysql -u root -p
mysql> CREATE DATABASE bbs;
#把bbs数据库里面所有表的权限授予给bbsuser,并设置密码qu
mysql> GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY '006121';
#刷新数据库
mysql>flush privileges;
#解压论坛压缩包
unzip Discuz_X3.4_SC_UTF8.zip -d /opt/dis
cd /opt/dis
#上传站点更新包
cp -r upload/ /usr/local/httpd/htdocs/bbs
#切换论坛目录
cd /usr/local/httpd/htdocs/bbs
#更改论坛目录属主
chown -R daemon ./config
chown -R daemon ./data
chown -R daemon ./uc_client
chown -R daemon ./uc_server/data
数据库服务器: localhost #本地架设就用localhost,如何不是在在本机上就要填写IP地址和端口号
数据库名字: bbs
数据库用户名: bbsuser
数据库密码: 006121
管理员账号: admin
管理员密码: 006121
访问地址:http://192.168.190.10/bbs/install/
至此论坛安装结束