Linux系统——LAMP架构

news2024/11/19 3:31:37

目录

一、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.php

php.ini配置选项列表:http://php.net/manual/zh/ini.list.php
expose_php = On
#响应报文显示首部字段x-poered-by:PHP/x.y.z,暴露php版本,建议为off

max_execution_time = 30
#最长执行时间为30s

memory_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 Server
   Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)
   Active: active (running) since 三 2024-02-28 16:25:25 CST; 4s ago
     Docs: man:mysqld(8)
           http://dev.mysql.com/doc/refman/en/using-systemd.html
  Process: 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 distribution

Copyright (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 distribution

Copyright (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 distribution

Copyright (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.coloradmin.cn/o/1478836.html

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

相关文章

力扣区间题:合并区间、插入区间

我们可以将区间按照左端点升序排列&#xff0c;然后遍历区间进行合并操作。 我们先将第一个区间加入答案&#xff0c;然后依次考虑之后的每个区间&#xff1a; 如果答案数组中最后一个区间的右端点小于当前考虑区间的左端点&#xff0c;说明两个区间不会重合&#xff0c;因此…

当大语言模型遇到AI绘画-google gemma与stable diffusion webui融合方法-矿卡40hx的AI一体机

你有想过建一台主机&#xff0c;又能AI聊天又能AI绘画&#xff0c;还可以直接把聊天内容直接画出来的机器吗&#xff1f; 当Google最新的大语言模型Gemma碰到stable diffusion webui会怎么样&#xff1f; 首先我们安装stable diffusion webui(automatic1111开源项目&#xff…

【基于ChatGPT大模型】GIS应用、数据清洗、统计分析、论文助手、项目基金助手、科研绘图、AI绘图

以ChatGPT、LLaMA、Gemini、DALLE、Midjourney、Stable Diffusion、星火大模型、文心一言、千问为代表AI大语言模型带来了新一波人工智能浪潮&#xff0c;可以面向科研选题、思维导图、数据清洗、统计分析、高级编程、代码调试、算法学习、论文检索、写作、翻译、润色、文献辅助…

Google Genie:创意互动环境

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

渗透测试靶场环境搭建

1.DVWA靶场 DVWA&#xff08;Damn Vulnerable Web Application&#xff09;是一个用来进行安全脆弱性鉴定的PHP/MySQL Web应用&#xff0c;包含了OWASP TOP10的所有攻击漏洞的练习环境&#xff0c;旨在为安全专业人员测试自己的专业技能和工具提供合法的环境&#xff0c;同时…

完美解决git 执行git push origin master指令 报错command not found

问题描述 报错信息为&#xff1a;在提交项目时的操作&#xff1a;找不到命令行 解决方案 &#xff08;1&#xff09;可以通过如下命令进行代码合并【注&#xff1a;pullfetchmerge】 git pull --rebase origin master&#xff08;2&#xff09;再执行语句&#xff1a; git p…

Linux(CentOS)学习

一、认识Linux 1、如何修改Linux时区 2、配置固定IP 3、重启网络服务 3、小技巧快捷键 4、环境变量设置 5、Linux文件的上传和下载 6、压缩和解压 二、基础命令 1、目录命令 (1、)查看目录内容&#xff08;ls&#xff09; 1、ls //查看当前目录内容 2、- a //显示隐藏内容 3…

Spatom——利用图神经网络进行蛋白质-蛋白质结合位点预测的新工具

介绍一个蛋白质-蛋白质结合位点预测的新工具——Spatom&#xff0c;这是一个图神经网络框架。其发布在brief in bioinformatics上面。 Paper and tool links 文章&#xff0c;网页工具和github链接如下 paper link: Spatom: a graph neural network for structure-based prot…

lv20 QT事件

1 事件模型 2 事件处理 virtual void keyPressEvent(QKeyEvent *event) virtual void keyReleaseEvent(QKeyEvent *event) virtual void mouseDoubleClickEvent(QMouseEvent *event) virtual void mouseMoveEvent(QMouseEvent *event) virtual void mousePressEvent(QMou…

【Android12】Monkey压力测试源码执行流程分析

Monkey压力测试源码执行流程分析 Monkey是Android提供的用于应用程序自动化测试、压力测试的测试工具。 其源码路径(Android12)位于 /development/cmds/monkey/部署形式为Java Binary # development/cmds/monkey/Android.bp // Copyright 2008 The Android Open Source Proj…

《PyTorch深度学习实践》第九讲多分类问题

一、 1、softmax的输入不需要再做非线性变换&#xff0c;也就是说softmax之前不再需要激活函数。softmax两个作用&#xff0c;如果在进行softmax前的input有负数&#xff0c;通过指数变换&#xff0c;得到正数。所有类的概率求和为1。 2、y的标签编码方式是one-hot。one-hot是…

java爬取深圳新房备案价

Java爬取深圳新房备案价 这是我做好效果,一共分3个页面 1、列表;2、统计;3、房源表 列表 价格分析页面 房源页面 一、如何爬取 第一步:获取深圳新房备案价 链接是:http://zjj.sz.gov.cn/ris/bol/szfdc/index.aspx 第二步:通过楼盘名查询获取明细 链接:http://z…

就业班 2401--2.27 Linux Day6--管道和重定向

管道与重定向 只有在开水里&#xff0c;茶叶才能展开生命浓郁的香气. 一、重定向 标准输入、标准正确输出、标准错误输出 进程在运行的过程中根据需要会打开多个文件&#xff0c;每打开一个文件会有一个数字标识。这个标识叫文件描述符。 进程使用文件描述符来管理打开的文件…

Android PDFView 提示401 pom

背景 在开发安卓app&#xff0c;使用PDF组件来解析URL地址 &#xff0c;从github找到一个开源组件 AndroidPdfViewer 遇到一个大坑&#xff0c;一直提示下载依赖401 pom 打开控制台链接弹出需要登录jitpack 原因分析&#xff1a; 这个组件项目依赖库链接到了需要鉴权的…

【airtest】自动化入门教程(一)AirtestIDE

目录 一、下载与安装 1、下载 2、安装 3、打开软件 二、web自动化配置 1、配置chrome浏览器 2、窗口勾选selenium window 三、新建项目&#xff08;web&#xff09; 1、新建一个Airtest项目 2、初始化代码 3、打开一个网页 四、恢复默认布局 五、新建项目&#xf…

服务器数据恢复-服务器RAID5上层XFS文件系统分区数据恢复案例

服务器数据恢复环境&#xff1a; MD1200磁盘柜中的磁盘通过RAID卡创建了一组RAID5阵列&#xff0c;分配了一个LUN。在Linux操作系统层面对该LUN进行了分区&#xff0c;划分sdc1和sdc2两个分区&#xff0c;通过LVM扩容的方式将sdc1分区加入到了root_lv中&#xff1b;sdc2分区格式…

VuePress + GitHub 搭建个人博客踩坑记录

最近想给我教练搭个网站,本来选的是 VuePress 框架,也折腾完了,起码是搭建出来了,踩的坑也都总结好了 但是最近发现了一个更简洁的模板: VuePress-theme-hope ,所以最终网站使用的样式是这个 不过我觉得这里面踩坑的记录应该还是有些价值的,分享出来,看看能不能帮到一些小伙伴~…

手机AI摄影时代开启,传音引领行业标准化建设

今年春节&#xff0c;AI摄影可谓大出风头。人们在社交平台晒出自己在龙年的AI写真&#xff0c;极大地增添了节日的氛围感&#xff0c;也让我们看到了“AI摄影”的价值。新年伊始&#xff0c;手机巨头们纷纷布局该赛道&#xff0c;基于AI大模型实现的影像功能成为业界关注焦点。…

CAPL编程学习笔记--关于on 事件的详细解释

CAPL编程是比较有特色的一种面向通讯的编程语言。 1&#xff1a;on XXX类型&#xff08;即事件类型&#xff09; 维克多的官方文档对CAPL的描述是一门类C语言&#xff0c;说白了它也是用C写出来的。我们看on&#xff08;注意都是小写&#xff09;事件的代码结构 on * { }&…

算法day03_ 59.螺旋矩阵II

推荐阅读 算法day01_ 27. 移除元素、977.有序数组的平方 算法day02_209.长度最小的子数组 目录 推荐阅读59.螺旋矩阵 II题目思路解法 59.螺旋矩阵 II 题目 给你一个正整数 n &#xff0c;生成一个包含 1 到 n2 所有元素&#xff0c;且元素按顺时针顺序螺旋排列的 n x n 正方形…