Linux系统——LAMP架构

目录

一、LAMP架构组成

1.LAMP定义 

2.各组件的主要作用 

3.CGI和FastCGI

3.1CGI

3.3CGI和FastCGI比较

4.PHP

4.1PHP简介

4.2PHP的Opcode语言

4.3PHP设置

二、LAMP架构实现

1.编译安装Apache httpd服务

2.编译安装Mysql

3.编译安装PHP

4.安装论坛

5.搭建博客


Web资源类型

  • 静态资源:原始形式与响应内容一致,在客户端浏览器执行

  • 动态资源:原始形式通常为程序文件,需要在服务器端执行之后,将执行结果返回给客户端

注意:静态和动态的区别,不在于网页是否能动态变化,而在于服务端的页面文件和客户端得到页面文件是否一致

一、LAMP架构组成

LAMP:

  • L:linux
  • A:apache (httpd)
  • M:mysql, mariadb
  • P:php, perl, python

1.LAMP定义 

LAMP 环境指的是在 Linux 操作系统中分别安装 Apache 网页服务器、MySQL 数据库服务器和 PHP 开发服务器,以及一些对应的扩展软件。AMP也支持win操作系统 (sccm 域升级版)

LAMP架构是目前成熟的企业网站应用模式之一,指的是协同工作的一整套系统和相关软件,能够提供动态web站点服务及其应用开发环境。(前台)Apache:作为LAMP架构的前端,是一款功能强大,稳定性好的web服务器程序,该服务器直接面向用户提供网站访问,发送网页,图片等内容。

后台Mysql:作为LAMP架构的后端,是一款流行的开源关系型数据库。在企业网站、业务系统应用中,各种账户信息、产品信息,客户资料、业务数据等都可以存储到mysql数据库,其他程序可以通过sql语句来查询,更改这些信息。

(中间连接)PHP/Perl/Python:作为三种开发动态的网页编程语言,负责解释动态网页文件,负责沟通web服务器和数据库系统已协同工作,并提供web应用程序的开发运行环境。其中PHP是一种广泛应用的开放源代码的多用途脚本语言,它可以嵌入到HTML中,尤其适合于web应用开发。

在搭建LAMP时安装顺序一般是linux Apache mysql php 。一般PHP放在最后,负责沟通web服务器和数据库系统以协同工作。

2.各组件的主要作用 

(平台)Linux:作为LAMP架构的基础,提供用于支撑Web站点的操作系统,能够与其他三个组件提供更好的稳定性,兼容性(AMP组件也支持Windows、UNIX等平台) 。

(前台)Apache:作为LAMP架构的前端,是一款功能强大,稳定性好的Web服务器程序,该服务器直接面向用户提供网站访问,发送网页,图片等文件内容。

(后台)MySQL:作为LAMP架构的后端,是一款流行的开源关系数据库系统。在企业网站、业务系统等应用中,各种账户信息、产品信息,客户资料、业务数据等都可以存储到MySQL数据库,其他程序可以通过SQL语句来查询,更改这些信息。

(中间连接)PHP/Perl/Python:作为三种开发动态网页的编程语言,负责解释动态网页文件,负责沟通Web服务器和数据库系统以协同工作,并提供Web应用程序的开发和运行环境。其中PHP是一种被广泛应用的开放源代码的多用途脚本语言,它可以嵌入到HTML中,尤其适合于Web应用开发。

apache主要实现如下功能:

  • 第一:处理http的请求、构建响应报文等自身服务;
  • 第二:配置让Apache支持PHP程序的响应(通过PHP模块或FPM);
  • 第三:配置Apache具体处理php程序的方法,如通过反向代理将php程序交给fcgi处理。

mysql 主要实现如下功能:

  • 第一:提供PHP程序对数据的存储;
  • 第二:提供PHP程序对数据的读取(通常情况下从性能的角度考虑,尽量实现数据库的读写分离)。

php主要实现如下功能:

  • 第一:提供apache的访问接口,即CGI或Fast CGI(FPM);
  • 第二:提供PHP程序的解释器;
  • 第三:提供mysql数据库的连接函数的基本环境。

3.CGI和FastCGI

3.1CGI

CGI:Common Gateway Interface 公共网关接口

CGI 在2000年或更早的时候用得比较多,以前web服务器一般只处理静态的请求,如果碰到一个动态请求怎么办呢?web服务器会根据这次请求的内容,然后会 fork 一个新进程来运行外部的 C 程序或者bash,perl脚本等,这个进程会把处理完的数据返回给web服务器,最后web服务器把内容发送给用户,刚才fork的进程也随之退出。 如果下次用户还请求改动态脚本,那么web服务器又再次fork一个新进程,周而复始的进行。

CGI 可以让一个客户端,从网页浏览器通过http服务器向执行在网络服务器上的程序传输数据;CGI描述了客户端和服务器程序之间传输的一种标准

