加入收藏 | 设为首页 | 会员中心 | 我要投稿 武陵站长网 (https://www.50888.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Centos7+Apache2.4+php5.6+mysql5

发布时间:2022-11-16 19:04:17 所属栏目:MySql教程 来源:未知
导读: 加上下面一行,重启apache
ServerName localhost:80
查看端口命令行如下:
#netstat -tnl|grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LIST
测试安装结果,打开浏览器,在

加上下面一行,重启apache

ServerName localhost:80

查看端口命令行如下:

#netstat -tnl|grep 80

tcp 0 0 0.0.0.0:80 0.0.0.0:* LIST

测试安装结果,打开浏览器,在地址栏中输入URL为:

如果浏览器中出现It works!则表明Apache服务器可以使用。

每种服务器软件都有必要制成开机时自动启动,Apache服务器开机自动启动,只要在“/etc/rc.d/rc.local”文件,加上 Apache服务器的启动命令即可。可以直接打开“/etc/rc.d/rc.local

”文件,在最后一行写入Apache启动命令,也可以用echo 命令追加进去,如下命令行示:

[root@localhost apache243]# echo “/usr/local/apache2/bin/apachectl start” >> /etc/rc.d/rc.local

2.12 安装配置MySQL数据库管理系统

PS:安装cmake的目的是,自mysql5.5及以上的源程序包,不再包括configure文件,因此不能直接安装,需要使用cmake来进行安装,因此安装mysql5.5以上的软件版本,需要首先确保操作系统中已经编译安装cmake软件。本例子中cmake和mysql一起安装。

cmake下载地址

2.12.1 安装编译cmake

# cd /usr/local/src/cmake-3.3.1

# ./configure //cmake仍然可以用configure命令来安装,在此,最好不要指定安装路径,以免后面安装mysql时提示找不到cmake

# make && make install

2.12.2 检查ncurses安装包是否安装

执行下面三行命令,执行完之后重新./configure(配置)

yum list|grep ncurses

yum -y install ncurses-devel

yum install ncurses-devel

2.12.3 使用cmake编译安装mysql

# cd /usr/local/src/mysql-5.5.27

# mkdir/usr/local/mysql

# make && make install

# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql

# make && make install

2.12.4 增加用户名和用户组

#groupadd mysql

#useradd -g mysql mysql

2.12.5 创建mysql数据库服务器的配置文件

可以使用源码包support-files目录中的my-medium.cnf文件作为模板,将其复制到/etc/目录下,命名为my.cnf文件即可。

[root@localhost mysql-5.0.18]# cp support-files/my-medium.cnf /etc/my.cnf

2.12.6 修改目录属主属组

将程序二进制的所有权改为root用户,数据目录的所有权改为运行mysqld程序的mysql用户。如果现在位于安装目录(/usr/local/mysql)下,命令行如下:

[root@localhost mysql]# chown -R root .(注意有点) //将文件的所有属性改为root用户

[root@localhost mysql]# chown -R mysql data //将数据目录的所有属性改为mysql用户,mysql5.5之前版本目录为var目录

[root@localhost mysql]# chgrp -R mysql . //将组属性改为mysql组

核查

[root@localhost mysql]# ls -l

total 40

drwxr-xr-x. 2 root mysql 4096 Feb 7 20:50 bin

drwxr-xr-x. 3 root mysql 4096 Feb 7 20:50 include

drwxr-xr-x. 2 root mysql 4096 Feb 7 20:50 info

drwxr-xr-x. 3 root mysql 4096 Feb 7 20:50 lib

drwxr-xr-x. 2 root mysql 4096 Feb 7 20:50 libexec

drwxr-xr-x. 3 root mysql 4096 Feb 7 20:50 man

drwxr-xr-x. 7 root mysql 4096 Feb 7 20:50 mysql-test

drwxr-xr-x. 3 root mysql 4096 Feb 7 20:50 share

drwxr-xr-x. 5 root mysql 4096 Feb 7 20:50 sql-bench

drwx——. 4 mysql mysql 4096 Feb 7 20:53 data

2.12.7 启动mysql服务

在所需要的东西被安装完成后,应当使用下面的命令启动MySQL服务了,命令行如下:

[root@localhost mysql]#/usr/local/mysql/bin/mysqld_safe –user=mysql &

[root@localhost mysql]# nohup: ignoring input and redirecting stderr to stdout

Starting mysqld daemon with databases from /usr/local/mysql/var

2.12.8 检查监听端口

MySQL数据库服务器启动之后,查看一下它的端口3306是否打开,如果看到以下结果表明mysql服务启动成功。命令行如下

[root@localhost mysql]# netstat -tnl|grep 3306

tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN

2.12.9 设置访问权限

在mysql安装过程中,使用mysql_install_db程序安装了mysql数据库授权表,表定义了初始mysql用户 账户和访问权限,所有初始化账户均没有密码。这些账户为超用户账户mysql命令行,可以执行任何操作。初始root账户的密码为空,因此任何人可以用root账户不用任 何密码来连接mysql服务器,并具有所有权限,这意味着mysql安装未受保护。如果你想要防止客户端不使用密码用匿名用户来连接,你应当为匿名账户指 定密码或删掉匿名帐户,应当为mysql root账户指定密码。使用mysql -u root启动mysql客户端控制台,连接mysql服务器。命 令行如下:

[root@localhost mysql]# bin/mysql -u root //没有密码可直接登录本机mysql服务器

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 5 to server version: 5.0.18-log

Type ‘help;’ or ‘\h’ for help. Type ‘\c’ to clear the buffer.

2.12.10 删除匿名用户

如果有匿名账户存在,它拥有全部的权限,因此删掉它可以提高安全,在mysql客户端执行SQL语如下:

mysql> delete from mysql.user where host=’localhost’ and user=”;

Query OK, 1 row affected (0.01 sec)

mysql> flush privileges; //立即生效

Query OK, 0 rows affected (0.00 sec)

2.12.11 密码指定方法

可以用几种方法为root账户指定密码,我们选择用其中的一种。在mysql客户端命令行上使用set password指定密码,一定要使 用password()函数来加密密码。例如下面设置localhost域的密码为itts-union.com。其他域可以使用同样的语句,使用的SQL语句如下。

mysql> set password for ‘root’@’localhost’=password(‘itts-union.com’);

Query OK, 0 rows affected (0.00 sec)

2.12.12 关闭mysql服务器

如果想关闭mysql服务器,在命令行使用mysql服务器的mysqladmin命令,通过-u参数给出mysql数据库管理员用户名root和通过-p参数给出密码,即可关闭mysql服务器。如下示:

[root@localhost mysql]# bin/mysqladmin -u root -p shutdown

Enter password:

STOPPING server from pid file /usr/local/mysql/var/localhost.pid

130207 21:27:05 mysqld ended

[1]+ Done /usr/local/mysql/bin/mysqld_safe –user=mysql

2.12.13 设置mysql服务开机自启动

mysql服务器和apache服务器一样也有必要设置为开机自动运行,设置方法进入到mysql源代码目录/usr/local/src /mysql-5.0.18,将子目录support-files下的mysql.server文件复制

到/etc/rc.d/init.d目录中,并重 命名为mysqld,命令行如下。

[root@localhost mysql]# cd /usr/src/mysql-5.5.28

[root@localhost mysql-5.5.28]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld

修改一下权限

[root@localhost mysql-5.5.28]# chown root.root /etc/rc.d/init.d/mysqld

[root@localhost mysql-5.5.28]# chmod 755 /etc/rc.d/init.d/mysqld

把mysqld添加到chkconfig中

[root@localhost mysql-5.5.28]# chkconfig –add mysqld

在图形和字符集界面下自动启动mysqld

[root@localhost mysql-5.5.28]# chkconfig –level 3 mysqld on

[root@localhost mysql-5.5.28]# chkconfig –level 5 mysqld on

再使用chkconfig –list命令检查设置

[root@localhost mysql-5.0.18]# chkconfig –list mysqld

mysqld 0:off 1:off 2:on 3:on 4:off 5:on 6:off

2.12.13 创建远程访问用户

请大家参考Mysql创建用户与授权,以便创建适合自己的用户和权限

2.13 安装配置PHP

2.13.1 进入php-5.4.11源码包编译

mkdir/usr/local/php

[root@localhost php-5.4.11]# ./configure \

-prefix=/usr/local/php \

-with-config-file-path=/usr/local/php/etc \

-with-apxs2=/usr/local/apache2/bin/apxs \

-with-mysql=/usr/local/mysql/ \

-with-libxml-dir=/usr/local/libxml2/ \

-with-png-dir=/usr/local/libpng/ \

-with-jpeg-dir=/usr/local/jpeg8/ \

-with-freetype-dir=/usr/local/freetype/ \

-with-gd=/usr/local/gd/ \

-with-zlib-dir=/usr/local/zlib/ \

-with-xpm-dir=/usr/lib \

-with-mcrypt=/usr/local/libmcrypt/ \

-with-mysqli=/usr/local/mysql/bin/mysql_config \

-enable-soap \

-enable-mbstring=all \

-enable-sockets

make(配置)

提示信息:

Build complete.

Don’t forget to run ‘make test’.

解决方案:不要make test 直接make install

常见的报错及解决

报错1 配置时可能会出现下面的错误:

checking for MySQL support… yes

checking for specified location of the MySQL UNIX socket… no

checking for MySQL UNIX socket location… no

configure: error: Cannot find libmysqlclient_r under /usr/local/mysql. Note that the MySQL client library is not bundled anymore!

其实这跟PHP没有关系,那是因为在编译APACHE的时候,使用–with-mpm模块,所以就必须在编译MYSQL的时候加上 –enable-thread-safe-client.参数这是PHP5.2的一个改进,在PHP5.2.0之前的版本都不需要MYSQL启用安全线程。关于–enable-thread-safe- client项的官方介绍如下:如何生成线程式客户端库总是线程安全的。最大的问题在于从套接字读取的net.c中的子程序并不是中断安全的。或许你可能 希望用自己的告警中断对服务器的长时间读取,以此来解决问题。如果为SIGPIPE中断安装了中断处理程序,套接字处理功能应是线程安全的。 SupeSite/X-为了避免连接中断时放弃程序,MySQL将在首次调用mysql_server_init()、mysql_init()或 mysql_connect()时屏蔽SIGPIPE。如果你打算使用自己的SIGPIPE处理程序,首先应调用 mysql_server_init(),然后安装你的处理程序.

还有第二种解决方法比较方便 :编译之前,先处理一下mysql的库,默认查找libmysqlclient_r.so,可是mysql默认为libmysqlclient.so,内容完全一样,做个链接即可

# cd /usr/local/mysql/lib/mysql/

# ln -s libmysqlclient.so.15.0.0 libmysqlclient_r.so

还会报make: *** [ext/gd/gd.lo] error

解决方法如下:

好像说这个错误算是php5.4的bug,下面对应的两篇文章有对应的说明:

mysql 命令查看数据类型_mysql命令_mysql命令行

解决方法:

vi /include/gd_io.h

gdIOCtx结构中增加void *data;

格式如下

typedef struct gdIOCtx

{

int (*getC) (struct gdIOCtx *);

int (*getBuf) (struct gdIOCtx *, void *, int);

void (*putC) (struct gdIOCtx *, int);

int (*putBuf) (struct gdIOCtx *, const void *, int);

/* seek must return 1 on SUCCESS, 0 on FAILURE. Unlike fseek! */

int (*seek) (struct gdIOCtx *, const int);

long (*tell) (struct gdIOCtx *);

void (*gd_free) (struct gdIOCtx *);

void (*data);

}

gdIOCtx;

我的GD安装在/usr/local/gd目录下,所以是#vi vi /usr/local/gd/include/gd_io.h

报错2

libltdl.so.3: cannot open shared object file: No such file or directory

make: *** [ext/phar/phar.php] Error 127

解决方法:

ln -s /usr/local/lib/libltdl.so.3 /usr/lib/libltdl.so.3

[root@localhost ~]# cd /usr/local/libpng/lib/

[root@localhost lib]# ls

libpng15.a libpng15.so libpng15.so.15.10.0 libpng.la pkgconfig

libpng15.la libpng15.so.15 libpng.a libpng.so

可以看到libpng15.so.15

然后修改/etc/ld.so.conf 文件:vi /etc/ld.so.conf

在第一行下面追加/usr/local/libpng/lib这个路径。

然后重新编译安装即可。

报错3

checking for png_write_image in -lpng… yes configure: error: libXpm.(a|so) not found.

解决方法: yum install libXpm-devel

其他错误,参考下面

PHP编译安装时常见错误解决办法

& make

& make install //完成编译安装

2.13.2 创建配置文件

安装完成后,需要建立PHP配置文件。在使用configure命令安装配置时使用“–with-config-file-path=/usr/local/php/etc/”选项,指定了配置文件的位置。将源码包下面的php.ini-development 文件复制到/usr/local/php/etc/中,并改名为php.ini即可,如下示:

[root@localhost php-5.4.11]# cp php.ini-development /usr/local/php/etc/php.ini

修改php.ini 把;date.timezone 前面的分号去掉,改成date.timezone =”PRC”

2.13.3 php和apache的整合

整合Apache与PHP,在上面编译之前,我们使用configure命令安装配置时,使用–with-apxs2=/usr/local/apache2/bin/apxs选项以使Apache 2将PHP作为功能模块使用。

但我们还要修改Apahce配置文件,添加PHP的支持,告 诉Apache将哪些后缀作为PHP解析。

例如,让Apache把.php或.phtml后缀名解析为PHP.使用vi打开Apache的配置文件 /etc/httpd/httpd.conf,找到AddType application/x-gzip .gz .tgz指令选项,并在其下方添加一 条指令

AddType application/x-httpd-php .php .phtml。也可以将任何后缀的文件解析为PHP,只要在添加的语 句中加入并用空格分开,这里以多添加一个.phtml来示例,如下示:

# If the AddEncoding directives above are commented-out, then you

# probably should define those extensions to indicate media types:

#

AddType application/x-compress .Z

AddType application/x-gzip .gz .tgz

AddType application/x-httpd-php .php .phtml

修改完成后必须重启Apache服务器,才能重新加载配置文件使修改生效。

[root@localhost php-5.4.11]#/usr/local/apache2/bin/apachectl stop

[root@localhost php-5.4.11]#/usr/local/apache2/bin/apachectl start

2.13.4 测试PHP环境可用性

测试PHP环境是否可以正常运行,在/usr/local/apache2/htdocs目录下建一个test.php或test.phtml的文件,内容如下示:

打开浏览器,在地址栏输入来运行该文件,如果出现下图内容,说明LAMP环境安装成功。

Centos7+Apache2.4+php5.6+mysql5.5搭建Lamp环境——为了wordPress

二、安装WordPress

解压wordpress的压缩包

tar zxvf wordpress-4.4.2-zh_CN.tar.gz

更改文件的读写权限

chmod -R 777wordpress

将解压后的wordpress下的所有文件复制到/usr/local/apache2/htdocs/下

在浏览器中输入地址

进入wordpress的安装界面,按提示安装即可

总结:

在我自己的服务器上,看着文章磨蹭着,花了大概5个小时才搭完LAMP环境,一方面是不熟练,另一方面是还不够了解。如果出了问题,一定要耐心,去查资料。

再次感谢“哥们”的文章,大部分内容是他的原创,我在他的基础上结合我的事实情况做了一些删改。

(编辑:武陵站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!