Linux操作系统之所以能够在十余年的时间里发展壮大以至于风靡全球,其开放源代码的特性是很重要的原因之一,及Linux操作系统中包括内核在内的所有软件都可以获得源代码,并且可以经过定制修改后编译安装。
虽然现代的Linux发行版本大部分采用包管理机制对软件进行打包安装,可以省去软件的编译安装过程,但是还有些情况需要使用源代码编译的方式为系统安装新的应用程序。
解包
解包 |
---|
习惯上将软件包解压到/sur/src/目录中 |
解包后源代码文件位置:/usr/src/软件名-版本号/ |
配置
配置 |
---|
配置工作通常使用源码目录中的configure脚本完成 |
执行“./configure --help”可查看帮助 |
典型的配置选项:–prefix=软件安装目录(指定软件包安装的目标文件夹) |
编译
安装
●1.X
◆目前最高版本是1.3, 运行稳定
◆向下兼容性较好,但缺乏- -些较新的功能
●2.X
◆目前最高版本是2.4
◆具有更多的功能特性
◆与1 .X相比,配置管理风格存在较大差异
●具有较大的自由度,功能可定制
●可及时获得最新的软件版本
●普遍适用于大多数Linux版本,便于移植使用
获得Apache服务器的源码包
●参考地址: htp://ttpd.apache.org/download.cgi
- 主要目录和文件
●服务目录: /usr/local/httpd/
●主配置文件: /usr/local/httpd/conf/httpd.conf
●网页目录: /usr/local/httpd/htdocs/
●服务脚本: /usr/local/httpd/bin/apachectl 中
●执行程序: /usr/local/httpd/bin/httpd_
●访问日志: /usr/localhttpd/log/access_ log
●错误日志: /usr/localhttpd/log/error_ log
■常用的全局配置参数
●ServerRoot:服务目录
●Listen:监听的IP地址、端口号
●User:运行服务的用户身份
●Group:运行服务的组身份
●ServerAdmin:管理员邮箱
●ServerName :网站服务器的域名
●DocumentRoot:网页文档的根目录
●DirectoryIndex:默认的索弓|页文件
●ErrorLog:设置错误日志文件的路径
●L ogLevel:记录日志的级别,默认为warn
●CustomL og:访问日志文件的位置
●PidFile:保存httpd进程PID号的文件
●AddDefaultCharset:设置站点中网页默认的字符集编码
●Timeout:网络连接超时,默认为300秒
●KeepAlive:是否保持连接,可选On或Off
●MaxKeepAliveRequests:每次连接最多请求文件数
●KeepAlive Timeout:保持连接状态时的超时时间
●Include:需要包含进来的其他配置文件
[root@localhost /]# cd /opt
[root@localhost opt]# mkdir apache mysql php
[root@localhost opt]# cd apache/
apr-util-1.6.0.tar.gz
apr-1.6.2.tar.gz
httpd-2.4.29.tar.bz2
[root@localhost apache]# tar xzvf apr-1.6.2.tar.gz
[root@localhost apache]# tar xzvf apr-util-1.6.0.tar.gz
[root@localhost apache]# tar -xjvf httpd-2.4.29.tar.bz2
[root@localhost apache]# mv apr-1.6.2 httpd-2.4.29/srclib/apr
[root@localhost apache]# mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util
[root@localhost opt]# yum -y install \
> gcc \ '编译器'
> gcc-c++ \ '编译器'
> make \ 'make工具'
> pcre-devel \ '支持正则表达式的工具'
> expat-devel \ '使网站能解析标签语言的工具'
> perl 'Perl语言工具'
[root@localhost apache]# cd httpd-2.4.29/
[root@localhost httpd-2.4.29]# ./configure \
> --prefix=/usr/local/httpd \ '指定路径'
> --enable-so \ '开启核心功能模块'
> --enable-rewrite \ '开启重写功能,如防盗链保护'
> --enable-charset-lite \ '开启字符集转换'
> --enable-cgi '开启通用网关接口'
[root@localhost httpd-2.4.29]# make && make install
[root@localhost httpd-2.4.29]# cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd '将启动脚本复制到/etc/init.d/初始化脚本文件中,并重命名为httpd'
[root@localhost httpd-2.4.29]# vim /etc/init.d/httpd
#!/bin/bash '在行首下一行插入以下内容,保存退出'
# chkconfig: 35 85 21 '35级别自动运行 第85个启动 第21个关闭 '
# description: Apache is a World Wide Web server
[root@localhost httpd-2.4.29]# chkconfig --add httpd '将httpd加入到SERVICE管理器'
[root@localhost httpd-2.4.29]# vim /usr/local/httpd/conf/httpd.conf
'搜索ServerName,修改#ServerName www.example.com:80,若使用域名,则必须修改'
ServerName www.peace.com:80
'搜索Listen,修改'
Listen 20.0.0.48:80 '开启IPv4并监听自己的IP地址'
#Listen 80 '关闭IPv6监听'
[root@localhost httpd-2.4.29]# ln -s /usr/local/httpd/conf/httpd.conf /etc/ '创建httpd.conf配置文件的软链接到/etc下面'
[root@localhost httpd-2.4.29]# ln -s /usr/local/httpd/bin/* /usr/local/bin/ '将httpd的命令文件都创建软链接到/usr/local/bin下'
[root@localhost httpd-2.4.29]# systemctl stop firewalld.service
[root@localhost httpd-2.4.29]# iptables -F
[root@localhost httpd-2.4.29]# setenforce 0 '关闭安全核心防护'
[root@localhost httpd-2.4.29]# httpd -t '发现httpd可以自动补全,-t检查语法错误'
[root@localhost httpd-2.4.29]# apachectl -t
[root@localhost httpd-2.4.29]# service httpd start
[root@localhost httpd-2.4.29]# netstat -ntap | grep 80 '查看80端口是否起来'
[root@localhost httpd-2.4.29]# cd /opt/mysql/
[root@localhost mysql]# yum -y install ncurses-devel autoconf cmake
mysql-5.6.26.tar.gz
'ncurses-devel是字符终端下屏幕控制的基本库'
'autoconf生成可以自动配置软件源代码 '
'cmake跨平台编译安装工具'
[root@localhost mysql]# tar xzvf mysql-5.6.26.tar.gz
[root@localhost mysql]# cd mysql-5.6.26
[root@localhost mysql-5.6.26]# cmake \
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
> -DDEFAULT_CHARSET=utf8 \
> -DDEFAULT_COLLATION=utf8_general_ci \
> -DEXTRA_CHARSETS=all \
> -DSYSCONFIDIR=/etc \
> -DMYSQL_DATADIR=/home/mysql/ \
> -DMYSQL_UNIX_ADDR=/home/mysql/mysql.sock
[root@localhost mysql-5.6.26]# make && make install
此处编译过程大概需要等10分钟左右,取决于你的CPU,也有可能等待一个小时
[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]# cd /etc/init.d/
[root@localhost init.d]# ls
functions httpd mysqld netconsole network README
[root@localhost init.d]# ls -l
'发现mysqld文件没有执行权限'
[root@localhost mysql-5.6.26]# chmod +x /etc/init.d/mysqld
[root@localhost mysql-5.6.26]# chkconfig --add /etc/init.d/mysqld '将mysqld添加到service服务器中'
[root@localhost mysql-5.6.26]# chkconfig mysqld --level 35 on '设置mysqld在运行级别3和5都是开启的'
[root@localhost mysql-5.6.26]# echo "PATH=$PATH:/usr/local/mysql/bin">>/etc/profile
'设置mysql命令到/etc/profile中寻找'
[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
[root@localhost mysql-5.6.26]# useradd -s /sbin/nologin mysql '添加用户,指定shell,禁止用户登录系统'
[root@localhost mysql-5.6.26]# chown -R mysql.mysql /usr/local/mysql/ '设置属主和数组'
[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
[root@localhost mysql-5.6.26]# vim /etc/profile
[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:/usr/local/mysql/bin
[root@localhost mysql-5.6.26]# vim /etc/init.d/mysqld
'搜索basedir,修改这两段内容'
basedir=/usr/local/mysql 添加工作路径
datadir=/home/mysql 添加数据路径
[root@localhost mysql-5.6.26]# service mysqld start
Starting MySQL. SUCCESS!
[root@localhost mysql-5.6.26]# netstat -anpt | grep 3306
tcp6 0 0 :::3306 :::* LISTEN 42478/mysqld
[root@localhost mysql-5.6.26]# mysqladmin -u root -p password "abc123" '设置数据库用户的密码'
Enter password: '原本密码为空,直接回车即可'
Warning: Using a password on the command line interface can be insecure.
[root@localhost mysql-5.6.26]# mysql -uroot -p '连接并登陆到MYSQL操作环境'
Enter password: '输入刚刚设置的密码abc123'
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.6.26 Source distribution
Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> exit '退出MYSQL操作环境'
[root@localhost mysql-5.6.26]# cd /opt/php/
[root@localhost php]# yum -y install \
> gd \
> libpng \
> libpng-devel \
> pcre \
> pcre-devel \
> libxml2-devel \
> libjpeg-devel
php-5.6.11.tar.bz2
[root@localhost php]# tar xjvf php-5.6.11.tar.bz2
[root@localhost php]# cd php-5.6.11/
[root@localhost php-5.6.11]# ./configure \
> --prefix=/usr/local/php5 \ '指定安装路径'
> --with-gd \ '指定GD库'
> --with-zlib \ '支持数据压缩函数库'
> --with-apxs2=/usr/local/httpd/bin/apxs \ '设置Apache服务提供的apxs模块支持程序的文件位置'
> --with-mysql=/usr/local/mysql \ '设置MySQL数据库服务程序的安装位置'
> --with-config-file-path=/usr/local/php5 \ '设置PHP配置文件存放的位置'
> --enable-mbstring '启用多字节字符串功能,以便支持中文等代码'
[root@localhost php-5.6.11]# make && make install
[root@localhost php-5.6.11]# cp php.ini-development /usr/local/php5/php.ini
[root@localhost php-5.6.11]# ln -s /usr/local/php5/bin/* /usr/local/bin/
[root@localhost php-5.6.11]# vim /etc/httpd.conf
'搜索php5,查看是否有下面文字,若没有,之前配置有问题,需要重新配置LAMP'
LoadModule php5_module modules/libphp5.so
'搜索AddType,在下段文字后添加两行文字'
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
<IfModule dir_module>
DirectoryIndex index.html index.php '在此段文字后添加index.php'
</IfModule>
[root@localhost php-5.6.11]# service httpd stop
[root@localhost php-5.6.11]# service httpd start
[root@localhost php-5.6.11]# vim /usr/local/httpd/htdocs/index.html
原本内容可以删除,添加以下字段
<?php
phpinfo();
?>
[root@localhost php-5.6.11]# mv /usr/local/httpd/htdocs/index.html /usr/local/httpd/htdocs/index.php
[root@localhost htdocs]# mysql -u root -p
...省略内容
mysql> create database bbs; '创建数据库'
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| bbq |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.00 sec)
mysql> grant all on bbq.* to 'bbsuser '@'%' identified by 'admin123'; '给用户bbsuser设置密码admin123并设置所有权限,所有终端都可登录'
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges; '刷新数据库'
Query OK, 0 rows affected (0.00 sec)
mysql> exit
Bye
[root@localhost php-5.6.11]# cd /opt
Discuz_X2.5_SC_UTF8.zip
[root@localhost opt]# unzip Discuz_X2.5_SC_UTF8.zip -d /opt/dis
[root@localhost opt]# cd /opt/dis
[root@localhost opt]# cp -r upload/ /usr/local/httpd/htdocs/bbs
'将upload复制到Apache服务站点中'
[root@localhost opt]# 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/
5.正在安装和安装完成
7.注册会员用户
8.进入后台,网址后缀重新输入/bbq/admin.php
[root@localhost bbs]# mysql -uroot -p
Enter password:
...省略内容
mysql> use bbs;
...省略内容
Database changed
mysql> show tables; '发现数据库有内容了'
+-----------------------------------+
| Tables_in_bbq |
+-----------------------------------+
| pre_common_admincp_cmenu |
| pre_common_admincp_group |