请求流程:

Client -- (http协议) --> httpd -- (cgi协议) --> application server (program file) -- (mysql协议) --> mysql

3.2FastCGI

fastcgi的方式是,web服务器收到一个请求时,不会重新fork一个进程(因为这个进程在web服务器启动时就开启了,而且不会退出),web服务器直接把内容传递给这个进程(进程间通信,但fastcgi使用了别的方式,tcp方式通信),这个进程收到请求后进行处理,把结果返回给web服务器,最后自己接着等待下一个请求的到来,而不是退出

请求流程:

Client -- (http协议) --> httpd -- (fastcgi协议) --> fastcgi服务器 -- (mysql协议) --> mysql

#httpd 利用CGI运行shell脚本[root@localhost ~]#vim   /var/www/cgi-bin/test.sh
#!/bin/bash
#
cat << EOF
Content-Type: text/html<pre>
My username is: $(id -un)
My id is: $(id -u)
My shell settings are:
$(set)My environment variables are:
$(env)Here is the file in /etc:
$(ls -l /etc/redhat-release )
$( cat /etc/redhat-release )# sleep 1000
</pre>
EOF[root@localhost ~]#chmod +x /var/www/cgi-bin/test.sh
[root@localhost ~]#ll /data/script/cgi.sh

3.3CGI和FastCGI比较

  • CGI: 兼职, 一次性的过河拆桥式的服务
  • FASTCGI: 专职,全周期的持续式的服务

4.PHP

4.1PHP简介

PHP官网:http://www.php.net/

PHP(Hypertext Preprocessor 超文本预处理器)是通用服务器端脚本编程语言,主要用于web开发实现动态web页面,也是最早实现将脚本嵌入HTML源码文档中的服务器端脚本语言之一。同时,php还提供了一个命令行接口,因此,其也可以在大多数系统上作为一个独立的shell来使用

Rasmus Lerdorf于1994年开始开发PHP,最初是一组被Rasmus Lerdorf称作“Personal Home Page Tool” 的Perl脚本, 可以用于显示作者的简历并记录用户对其网站的访问。后来,Rasmus Lerdorf使用C语言将这些Perl脚本重写为CGI程序,还为其增加了运行Web forms的能力以及与数据库交互的特性,并将其重命名为“Personal Home Page/Forms Interpreter”或“PHP/FI”。此时,PHP/FI已经可以用于开comp.infosystems.www.authoring.cgi Usenet讨论组,从此PHP开始走进人们的视野。1997年,其2.0版本发布

1997年,两名以色列程序员Zeev Suraski和Andi Gutmans重写的PHP的分析器(parser)成为PHP发展到3.0的基础,而且从此将PHP重命名为PHP: Hypertext Preprocessor。此后,这两名程序员开始重写整个PHP核心,并于1999年发布了Zend Engine 1.0,这也意味着PHP 4.0的诞生。2004年7月,Zend Engine 2.0发布,由此也将PHP带入了PHP 5时代。PHP5包含了许多重要的新特性,如增强的面向对象编程的支持、支持PDO(PHP Data Objects)扩展机制以及一系列对PHP性能的改进

Zend Engine是开源的、PHP脚本语言的解释器,它最早是由以色列理工学院(Technion)的学生Andi Gutmans和Zeev Suraski所开发,Zend也正是此二人名字的合称。后来两人联合创立了Zend Technologies公司

Zend Engine 1.0于1999年随PHP 4发布,由C语言开发且经过高度优化,并能够做为PHP的后端模块使用。Zend Engine为PHP提供了内存和资源管理的功能以及其它的一些标准服务,其高性能、可靠性和可扩展性在促进PHP成为一种流行的语言方面发挥了重要作用

Zend Engine的出现将PHP代码的处理过程分成了两个阶段:首先是分析PHP代码并将其转换为称作Zend opcode的二进制格式opcode(类似Java的字节码),并将其存储于内存中;第二阶段是使用Zend Engine去执行这些转换后的Opcode

4.2PHP的Opcode语言

Opcode是一种PHP脚本编译后的中间语言,类似于Java的ByteCode,或者.NET的MSL

PHP的语言引擎Zend执行PHP脚本代码一般会经过如下4个步骤

  • Scanning 词法分析,将PHP代码转换为语言片段(Tokens)
  • Parsing 语义分析,将Tokens转换成简单而有意义的表达式
  • Compilation 将表达式编译成Opcode
  • Execution 顺次执行Opcode,每次一条,从而实现PHP脚本的功能

即:扫描-->分析-->编译-->执行

4.3PHP设置

php 的配置文件:/etc/php.ini, /etc/php.d/*.ini

配置文件在php解释器启动时被读取

对配置文件的修改生效方法

  • Modules:重启httpd服务
  • FastCGI:重启php-fpm服务

/etc/php.ini配置文件格式:

[foo]:Section Header
directive = value

注释符:

  • 以#开头,纯粹的注释信息
  • 以 ; 开头,用于注释可启用的directive

提示:较新的版本中,已经完全使用 “ ; ” 进行注释

php.ini配置参考文档

php.ini的核心配置选项文档: http://php.net/manual/zh/ini.core.phpphp.ini配置选项列表:http://php.net/manual/zh/ini.list.php
expose_php = On
#响应报文显示首部字段x-poered-by:PHP/x.y.z,暴露php版本,建议为offmax_execution_time = 30
#最长执行时间为30smemory_limit=128M
#可调大display_errors=off
#调试使用,不要打开,否则可能暴露重要信息display_startup_errors=off
#建议关闭post_max_size=8M
#最大上传数据大小,可能调大,比下面的项大upload_max_filesize=2M
#最大上传文件,可能调大max_file_uploads = 20
#同时上传最多文件数date.timezone = Asia/Shanghai
#指定时区short_open_tag=on
#开启短标签,如:<? phpinfo();?>

二、LAMP架构实现

1.编译安装Apache httpd服务

[root@localhost ~]#systemctl stop firewalld
[root@localhost ~]#setenforce 0
setenforce: SELinux is disabled#安装环境依赖包
[root@localhost ~]#yum -y install gcc gcc-c++ make pcre-devel expat-devel perl pcre
gcc \                #c语言编译器
gcc-c++ \            #c编译器
make \               #源代码编译器
pcre\                #pcre函数库
pcre-devel \         #pcre接口开发包
expat-devel \        #用于支持网站解析HTML、XML文件
perl                 #perl 语言编译器
#配置本地yum仓库[root@localhost ~]#cd /etc/yum.repos.d/
[root@localhost yum.repos.d]#ls
CentOS-Base.repo       CentOS-fasttrack.repo  CentOS-Vault.repo
CentOS-CR.repo         CentOS-Media.repo      epel.repo
CentOS-Debuginfo.repo  CentOS-Sources.repo    epel-testing.repo
[root@localhost yum.repos.d]#mkdir repos.bak
[root@localhost yum.repos.d]#mv *.repo repos.bak/
[root@localhost yum.repos.d]#ls
repos.bak
[root@localhost yum.repos.d]#cd repos.bak/
[root@localhost repos.bak]#ls
CentOS-Base.repo       CentOS-fasttrack.repo  CentOS-Vault.repo
CentOS-CR.repo         CentOS-Media.repo      epel.repo
CentOS-Debuginfo.repo  CentOS-Sources.repo    epel-testing.repo
[root@localhost repos.bak]#cd -
/etc/yum.repos.d
[root@localhost yum.repos.d]#vim local.repo[local]
name=local
baseurl=file:///mnt
enabled=1
gpgcheck=0[root@localhost yum.repos.d]#yum clean all
[root@localhost yum.repos.d]#yum makecache

事先准备apr-1.6.2.tar.gz  apr-util-1.6.0.tar.gz  httpd-2.4.29.tar.bz2三个压缩包 

[root@localhost yum.repos.d]#cd /opt
[root@localhost opt]#rz -E
rz waiting to receive.
[root@localhost opt]#ls
apr-1.6.2.tar.gz  apr-util-1.6.0.tar.gz  httpd-2.4.29.tar.bz2
[root@localhost opt]#tar xf httpd-2.4.29.tar.bz2 
[root@localhost opt]#tar xf apr-1.6.2.tar.gz 
[root@localhost opt]#tar xf apr-util-1.6.0.tar.gz 
[root@localhost opt]#ls
apr-1.6.2         apr-util-1.6.0         httpd-2.4.29
apr-1.6.2.tar.gz  apr-util-1.6.0.tar.gz  httpd-2.4.29.tar.bz2#apr组件包用于支持Apache上层应用跨平台,提供底层接口库,能有效的降低并发连接数、降低进程和减少访问堵塞。
[root@localhost opt]#mv apr-1.6.2 /opt/httpd-2.4.29/srclib/apr
[root@localhost opt]#mv apr-util-1.6.0 /opt/httpd-2.4.29/srclib/apr-util
[root@localhost opt]#ls
apr-1.6.2.tar.gz  apr-util-1.6.0.tar.gz  httpd-2.4.29  httpd-2.4.29.tar.bz2
[root@localhost opt]#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--prefix=/usr/local/httpd \       #指定httpd的安装目录
--enable-so \                     #启用动态加载模块支持,使httpd具备进一步扩展功能的能力
--enable-rewrite \             #启用网页地址的重写功能,用于网站优化、防盗链及目录迁移维护   
--enable-charset-lite \     #启用字符集支持,以便支持使用各种字符集编码的页面
--enable-cgi      #启用CGI(通用网关接口)脚本程序支持,便于网站外部扩展应用访问的能力[root@localhost httpd-2.4.29]#make
[root@localhost httpd-2.4.29]#make install#优化配置文件路径,并把httpd服务的可执行程序文件放入路径环境变量的目录中便于系统识别
[root@localhost httpd-2.4.29]#ln -s /usr/local/httpd/conf/httpd.conf /etc/
#建立配置文件软连接放入etc目录下
[root@localhost httpd-2.4.29]#ln -s /usr/local/httpd/bin/* /usr/local/bin/
#将启动文件放入/usr/local/bin/目录下可以直接使用
[root@localhost httpd-2.4.29]#cp /usr/local/httpd/bin/apachectl /etc/init.d/httpd
[root@localhost httpd-2.4.29]#chmod +x /etc/init.d/httpd
[root@localhost httpd-2.4.29]#ll /etc/init.d/httpd 
-rwxr-xr-x 1 root root 3431 2月  28 14:42 /etc/init.d/httpd
[root@localhost httpd-2.4.29]#vim /etc/init.d/httpd[root@localhost httpd-2.4.29]#chkconfig --add httpd
#将httpd加入service管理器

[root@localhost httpd-2.4.29]#vim /usr/local/httpd/conf/httpd.conf

[root@localhost httpd-2.4.29]#vim /etc/hosts

[root@localhost httpd-2.4.29]#service httpd start
#启动服务注意使用了service启动不要使用systemctl关闭,两种无法混用
[root@localhost httpd-2.4.29]#netstat -natp|grep 80
tcp        0      0 192.168.241.11:80       0.0.0.0:*               LISTEN      34886/httpd 
[root@localhost httpd-2.4.29]#cat /usr/local/httpd/htdocs/index.html 
<html><body><h1>It works!</h1></body></html>

方法2添加httpd服务[root@localhost mysql-5.6.26]#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
[root@localhost system]# systemctl start httpd.service 
Warning: httpd.service changed on disk. Run 'systemctl daemon-reload' to reload units.
Job for httpd.service failed because the control process exited with error code. See "systemctl status httpd.service" and "journalctl -xe" for details.
[root@localhost system]# systemctl daemon-reload
[root@localhost system]# systemctl start httpd.service 
[root@localhost system]# netstat -ntap |grep 80
tcp6       0      0 :::80                   :::*                    LISTEN      121165/httpd      

2.编译安装Mysql

需要事先准备好mysql-boost-5.7.20.tar.gz  boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz三个压缩包

[root@localhost httpd-2.4.29]#cd /opt
[root@localhost opt]#ls
apr-1.6.2.tar.gz  apr-util-1.6.0.tar.gz  httpd-2.4.29  httpd-2.4.29.tar.bz2
[root@localhost opt]#rz -E
rz waiting to receive.
[root@localhost opt]#ls
apr-1.6.2.tar.gz       httpd-2.4.29          mysql-boost-5.7.20.tar.gz
apr-util-1.6.0.tar.gz  httpd-2.4.29.tar.bz2
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz
#安装依赖包[root@localhost opt]#yum install -y ncurses-devel autoconf cmake
ncurses \              #字符终端下图形互动功能的动态库
ncurses-devel \        #ncurses开发包
bison \                #语法分析器
cmake                  #mysql需要用到的cmake编译安装包
[root@localhost opt]#useradd -s /sbin/nologin  mysql
[root@localhost opt]#tar xf mysql-boost-5.7.20.tar.gz 
[root@localhost opt]#cd mysql-5.7.20/
[root@localhost mysql-5.7.20]#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_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=boost \
> -DWITH_SYSTEMD=1####配置选项含义###
1、DCMAKE_INSTALL_PREFIX:指定将 mysql 数据库程序安装到某目录下,
如目录/usr/local/ mysql。
2、DMYSQL_UNIX_ADDR:指定套接字文件的存储路径,数据库连接的文件
3、DSYSCONFDIR:指定初始化参数文件目录
3、DDEFAULT_CHARSET:指定默认使用的字符集编码,如 utf8。
5、DDEFAULT_COLLATION:指定默认使用的字符集校对规则,utf8_general_ci 是适用于 UTF-8 字符集的通用规则。
6、DWITH_INNOBASE_STORAGE_ENGINE=1 :安装INNOBASE存储引擎
7、DWITH_ARCHIVE_STORAGE_ENGINE=1 :安装ARCHIVE存储引擎 
8、DWITH_BLACKHOLE_STORAGE_ENGINE=1 :安装BLACKHOLE存储引擎 
9、DWITH_PERFSCHEMA_STORAGE_ENGINE :安装FEDERATED存储引擎 指定安装文件的安装路径时常用的选项:-DCMAKE_INSTALL_PREFIX=/usr/local/mysql         指定安装路径 
-DMYSQL_DATADIR=/data/mysql                     数据安装路径 
-DSYSCONFDIR=/etc                               配置文件的安装路径由于MySQL支持很多的存储引擎而默认编译的存储引擎包括:csv、myisam、myisammrg和heap。若要安装其它存储引擎,可以使用类似如下编译选项:-DWITH_INNOBASE_STORAGE_ENGINE=1          安装INNOBASE存储引擎 
-DWITH_ARCHIVE_STORAGE_ENGINE=1           安装ARCHIVE存储引擎 
-DWITH_BLACKHOLE_STORAGE_ENGINE=1         安装BLACKHOLE存储引擎 
-DWITH_FEDERATED_STORAGE_ENGINE=1         安装FEDERATED存储引擎 若要明确指定不编译某存储引擎,可以使用类似如下的选项:-DWITHOUT_<ENGINE>_STORAGE_ENGINE=1 比如:-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1        不启用或不编译EXAMPLE存储引擎 
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1 -DWITHOUT_PARTITION_STORAGE_ENGINE=1如若要编译进其它功能,如SSL等,则可使用类似如下选项来实现编译时使用某库或不使用某库:-DWITH_READLINE=1 -DWITH_SSL=system           表示使用系统上的自带的SSL库 
-DWITH_ZLIB=system -DWITH_LIBWRAP=0其它常用的选项:-DMYSQL_TCP_PORT=3306                       设置默认端口的 
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock           MySQL进程间通信的套接字的位置 
-DENABLED_LOCAL_INFILE=1                    是否启动本地的LOCAL_INFILE -DEXTRA_CHARSETS=all                        支持哪些额外的字符集 
-DDEFAULT_CHARSET=utf8                      默认字符集 
-DDEFAULT_COLLATION=utf8_general_ci         默认的字符集排序规则 
-DWITH_DEBUG=0                              是否启动DEBUG功能 
-DENABLE_PROFILING=1                        是否启用性能分析功能[root@localhost mysql-5.7.20]#make -j2
[root@localhost mysql-5.7.20]#make install
[root@localhost mysql-5.7.20]#chown -R mysql:mysql /usr/local/mysql/
#数据库目录进行权限调整[root@localhost mysql-5.7.20]#vim /etc/my.cnf[client]
#客户端设置
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock[mysql]
port = 3306
default-character-set=utf8
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#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后,不能用双引号来引用字符串,因为它被解释为识别符[root@localhost mysql-5.7.20]#chown mysql:mysql /etc/my.cnf
[root@localhost mysql-5.7.20]#chown -R mysql:mysql /usr/local/mysql/
#更改mysql安装目录和配置文件的属主属组#设置环境变量
echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
[root@localhost mysql-5.7.20]#source /etc/profile
[root@localhost mysql-5.7.20]#echo $PATH
/usr/local/mysql/bin:/usr/local/mysql/lib:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin#初始化数据库
[root@localhost mysql-5.7.20]#cd /usr/local/mysql/bin/
[root@localhost bin]#./mysqld \
> --initialize-insecure \
#生成初始化密码为空
> --user=mysql \
#指定管理用户
> --basedir=/usr/local/mysql \
#指定数据库的安装目录
> --datadir=/usr/local/mysql/data
#指定数据库文件的存储路径[root@localhost bin]#cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
#添加mysqld系统服务
[root@localhost bin]#systemctl enable mysqld
Created symlink from /etc/systemd/system/multi-user.target.wants/mysqld.service to /usr/lib/systemd/system/mysqld.service.
[root@localhost bin]#systemctl start mysqld
[root@localhost bin]#systemctl status mysqld
● mysqld.service - MySQL ServerLoaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)Active: active (running) since 三 2024-02-28 16:25:25 CST; 4s agoDocs: man:mysqld(8)http://dev.mysql.com/doc/refman/en/using-systemd.htmlProcess: 57789 ExecStart=/usr/local/mysql/bin/mysqld --daemonize --pid-file=/usr/local/mysql/mysqld.pid $MYSQLD_OPTS (code=exited, status=0/SUCCESS)Process: 57768 ExecStartPre=/usr/local/mysql/bin/mysqld_pre_systemd (code=exited, status=0/SUCCESS)Main PID: 57792 (mysqld)CGroup: /system.slice/mysqld.service└─57792 /usr/local/mysql/bin/mysqld --daemonize --pid-file=/usr/...2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: Version: '5.7.20'  so...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain mysqld[57789]: 2024-02-28T08:25:25.5...
2月 28 16:25:25 localhost.localdomain systemd[1]: Started MySQL Server.
Hint: Some lines were ellipsized, use -l to show in full.
[root@localhost bin]#netstat -anpt | grep 3306
tcp6       0      0 :::3306                 :::*                    LISTEN      57792/mysqld
[root@localhost bin]#mysqladmin -u root -p password "abc123"
#给root账号设置密码为abc123,提示输入的是原始密码(为空)
Enter password: 
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
[root@localhost bin]#mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 5.7.20 Source distributionCopyright (c) 2000, 2017, 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> 
mysql> 
mysql> ^DBye

3.编译安装PHP

事先要准备好 Discuz_X3.4_SC_UTF8.zip  php-7.1.10.tar.bz2两个压缩包

[root@localhost bin]#cd /opt
[root@localhost opt]#ls
apr-1.6.2.tar.gz       cmake                 mysql-5.7.20
apr-util-1.6.0.tar.gz  httpd-2.4.29          mysql-boost-5.7.20.tar.gz
bison                  httpd-2.4.29.tar.bz2  ncurses
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz   ncurses-devel
[root@localhost opt]#rz -E
rz waiting to receive.
[root@localhost opt]#ls
apr-1.6.2.tar.gz       Discuz_X3.4_SC_UTF8.zip  mysql-boost-5.7.20.tar.gz
apr-util-1.6.0.tar.gz  httpd-2.4.29             ncurses
bison                  httpd-2.4.29.tar.bz2     ncurses-devel
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz      php-7.1.10.tar.bz2
cmake                  mysql-5.7.20#安装依赖环境 依赖包 安装GD库和GD库关联程序,用来处理和生成图片
[root@localhost opt]#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#编译安装
[root@localhost opt]#tar xf php-7.1.10.tar.bz2 
[root@localhost opt]#cd php-7.1.10/
[root@localhost php-7.1.10]#./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压缩格式
[root@localhost php-7.1.10]#make -j2
[root@localhost php-7.1.10]#make install#复制模版文件作为PHP 的主配置文件,并进行修改
[root@localhost php-7.1.10]#cp /opt/php-7.1.10/php.ini-development /usr/local/php7/php.ini
#在测试环境时使用php.ini-development文件,而在生产环境时使用php.ini-production文件[root@localhost php-7.1.10]#vim /usr/local/php7/php.ini

[root@localhost php-7.1.10]#ln -s /usr/local/php7/bin/* /usr/local/bin/
[root@localhost php-7.1.10]#vim /etc/httpd.conf

这里的点前面空格一定要加,否则报错

[root@localhost php-7.1.10]#vim /usr/local/httpd/htdocs/index.php<?php
phpinfo();
?>[root@localhost php-7.1.10]#service httpd start

测试php 

4.安装论坛

[root@localhost php-7.1.10]#mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 10
Server version: 5.7.20 Source distributionCopyright (c) 2000, 2017, 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> CREATE DATABASE bbs;
#创建一个数据库
Query OK, 1 row affected (0.01 sec)mysql> GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
#把bbs数据库里面所有表的权限授予给bbsuser,并设置密码
Query OK, 0 rows affected, 1 warning (0.01 sec)mysql> flush privileges;
#刷新数据库
Query OK, 0 rows affected (0.00 sec)mysql> ^DBye
#Ctrl D 退出
[root@localhost php-7.1.10]#cd /opt
[root@localhost opt]#ls
apr-1.6.2.tar.gz       Discuz_X3.4_SC_UTF8.zip  mysql-boost-5.7.20.tar.gz
apr-util-1.6.0.tar.gz  httpd-2.4.29             ncurses
bison                  httpd-2.4.29.tar.bz2     ncurses-devel
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz      php-7.1.10
cmake                  mysql-5.7.20             php-7.1.10.tar.bz2
[root@localhost opt]#unzip Discuz_X3.4_SC_UTF8.zip
#解压论坛压缩包
[root@localhost opt]#cd dir_SC_UTF8/
[root@localhost dir_SC_UTF8]#cp -r upload/ /usr/local/httpd/htdocs/bbs
#上传站点更新包
[root@localhost dir_SC_UTF8]#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
#更改论坛目录的属主
[root@localhost bbs]#chmod -R 777 ./config/
[root@localhost bbs]#chmod -R 777 ./data/
[root@localhost bbs]#chmod -R 777 ./uc_client/
[root@localhost bbs]#chmod -R 777 ./uc_server/

登录管理员 

5.搭建博客

[root@localhost bbs]#cd /opt
[root@localhost opt]#ls
apr-1.6.2.tar.gz       Discuz_X3.4_SC_UTF8.zip    ncurses
apr-util-1.6.0.tar.gz  httpd-2.4.29               ncurses-devel
bison                  httpd-2.4.29.tar.bz2       php-7.1.10
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz        php-7.1.10.tar.bz2
cmake                  mysql-5.7.20               说明.htm
dir_SC_UTF8            mysql-boost-5.7.20.tar.gz
[root@localhost opt]#rz -E
rz waiting to receive.
[root@localhost opt]#ls
apr-1.6.2.tar.gz       Discuz_X3.4_SC_UTF8.zip    ncurses
apr-util-1.6.0.tar.gz  httpd-2.4.29               ncurses-devel
bison                  httpd-2.4.29.tar.bz2       php-7.1.10
boost_1_59_0.tar.gz    mysql-5.7.17.tar.gz        php-7.1.10.tar.bz2
cmake                  mysql-5.7.20               wordpress-6.1.1-zh_CN.zip
dir_SC_UTF8            mysql-boost-5.7.20.tar.gz  说明.htm
[root@localhost opt]#unzip wordpress-6.1.1-zh_CN.zip 
[root@localhost opt]#cp -r wordpress/ /usr/local/httpd/htdocs/
[root@localhost opt]#cd /usr/local/httpd/htdocs/
[root@localhost htdocs]#ls
bbs  index.html  index.php  wordpress
[root@localhost htdocs]#chmod -R 777 wordpress/
[root@localhost htdocs]#mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 55
Server version: 5.7.20 Source distributionCopyright (c) 2000, 2017, 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> create database blog;
Query OK, 1 row affected (0.00 sec)mysql> GRANT all ON blog.* To 'bloguser'@'%' IDENTIFIED BY 'admin123'-> -> -> -> -> ;
Query OK, 0 rows affected, 1 warning (0.00 sec)mysql> GRANT all ON blog.* To 'bloguser'@'localhost' IDENTIFIED BY 'admin123'; 
Query OK, 0 rows affected, 1 warning (0.00 sec)mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)mysql> ^DBye

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/711785.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux编程 2.4 文件和目录-Linux文件系统结构

1、文件操作基本元素 文件操作相关的最基本元素是&#xff1a;目录结构、索引节点和文件的数据本身。 目录结构&#xff08;目录项&#xff09;索引节点&#xff08;i节点&#xff09;文件的数据 2、文件系统的三个区域 属性&#xff1a; 超级块&#xff1a;存放文件系统本身…

【学习心得】Python调用JS的三种常用方法

在做JS逆向的时候&#xff0c;一种情况是直接用Python代码复现JS代码的功能&#xff0c;达成目的。但很多时候这种方法有明显的缺点&#xff0c;那就是一旦JS代码逻辑发生了更改&#xff0c;你就得重写Python的代码逻辑非常不便。于是第二种情况就出现了&#xff0c;我直接得到…

python自动化管理和zabbix监控网络设备(防火墙和python自动化配置部分)

目录 前言 一、ssh配置 1.FW1 2.core-sw1 3.core-sw2 二、python自动化配置防火墙 三、验证DNAT 四、验证DNAT 前言 视频演示请访问b站主页 白帽小丑的个人空间-白帽小丑个人主页-哔哩哔哩视频 一、ssh配置 给需要自动化管理的设备配置ssh服务端用户名和密码 1.FW1 …

纯css实现-让字符串在文字少时显示为居中对齐,而在文字多时显示为左对齐

纯css实现-让字符串在文字少时显示为居中对齐&#xff0c;而在文字多时显示为左对齐 使用flex实现 思路 容器样式&#xff08;.container&#xff09;: Flex容器的BFC性质使得其内部的子元素&#xff08;.text-box&#xff09;在水平方向上能够居中&#xff0c;通过justify-c…

生态环境数据分析新篇章:Meta分析、R语言、Matlab、贝叶斯、结构方程模型等的前沿实践

目录 ①Meta分析在生态环境领域里的应用 ②R语言在生态环境领域中的应用 ③MATLAB在生态环境数据处理与分析中的应用 ④基于R语言piecewiseSEM结构方程模型在生态环境应用 ⑤R语言贝叶斯方法在生态环境领域中的高阶技术应用 更多应用 为了Meta分析问题的设计、基础理论、…

【菜鸟入门!】Matlab零基础快速入门教程

数学建模竞赛中&#xff0c;编程软件是必不可缺少的&#xff0c;比如大家都熟知的MATLAB多数同学们都会经常用到&#xff0c;今天给大家介绍一些MATLAB的基本元素&#xff0c;希望帮助大家更好的掌握编写基本的函数&#xff01; 变量和数组 MATLAB 程序的基本数据单元是数组。一…

Vue.js的双向绑定原理

Vue的双向绑定 vue双向绑定是其最重要的核心亮点&#xff0c;其原理也很简单&#xff0c;这里做个简单总结 vue2的双向绑定是利用的Object.definePropertyvue3的双向绑定是利用的 ES6Porxy中的defineProperty(target, propKey, propDesc 其作用类似于Object.defineProperty …

您想要拥有 Apple Vision Pro 的原因

自从2024年2月2日Apple Vision Pro发布以来&#xff0c;网上已经有很多关于如何使用这款苹果最新设备的示例。该平台引入的空间计算新世界能够完成许多在其他设备上无法完成的事情。Reddit 上的这个人能够以 51202160 的分辨率从他的 PC 上串流游戏&#xff01;在本文中&#x…

SpringMVC01、回顾MVC

1、回顾MVC 1.1、什么是MVC MVC是模型(Model)、视图(View)、控制器(Controller)的简写&#xff0c;是一种软件设计规范。是将业务逻辑、数据、显示分离的方法来组织代码。MVC主要作用是降低了视图与业务逻辑间的双向偶合。MVC不是一种设计模式&#xff0c;MVC是一种架构模式。…

Docker部署前后端服务示例

使用Docker部署js前端 1.创建Dockerfile 在项目跟目录下创建Dockerfile文件&#xff1a; # 使用nginx作为基础镜像 FROM nginx:1.19.1# 指定工作空间 WORKDIR /data/web# 将 yarn build 打包后的build文件夹添加到工作空间 ADD build build# 将项目必要文件添加到工作空间&a…

数据结构—>带你深入了解单链表(基础篇)

✅作者简介&#xff1a;大家好&#xff0c;我是橘橙黄又青&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;橘橙黄又青-CSDN博客 前面我们学习了顺序表&#xff0c;今天我们来学习与顺序表类似的单链表 1.&#x1f3…

鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:透明度设置)

设置组件的透明度。 说明&#xff1a; 从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 opacity opacity(value: number | Resource) 设置组件的不透明度。 卡片能力&#xff1a; 从API version 9开始&#xff0c;该接口…

香橙派AIpro快速上手指南

1 前言 作为业界首款基于昇腾深度研发的AI开发板&#xff0c;Orange Pi AIpro无论在外观上、性能上还是技术服务支持上都非常优秀&#xff0c;其8/20TOPS澎湃算力是目前开发板市场中所具备的最大算力&#xff0c;能覆盖生态开发板者的主流应用场景&#xff0c;让用户实践各种创…

Web自动化测试平台开发---Automated_platform

一、项目简介 历时一个假期&#xff0c;Automated_platform 第一版完工&#xff0c;是一款基于po模式的自动化测试平台,采用后端技术为DjangoceleryRabbitMQmysql 配置mysql数据库&#xff0c;进行数据迁移后&#xff0c;运行项目后&#xff0c;即可成功访问http://127.0.0.1:8…

【软考】数据结构之队列和栈

目录 1.例题一1.1题目1.2 题目截图1.3 题目分析 1.例题一 1.1题目 输出受限的双端队列是指元素可以从队列的两端输入&#xff0c;但只能从队列的一端输出&#xff0c;如下图所示&#xff0c;若有e1&#xff0c;e2&#xff0c;e3&#xff0c;e4依次进入输出受限的双端队列&…

Linux——进程控制(一)进程的创建与退出

目录 一、进程创建 1.写时拷贝 2.创建多个进程 二、进程终止 1.main函数的返回值 2.bash中的$? 3.自定义退出码 4.C语言的错误码 5.错误码与退出码的区别 6.代码异常终止 7.exit函数 8.总结 一、进程创建 在之前&#xff0c;我们学过linux中的非常重要的函数——…

速卖通店铺营销秘籍:如何巧妙运用活动提升转化率

对于速卖通卖家而言&#xff0c;想要提升店铺的成交率&#xff0c;除了依赖付费推广外&#xff0c;更重要的是如何通过店铺营销来吸引和留住潜在买家。今天&#xff0c;我们就来深入探讨一下速卖通店铺营销的几个关键策略。 首先&#xff0c;我们要明确一点&#xff0c;速卖通平…

IDEA中的Structure模块使用详解

IDEA中的Structure模块使用详解 类方法的展示 从左往右介绍&#xff1a; 1、最开头的 m 标识是表示为方法&#xff0c;如出现 f 标识则表示为属性&#xff1b; 2、m后面跟着的是方法或者属性的访问修饰符&#xff1a; #红色关闭的锁表示为private&#xff1b; #圆圈表示不带…

使用Docker搭建一款实用的个人IT工具箱——It-Tools

作为程序员&#xff0c;在日常工作中&#xff0c;需要借助一些工具来提高我们工作效率&#xff0c;IT-Tools是为开发人员度身打造的一套便捷在线工具。它提供全面功能&#xff0c;使开发者能以更高效方式完成任务。经由IT-Tools&#xff0c;开发人员能轻松应对各类技术挑战&…

qt QRadioButton 及QButtonGroup 使用

QRadioButton 放在组合框QGroupBox中&#xff0c;再点击时&#xff0c;即使有多个QRadioButton按钮&#xff0c;同时选中的也就只有一个。 如下图所示&#xff0c; 对于多个QRadioButton&#xff0c;每个按钮都写一个槽函数是不太明智的选择&#xff0c;需要将QRadioButton放在…