CentOS6.4+httpd2.4.4+mysql5.6.12+php5.4.16+xcache3.03(最新LAMP编译安装过程)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

大纲

一、编译安装Apache

二、安装Mysql数据库

三、编译安装PHP

四、整合Apache与PHP

五、安装Xcache加速器

六、启用服务器状态

七、PHP连接Mysql测试

八、安装Discuz论坛(Discuz_X3.0_SC_GBK)

注:所有软件版本 CentOS6.4+httpd2.4.4+mysql5.6.12+php5.4.16+xcache3.03 都是目前最新(所有的安装包点击这里下载

一、编译安装Apache

1. 安装前准备

修改yum源(163)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
[root@web ~] # yum install wget
[root@web ~] # wget http://mirrors.163.com/.help/CentOS6-Base-163.repo
--2013-06-29 18:39:02--  http: //mirrors .163.com/.help /CentOS6-Base-163 .repo
Resolving mirrors.163.com... 123.58.173.106
Connecting to mirrors.163.com|123.58.173.106|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 2006 (2.0K) [application /octet-stream ]
Saving to: a?CentOS6-Base-163.repo?
100%[================>] 2,006       --.-K /s    in  0s
2013-06-29 18:39:02 (152 MB /s ) - a?CentOS6-Base-163.repoa? saved [2006 /2006 ]
[root@web ~] # cd /etc/yum.repos.d/
[root@web yum.repos.d] # mv CentOS-Base.repo CentOS-Base.repo.bak
[root@web yum.repos.d] # mv /root/CentOS6-Base-163.repo CentOS-Base.repo
[root@web yum.repos.d] # ls
CentOS-Base.repo       CentOS-Media.repo
CentOS-Base.repo.bak   CentOS-Vault.repo
CentOS-Debuginfo.repo
[root@web yum.repos.d] # yum clean all
Loaded plugins: fastestmirror
Cleaning repos: base extras updates
Cleaning up Everything
Cleaning up list of fastest mirrors
[root@web yum.repos.d] # yum makecache
Loaded plugins: fastestmirror
Determining fastest mirrors
base                               | 3.7 kB     00:00
base /group_gz                       | 212 kB     00:00
base /filelists_db                   | 5.9 MB     00:01
base /primary_db                     | 4.4 MB     00:01
base /other_db                       | 2.7 MB     00:00
extras                                                                                             | 3.4 kB     00:00
extras /filelists_db                                                                                 |  10 kB     00:00
extras /prestodelta                                                                                  |  905 B     00:00
extras /primary_db                                                                                   |  18 kB     00:00
extras /other_db                                                                                     | 5.7 kB     00:00
updates                                                                                            | 3.4 kB     00:00
updates /filelists_db                                                                                | 2.9 MB     00:00
updates /prestodelta                                                                                 | 617 kB     00:02
updates /primary_db                                                                                  | 3.2 MB     00:00
updates /other_db                                                                                    | 419 kB     00:00
Metadata Cache Created
[root@web yum.repos.d] #


安装编译工具

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@web yum.repos.d] #yum groupinstall "Development Tools" "Development Libraries" –y
[root@web yum.repos.d] # yum grouplist
Loaded plugins: fastestmirror
Setting up Group Process
Loading mirror speeds from cached hostfile
Installed Groups:
    Development tools
    E-mail server
    Fonts
    General Purpose Desktop
    Graphical Administration Tools
    Input Methods
    Legacy X Window System compatibility
    MySQL Database client
    Perl Support

关闭SElinux

1
2
3
4
5
6
7
8
9
10
11
12
[root@web ~] # vim /etc/selinux/config
# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#     enforcing - SELinux security policy is enforced.
#     permissive - SELinux prints warnings instead of enforcing.
#     disabled - No SELinux policy is loaded.
SELINUX=disabled
# SELINUXTYPE= can take one of these two values:
#     targeted - Targeted processes are protected,
#     mls - Multi Level Security protection.
SELINUXTYPE=targeted
[root@web ~] # reboot

关闭防火墙

1
2
3
4
5
6
7
8
[root@web ~] # service iptables stop
[root@web ~] # service ip6tables stop
[root@web ~] # chkconfig iptables off
[root@web ~] # chkconfig ip6tables off
[root@web ~] # chkconfig iptables --list
iptables        0:off   1:off   2:off   3:off   4:off   5:off   6:off
[root@web ~] # chkconfig ip6tables --list
ip6tables       0:off   1:off   2:off   3:off   4:off   5:off   6:off

修改主机名

1
2
3
4
5
6
7
[root@web ~] # vim /etc/sysconfig/network
NETWORKING= yes
HOSTNAME=web. test .com
~          
[root@web ~] # vim /etc/hosts
127.0.0.1   web web. test .com localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6


2. 解决依赖关系

httpd-2.4.4需要较新版本的apr和apr-util,因此需要事先对其进行升级。升级方式有两种,一种是通过源代码编译安装,一种是直接升级rpm包。

(1). 编译安装apr

1
2
3
4
5
6
[root@web src] # tar xf apr-1.4.6.tar.bz2
[root@web src] # cd apr-1.4.6
[root@web src] # ./configure --help | less             (可以查看帮助文件)
[root@web src] # ./configure --prefix=/usr/local/apr  (指定安装路径)
[root@web src] # make
[root@web src] # make install


(2). 编译安装apr-util

1
2
3
4
5
6
7
[root@web src] # tar xf apr-util-1.5.2.tar.bz2
[root@web src] # cd apr-util-1.5.2
[root@web src] # ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
(--prefix指定安装路径;--with-apr指定apr的安装路径,apr-util依赖于apr)
[root@web src] # make && make install
附:apache官方对APR的介绍:
The mission of the Apache Portable Runtime (APR) project is to create and maintain software libraries that provide a predictable and consistent interface to underlying platform-specific implementations. The primary goal is to provide an API to  which  software developers may code and be assured of predictable  if  not identical behaviour regardless of the platform on  which  their software is built, relieving them of the need to code special- case  conditions to work around or take advantage of platform-specific deficiencies or features.

(3). httpd-2.4.4编译过程也要依赖于pcre-devel软件包,需要事先安装。

1
[root@web ~] # yum install pcre-devel -y

3. 编译安装httpd-2.4.4

1
2
3
4
5
6
7
8
9
10
11
12
13
[root@web src] # tar xf httpd-2.4.4.tar.gz
[root@web src] # cd httpd-2.4.4
[root@web httpd-2.4.4] # ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-cgid --enable-modules=most --enable-mods-shared=most --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-mpms-shared=all --with-mpm=event
--sysconfdir= /etc/httpd   :指定配置文件安装位置
-- enable -so              :支持动态共享模块如果没有这个模块PHP将无法与apache结合工作
-- enable -ssl             :启用支持ssl
-- enable -cgi             :支持cgi
-- enable -rewrite         :支持URL重写
  --with-zlib             :压缩库,在互联网上传播时可节约带宽
--with-apr= /usr/local/apr  :指定apr路径
--with-apr-util= /usr/local/apr-util  :指定apr-util路径
-- enable -mpms-shared=all  :支持多道处理模块
--with-mpm=event         :设定默认的模块

错误:

1
checking whether to  enable  mod_ssl... configure: error: mod_ssl has been requested but can not be built due to prerequisite failures

解决方法:

1
[root@web httpd-2.4.4] # yum install -y openssl-devel

补充说明:

(1)构建MPM为静态模块   
在 全部平台中,MPM都可以构建为静态模块。在构建时选择一种MPM,链接到服务器中。如果要改变MPM,必须重新构建。为了使用指定的MPM,请在执行 configure脚本 时,使用参数 --with-mpm=NAME。NAME是指定的MPM名称。编译完成后,可以使用 httpd -l 来确定选择的MPM。 此命令会列出编译到服务器程序中的所有模块,包括 MPM。

(2)构建 MPM 为动态模块   
在 Unix或类似平台中,MPM可以构建为动态模块,与其它动态模块一样在运行时加载。 构建 MPM 为动态模块允许通过修改LoadModule指令内容来改变MPM,而不用重新构建服务器程序。在执行configure脚本时,使用--enable- mpms-shared选项即可启用此特性。当给出的参数为all时,所有此平台支持的MPM模块都会被安装。还可以在参数中给出模块列表。默认MPM, 可以自动选择或者在执行configure脚本时通过--with-mpm选项来指定,然后出现在生成的服务器配置文件中。编辑LoadModule指令 内容可以选择不同的MPM。

4. 修改httpd的主配置文件,设置其Pid文件的路径

说明:手动编译安装后,httpd.pid文件是存放在/usr/local/apache/logs/目录下的,这个位置未免有些不方便。

更改配置文件

1
2
3
4
5
6
[root@web httpd-2.4.4] # cd
[root@web ~] # cd /etc/httpd/
[root@web httpd] # ls
conf  conf.d  extra  httpd.conf  logs  magic  mime.types  modules  original  run
[root@web httpd] # cp httpd.conf httpd.conf.bak
[root@web httpd] # vim httpd.conf

#在配置文件中找一个位置定义一下Pid文件路径就可以了

1
Pidfile  "/var/run/httpd.pid"

5. 提供SysV服务脚本/etc/rc.d/init.d/httpd

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
[root@web httpd] # vim /etc/init.d/httpd
#!/bin/bash
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server.  It is used to serve \
/etc/rc .d /init .d /functions       -----读取函数
if  [ -f  /etc/sysconfig/httpd  ];  then
         /etc/sysconfig/httpd
fi
# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG- "C" }
# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS= ""
# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.
# Path to the apachectl script, server binary, and short-form for messages.
apachectl= /usr/local/apache/bin/apachectl    # -----指定apachectl程序位置
httpd=${HTTPD- /usr/local/apache/bin/httpd #-------httpd程序位置
prog=httpd
pidfile=${PIDFILE- /var/run/httpd .pid}   #----如果文件存在就使用存在文件路径,如果不存在就使用/var/rum/httpd.pid
lockfile=${LOCKFILE- /var/lock/subsys/httpd # --------创建的锁文件
RETVAL=0
start() {
         echo  -n $ "Starting $prog: "
         LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS  #----以$pidfile文件执行httpd 并且使用选项start
         RETVAL=$?   #------定义执行状态返回值
         echo
         [ $RETVAL = 0 ] &&  touch  ${lockfile}  #-----成功时创建锁文件
         return  $RETVAL
}
stop() {
        echo  -n $ "Stopping $prog: "
        killproc -p ${pidfile} -d 10 $httpd
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] &&  rm  -f ${lockfile} ${pidfile}
}
reload() {
     echo  -n $ "Reloading $prog: "
     if  ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >& /dev/null then
         RETVAL=$?
         echo  $ "not reloading due to configuration syntax error"
         failure $ "not reloading $httpd due to configuration syntax error"
     else
         killproc -p ${pidfile} $httpd -HUP
         RETVAL=$?
     fi
     echo
}
# See how we were called.
case  "$1"  in
   start)
        start
        ;;
   stop)
        stop
        ;;
   status)
         status -p ${pidfile} $httpd
        RETVAL=$?
        ;;
   restart)
        stop
        start
        ;;
   condrestart)
        if  [ -f ${pidfile} ] ;  then
               stop
               start
        fi
        ;;
   reload)
         reload
        ;;
   graceful|help|configtest|fullstatus)
        $apachectl $@
        RETVAL=$?
        ;;
   *)
        echo  $ "Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
        exit  1
esac
exit  $RETVAL

[root@web httpd]# chmod +x /etc/init.d/httpd  #添加执行权限

#设置开机自启动

1
2
3
4
5
[root@web httpd] # chkconfig httpd --add
[root@web httpd] # chkconfig httpd on
[root@web httpd] # chkconfig httpd --list
httpd           0:off   1:off   2:on    3:on    4:on    5:on    6:off
[root@web httpd] #

6. 启动apache并测试

1
2
3
4
5
6
7
8
9
10
11
12
13
14
[root@web httpd] # service httpd start
Starting httpd: AH00558: httpd: Could not reliably determine the server 's fully qualified domain name, using web.test.com. Set the ' ServerName' directive globally to suppress this message
                                                            [  OK  ]
[root@web httpd] #
[root@web httpd] # netstat -ntulp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID /Program  name
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      990 /sshd 
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1066 /master
tcp        0      0 :::80                       :::*                        LISTEN      36920 /httpd
tcp        0      0 :::22                       :::*                        LISTEN      990 /sshd 
tcp        0      0 ::1:25                      :::*                        LISTEN      1066 /master
udp        0      0 0.0.0.0:68                  0.0.0.0:*                               890 /dhclient
[root@web httpd] #

启动成功了,但似乎有警告,我们看一下!

1
Starting httpd: AH00558: httpd: Could not reliably determine the server 's fully qualified domain name, using web.test.com. Set the ' ServerName' directive globally to suppress this message

解决方案:

编辑httpd.conf文件,搜索"/ServerName",添加ServerName localhost:80

1
2
3
4
5
6
[root@web httpd] # vim /etc/httpd/httpd.conf
再重新启动apache 即可。
[root@web httpd] # service httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@web httpd] #

好了问题解决,下面我们用Windows 7访问一下!效果如下:

效果图1

好了测试成功,下面我们继续!

7. 为httpd服务的相关命令添加环境变量

1
2
3
[root@web httpd] # httpd
- bash : httpd:  command  not found
[root@web httpd] #

大 家看到了,虽然我们可以使用 service httpd restart 来重新启动Apache,是我们无法使用httpd命令,下面我们就来解决一下!直接在/etc/profile.d目录下创建的httpd.sh环境变 量文件,因为在默认的情况下这个目录下定义的环境变量都是profile文件的组成部分。

1
2
3
4
5
6
[root@web httpd] # vim /etc/profile.d/httpd.sh
export  PATH=$PATH: /usr/local/apache/bin
[root@web httpd] # source /etc/profile #重新读取一下环境变量
[root@web httpd] # httpd –t #测试一下
Syntax OK
[root@web httpd] #

现在httpd服务的相关命令就可以直接使用了,嘿嘿!

二、安装Mysql数据库

1. 准备数据存放的文件系统

说明:新建一个逻辑卷,并将其挂载至特定目录即可。这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录。

(1). 先确认下系统里是否有LVM工具,默认没有安装

1
2
[root@web httpd] # rpm -qa | grep lvm
[root@web httpd] # yum install -y lvm2

(2). 查看一下磁盘

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@web httpd] # fdisk -l
Disk  /dev/sda : 21.5 GB, 21474836480 bytes
255 heads, 63 sectors /track , 2610 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical /physical ): 512 bytes / 512 bytes
I /O  size (minimum /optimal ): 512 bytes / 512 bytes
Disk identifier: 0x0000a0a2
    Device Boot      Start         End      Blocks   Id  System
/dev/sda1    *           1          26      204800   83  Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2               26        1301    10240000   83  Linux
/dev/sda3             1301        1938     5120000   83  Linux
/dev/sda4             1938        2611     5405696    5  Extended
/dev/sda5             1939        2066     1024000   82  Linux swap / Solaris
[root@web httpd] #

(3). 创建逻辑分区

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
[root@web ~] # fdisk /dev/sda
/dev/sda7             2066        2327     2099724   8e  Linux LVM  #我这里是测试环境就创建了一个2G分区
[root@web ~] # partx -a /dev/sda #告诉内核有关存在和磁盘上的分区的编号
[root@web ~] # pvcreate /dev/sda7 #创建物理卷
   Physical volume  "/dev/sda7"  successfully created
[root@web ~] # vgcreate myvg /dev/sda7 #创建卷组
   Volume group  "myvg"  successfully created
[root@web ~] #
[root@web ~] # lvcreate -n mydata -L 1G myvg #创建一个1G的逻辑卷
   Logical volume  "mydata"  created
[root@web ~] # lvs
   LV     VG   Attr      LSize Pool Origin Data%  Move Log Cpy%Sync Convert
   mydata myvg -wi-a---- 1.00g                                  
[root@web ~] #
[root@web ~] # mkfs.ext4 /dev/myvg/mydata #格式化
[root@web ~] # mkdir /mydata #创建挂载目录
[root@web ~] # mount /dev/myvg/mydata /mydata/ #挂载
[root@web ~] # vim /etc/fstab
/dev/myvg/mydata         /mydata                  ext4    defaults        0 0  #增加这一行
[root@web ~] # mount –a #测试挂载是否成功
[root@web ~] # mount
/dev/sda2  on /  type  ext4 (rw)
proc on  /proc  type  proc (rw)
sysfs on  /sys  type  sysfs (rw)
devpts on  /dev/pts  type  devpts (rw,gid=5,mode=620)
tmpfs on  /dev/shm  type  tmpfs (rw)
/dev/sda1  on  /boot  type  ext4 (rw)
/dev/sda3  on  /data  type  ext4 (rw)
none on  /proc/sys/fs/binfmt_misc  type  binfmt_misc (rw)
/dev/mapper/myvg-mydata  on  /mydata  type  ext4 (rw)
[root@web ~] #

(4). 为了便于管理在/mydata目录下再创建个子目录data用于存放数据

1
2
3
4
[root@web ~] # mkdir /mydata/data
[root@web ~] # ls /mydata/
data  lost+found
[root@web ~] #

2. 新建用户以安全方式运行进程

1
2
3
[root@web ~] # groupadd -r mysql
[root@web ~] # useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql
[root@web ~] # chown -R mysql:mysql /mydata/data

3. 安装并初始化mysql5.6.12

(1). 说明:mysql 安装包有三种式,rpm,源码包,二进制包(已编译好,解压后简单配置一下就可以用),我这里用的就是二进制包

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
[root@web src] # tar -xf mysql-5.6.12-linux-glibc2.5-x86_64.tar.gz -C /usr/local/ #-C指定解压目录
[root@web  local ] # ln -sv mysql-5.6.12-linux-glibc2.5-x86_64/ mysql #创建软链接
`mysql ' -> `mysql-5.6.12-linux-glibc2.5-x86_64/'
[root@web  local ] # cd mysql
[root@web mysql] # ls
bin      data  include         lib  mysql- test   scripts  sql-bench
COPYING  docs  INSTALL-BINARY   man   README      share    support-files
[root@web mysql] #
[root@web mysql] # chown -R mysql:mysql . #更改属主属组
[root@web mysql] # ll
total 76
drwxr-xr-x  2 mysql mysql  4096 Jun 29 21:12 bin
-rw-r--r--  1 mysql mysql 17987 May 21 23:18 COPYING
drwxr-xr-x  3 mysql mysql  4096 Jun 29 21:12 data
drwxr-xr-x  2 mysql mysql  4096 Jun 29 21:12 docs
drwxr-xr-x  3 mysql mysql  4096 Jun 29 21:12 include
-rw-r--r--  1 mysql mysql  7469 May 21 23:18 INSTALL-BINARY
drwxr-xr-x  3 mysql mysql  4096 Jun 29 21:12 lib
drwxr-xr-x  4 mysql mysql  4096 Jun 29 21:12  man
drwxr-xr-x 10 mysql mysql  4096 Jun 29 21:12 mysql- test
-rw-r--r--  1 mysql mysql  2496 May 21 23:18 README
drwxr-xr-x  2 mysql mysql  4096 Jun 29 21:12 scripts
drwxr-xr-x 28 mysql mysql  4096 Jun 29 21:12 share
drwxr-xr-x  4 mysql mysql  4096 Jun 29 21:12 sql-bench
drwxr-xr-x  3 mysql mysql  4096 Jun 29 21:12 support-files

(2). 执行mysql 初始化的data存放位置的准备

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
[root@web mysql] # scripts/mysql_install_db --user=mysql --datadir=/mydata/data #执行mysql 初始化的data存放位置的准备
Installing MySQL system tables.... /bin/mysqld : error  while  loading shared libraries: libaio.so.1: cannot  open  shared object  file : No such  file  or directory
#初始化时报错说缺少libaio.so我们安装一下
[root@web mysql] # yum install libaio
[root@web mysql] # scripts/mysql_install_db --user=mysql --datadir=/mydata/data #再次执行mysql 初始化的data存放位置的准备
To start mysqld at boot  time  you have to copy
support-files /mysql .server to the right place  for  your system
PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To  do  so, start the server,  then  issue the following commands:
   . /bin/mysqladmin  -u root password  'new-password'
   . /bin/mysqladmin  -u root -h web. test .com password  'new-password'
Alternatively you can run:
   . /bin/mysql_secure_installation
which  will also give you the option of removing the  test
databases and anonymous user created by default.  This is
strongly recommended  for  production servers.
See the manual  for  more  instructions.
You can start the MySQL daemon with:
   cd  . ; . /bin/mysqld_safe  &
You can  test  the MySQL daemon with mysql- test -run.pl
   cd  mysql- test  ; perl mysql- test -run.pl
Please report any problems with the . /bin/mysqlbug  script!
The latest information about MySQL is available on the web at
http: //www .mysql.com
Support MySQL by buying support /licenses  at http: //shop .mysql.com
WARNING: Found existing config  file  . /my .cnf on the system.
Because this  file  might be  in  use, it was not replaced,
but was used  in  bootstrap (unless you used --defaults- file )
and when you later start the server.
The new default config  file  was created as . /my-new .cnf,
please compare it with your  file  and take the changes you need.
WARNING: Default config  file  /etc/my .cnf exists on the system
This  file  will be  read  by default by the MySQL server
If you  do  not want to use this, either remove it, or use the
--defaults- file  argument to mysqld_safe when starting the server
[root@web mysql] #
[root@web mysql] # ls /mydata/data/ #查看 data 目录有文件说明初始化成功
ibdata1  ib_logfile0  ib_logfile1  mysql  performance_schema   test

(3). 初始化完成后mysql中目录文件的属主应改回成root,以免被别人攻破mysql用户密码而带来数据破坏等

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[root@web mysql] # cd /usr/local/mysql/
[root@web mysql] # chown root /usr/local/mysql/* -R
[root@web mysql] # ll
total 84
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 bin
-rw-r--r--  1 root mysql 17987 May 21 23:18 COPYING
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 data
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 docs
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 include
-rw-r--r--  1 root mysql  7469 May 21 23:18 INSTALL-BINARY
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 lib
drwxr-xr-x  4 root mysql  4096 Jun 29 21:12  man
-rw-r--r--  1 root root    943 Jun 29 21:18 my.cnf
-rw-r--r--  1 root root    943 Jun 29 21:23 my-new.cnf
drwxr-xr-x 10 root mysql  4096 Jun 29 21:12 mysql- test
-rw-r--r--  1 root mysql  2496 May 21 23:18 README
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 scripts
drwxr-xr-x 28 root mysql  4096 Jun 29 21:12 share
drwxr-xr-x  4 root mysql  4096 Jun 29 21:12 sql-bench
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 support-files
[root@web mysql] #

4. 为mysql提供主配置文件

初始化后会自动在当前目录下创建一个my.cnf配置文件,直接修改就可以(在mysql 5.6 以后配置文件自动生成,不需要我们再进行复制)

(1).  查看配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
[root@web mysql] # ll
total 84
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 bin
-rw-r--r--  1 root mysql 17987 May 21 23:18 COPYING
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 data
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 docs
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 include
-rw-r--r--  1 root mysql  7469 May 21 23:18 INSTALL-BINARY
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 lib
drwxr-xr-x  4 root mysql  4096 Jun 29 21:12  man
-rw-r--r--  1 root root    943 Jun 29 21:18 my.cnf
-rw-r--r--  1 root root    943 Jun 29 21:23 my-new.cnf
drwxr-xr-x 10 root mysql  4096 Jun 29 21:12 mysql- test
-rw-r--r--  1 root mysql  2496 May 21 23:18 README
drwxr-xr-x  2 root mysql  4096 Jun 29 21:12 scripts
drwxr-xr-x 28 root mysql  4096 Jun 29 21:12 share
drwxr-xr-x  4 root mysql  4096 Jun 29 21:12 sql-bench
drwxr-xr-x  3 root mysql  4096 Jun 29 21:12 support-files
[root@web mysql] #
[root@web mysql] # cat my.cnf
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html
[mysqld]
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
# These are commonly set, remove the # and set as required.
# basedir = .....
# datadir = .....
# port = .....
# server_id = .....
# socket = .....
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[root@web mysql] #

大家可以看到生成的配置文件很简单,我们得添加一些内容!

(2).  修改配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
[root@web mysql] # vim my.cnf
添加内容是:
binlog- format =ROW
log-bin=master-bin.log
log-slave-updates= true
gtid-mode=on
enforce-gtid-consistency= true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync -master-info=1
slave-parallel-workers=2
binlog-checksum=CRC32
master-verify-checksum=1
slave-sql-verify-checksum=1
binlog-rows-query-log_events=1
server- id =1
report-port=3306
port=3306
datadir= /mydata/data
socket= /tmp/mysql .sock
report-host=master. test .com

5. 为mysql提供sysv服务脚本并启动服务

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
[root@web mysql] # cp support-files/mysql.server /etc/init.d/mysqld #复制sysv脚本
[root@web mysql] # chkconfig --add mysqld
[root@web mysql] # chkconfig mysqld on #开机自启动
[root@web mysql] # chkconfig mysqld --list
mysqld          0:off   1:off   2:on    3:on    4:on    5:on    6:off
[root@web mysql] # service mysqld start
Starting MySQL.... SUCCESS!
[root@web mysql] # netstat -ntulp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID /Program  name
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      990 /sshd 
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1066 /master
tcp        0      0 :::80                       :::*                        LISTEN      37120 /httpd
tcp        0      0 :::22                       :::*                        LISTEN      990 /sshd 
tcp        0      0 ::1:25                      :::*                        LISTEN      1066 /master
tcp        0      0 :::3306                     :::*                        LISTEN      37924 /mysqld         #mysql启动成功
udp        0      0 0.0.0.0:68                  0.0.0.0:*                               890 /dhclient

6. 输出mysql的man手册至man命令的查找路径

1
2
[root@web mysql] # vim /etc/man.config
MANPATH  /usr/local/mysql/man  #增加这一行

7. 输出mysql的头文件至系统头文件路径/usr/include

1
2
3
[root@web mysql] # ln -sv /usr/local/mysql/include/ /usr/include/mysql #输出mysql的头文件至系统头文件
` /usr/include/mysql ' -> `/usr/local/mysql/include/'
[root@web mysql] # cd /usr/include/mysql/

8. 输出mysql的库文件给系统库查找路径

1
2
3
4
5
6
7
8
9
10
[root@web mysql] # vim /etc/ld.so.conf.d/mysql.conf
/usr/local/mysql/lib  #直接新建编辑/etc/ld.so.conf.d/mysql.conf文件,把mysql的库文件路径添加进去就可以了
~            
[root@web mysql] # ldconfig –v# 让系统重新读取库文件
/usr/local/mysql/lib :
         libtcmalloc_minimal.so.0 -> libtcmalloc_minimal.so (changed)
         libmysqlclient.so.18 -> libmysqlclient_r.so.18.0.0
/usr/lib64/mysql :
         libmysqlclient.so.16 -> libmysqlclient.so.16.0.0
         libmysqlclient_r.so.16 -> libmysqlclient_r.so.16.0

9. 修改PATH环境变量,让系统可以直接使用mysql的相关命令

1
2
3
[root@web mysql] # vim /etc/profile.d/mysql.sh  #添加环境变量(与添加httpd是一样的)
export  PATH=$PATH: /usr/local/mysql/bin
[root@web mysql] # source /etc/profile #重新读取一下环境变量

10. 测试并连接mysql

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[root@web mysql] # mysql
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection  id  is 1
Server version: 5.6.12-log MySQL Community Server (GPL)
Copyright (c) 2000, 2013, 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> SHOW DATABASES;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
test                |
+--------------------+
4 rows  in  set  (0.02 sec)
mysql>

三、编译安装PHP

1. 编译安装php-5.4.16

说明:   
(1). 这里为了支持apache的worker或event这两个MPM,编译时使用了--enable-maintainer-zts选项。    
(2). 如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。 mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。    

1
2
3
4
# ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd
# make
# make test
# make intall


(1). 安装图片资源软件  

1
[root@web php-5.4.16] # yum -y install gd gd-devel  libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel

(2). 安装libxml(扩展标记语言)库

1
[root@web php-5.4.16] # yum -y  install libxml2 libxml2-devel

(3). 安装bzip2压缩库

1
[root@web php-5.4.16] # yum install -y bzip2 bzip2-devel

(4). 安装mcrypt加密库

1
2
3
4
5
6
7
8
9
[root@web src] # rpm -ivh libmcrypt-2.5.8-4.3.x86_64.rpm
warning: libmcrypt-2.5.8-4.3.x86_64.rpm: Header V3 DSA /SHA1  Signature, key ID 04b8b50a: NOKEY
Preparing...                 ########################################### [100%]
    1:libmcrypt               ########################################### [100%]
[root@web src] # rpm -ivh libmcrypt-devel-2.5.8-4.3.x86_64.rpm
warning: libmcrypt-devel-2.5.8-4.3.x86_64.rpm: Header V3 DSA /SHA1  Signature, key ID 04b8b50a: NOKEY
Preparing...                 ########################################### [100%]
    1:libmcrypt-devel         ########################################### [100%]
[root@web src] #

(5). 编译php 5.4.16

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
[root@web php-5.4.16] # tar -xf php-5.4.16.tar.gz
[root@web php-5.4.16] # cd php-5.4.16
[root@web php-5.4.16] # ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-gd --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  --enable-maintainer-zts
--with-mysql= /usr/local/mysql  :mysql相关
--with-openssl :让其能够支持openssl功能
--with-mysqli= /usr/local/mysql/bin/mysql_config  :mysql的另外一个接口,让mysql与php交互的接口;接口程序是mysql_config,是个二进制程序
-- enable -mbstring :多字节string,支持中文或者是非一个字节能够表示的语言
--with-gd : 支持gd库
--with-freetpye- dir :支持freetype功能,freetype:自由的可移植的字体库,可以实现去引用特定字体的
--with-jpeg- dir :支持jpeg图片
--with-png- dir :支持png图片
--with-zlib:互联网上常用的,通用格式的压缩库,让数据文件先压缩再传送给客户端
--with-libxml- dir :xml(扩展标记语言),现在的很多系统在实现数据交互的时候,都要基于xml来实现,所以要php支持xml,并且让其知道其库文件所在位置
-- enable -sockets:让php支持基于套接字的通信
--with-apxs2:基于apxs实现让php编译成apace模块
--with-mcrypt:支持加密功能的,额外的加密库
--with-config- file -path :php配置文件的路径放在了什么地方 主配置文件是php.ini
--with-config- file -scan :主配置文件的片段,也是配置文件,这个路径下以.ini结尾的都是配置文件片段
--with-bz2 :压缩库
-- enable -maintainer-zts :这一项的使用取决于apache是什么类型的,apache使用的是prefork就不需要;如果使用的是event或者是worker就要添加这一项;apache以线程工作就必须编译这一项
Generating files
configure: creating . /config .status
creating main /internal_functions .c
creating main /internal_functions_cli .c
+--------------------------------------------------------------------+
| License:                                                           |
| This software is subject to the PHP License, available  in  this     |
| distribution  in  the  file  LICENSE.  By continuing this installation |
| process, you are bound by the terms of this license agreement.     |
| If you  do  not agree with the terms of this license, you must abort |
| the installation process at this point.                            |
+--------------------------------------------------------------------+
Thank you  for  using PHP.
config.status: creating php5.spec
config.status: creating main /build-defs .h
config.status: creating scripts /phpize
config.status: creating scripts /man1/phpize .1
config.status: creating scripts /php-config
config.status: creating scripts /man1/php-config .1
config.status: creating sapi /cli/php .1
config.status: creating main /php_config .h
config.status: executing default commands
#编译完成
[root@web php-5.4.16] # make && make install
Installing PHP SAPI module:       apache2handler
/usr/local/apache/build/instdso .sh SH_LIBTOOL= '/usr/local/apr/build-1/libtool'  libphp5.la  /usr/local/apache/modules
/usr/local/apr/build-1/libtool  --mode= install  install  libphp5.la  /usr/local/apache/modules/
libtool:  install install  .libs /libphp5 .so  /usr/local/apache/modules/libphp5 .so
libtool:  install install  .libs /libphp5 .lai  /usr/local/apache/modules/libphp5 .la
libtool:  install : warning: remember to run `libtool --finish  /root/src/php-5 .4.16 /libs '
chmod  755  /usr/local/apache/modules/libphp5 .so
[activating module `php5'  in  /etc/httpd/httpd .conf]
Installing PHP CLI binary:         /usr/local/php/bin/
Installing PHP CLI  man  page:       /usr/local/php/php/man/man1/
Installing PHP CGI binary:         /usr/local/php/bin/
Installing build environment:      /usr/local/php/lib/php/build/
Installing header files:           /usr/local/php/include/php/
Installing helper programs:        /usr/local/php/bin/
   program: phpize
   program: php-config
Installing  man  pages:              /usr/local/php/php/man/man1/
   page: phpize.1
   page: php-config.1
Installing PEAR environment:       /usr/local/php/lib/php/
[PEAR] Archive_Tar    - installed: 1.3.11
[PEAR] Console_Getopt - installed: 1.3.1
warning: pear /PEAR  requires package  "pear/Structures_Graph"  (recommended version 1.0.4)
warning: pear /PEAR  requires package  "pear/XML_Util"  (recommended version 1.2.1)
[PEAR] PEAR           - installed: 1.9.4
Wrote PEAR system config  file  at:  /usr/local/php/etc/pear .conf
You may want to add:  /usr/local/php/lib/php  to your php.ini include_path
[PEAR] Structures_Graph- installed: 1.0.4
[PEAR] XML_Util       - installed: 1.2.1
/root/src/php-5 .4.16 /build/shtool  install  -c ext /phar/phar .phar  /usr/local/php/bin
ln  -s -f  /usr/local/php/bin/phar .phar  /usr/local/php/bin/phar
Installing PDO headers:           /usr/local/php/include/php/ext/pdo/
[root@web php-5.4.16] #

#安装完成

(6). 为php提供配置文件

查看配置文件

1
2
3
4
5
6
7
8
[root@web php-5.4.16] # ls | grep php.ini
php.ini-development
php.ini-production
[root@web php-5.4.16] #
php.ini-development :用于开发环境
php.ini-production :用于生产环境:把这项复制到 /etc/ 目录下重命名为php.ini即可;不需要启动服务,因为已经编译成apache模块了;是否启动服务要看工作模型,当做成fastcgi要启动服务
[root@web php-5.4.16] # cd php-5.4.16
[root@web php-5.4.16] # cp php.ini-production /etc/php.ini

(在编译的时候已经指定了配置文件的路径,所以php会自动到/etc/目录下去找其配置文件)

四、整合Apache与PHP

1. 编辑apache配置文件httpd.conf,以apache支持php

(1).  首先要在apache配置文件中定义,使apache能够处理php结尾的文件 ,全文查找AddType字段,添加一下内容

1
2
3
4
[root@web php-5.4.16] # vim /etc/httpd/httpd.conf
AddType application /x-httpd-php   .php
AddType application /x-httpd-php-source   .phps
PHPIniDir  "/usr/local/php"

(2). 定位至DirectoryIndex index.html修改为:   

1
DirectoryIndex  index.php  index.html


2. 重启apache并测试

1
2
3
4
[root@web php-5.4.16] # service httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@web php-5.4.16] #

3. 增加测试文件  

1
2
3
4
[root@web php-5.4.16]# vim /usr/local/apache/htdocs/test.php
<?
         phpinfo();
?>

4. 测试效果

效果2

5. 问题

在用PHP5.3以上的PHP版本时,只要是涉及时间的会报一个错!

执行phpinfo();时提示:

1
Warning: phpinfo(): It is not safe to rely on the system 's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function. In case you used any of those methods and you are still getting this warning, you most likely misspelled the timezone identifier. We selected the timezone ' UTC'  for  now, but please  set  date .timezone to  select  your timezone.  in  /usr/local/apache/htdocs/test .php on line 2

解决办法有三种:

(1). 在页头使用date_default_timezone_set()设置 date_default_timezone_set('PRC'); //东八时区 echo date('Y-m-d H:i:s');

1
2
3
4
5
[root@web php-5.4.16] # vim /usr/local/apache/htdocs/test.php
<?
         date_default_timezone_set( "PRC" );
         phpinfo();
?>

(2). 在页头使用 ini_set('date.timezone','Asia/Shanghai');

(3). 修改php.ini。打开php.ini查找date.timezone 去掉前面的分号修改成为:date.timezone ="PRC" PRC注意加上双引号,要不还会出错!

1
2
[root@web php-5.4.16] # vim /etc/php.ini
date .timezone =  "PRC"

五、安装Xcache加速器

1. 为php添加xcache功能

1
2
3
4
5
6
7
8
[root@web src] # tar -xf xcache-3.0.3.tar.gz
[root@web src] # cd xcache-3.0.3
[root@web xcache-3.0.3] # /usr/local/php/bin/phpize
Configuring  for :
PHP Api Version:         20100412
Zend Module Api No:      20100525
Zend Extension Api No:   220100525
[root@web xcache-3.0.3] #

2. 编译安装Xcache 3.0.3

1
2
3
4
5
[root@web xcache-3.0.3] # ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
[root@web xcache-3.0.3] # make && make install
编译完成,让php支持xcache功能前提要把xcache的配置信息添加到php的配置文件中
Installing shared extensions:      /usr/local/php/lib/php/extensions/no-debug-zts-20100525/
[root@web xcache-3.0.3] #

3. 编辑php.ini,整合php和xcache

1
2
3
4
5
6
7
8
9
10
11
[root@web xcache-3.0.3] # mkdir /etc/php.d
[root@web xcache-3.0.3] # cp xcache.ini /etc/php.d/ #也可以直接把xcache.ini配置信息直接追加到php.ini配置文件中
[root@web xcache-3.0.3] # ls /etc/php.d/
xcache.ini
[root@web xcache-3.0.3] # vim /etc/php.d/xcache.ini #
接下来编辑 /etc/php .d /xcache .ini,找到zend_extension开头的行,修改为如下行:
[xcache-common]
;; non-Windows example:
extension =  /usr/local/php/lib/php/extensions/no-debug-zts-20100525/xcache .so  #修改这一行
;; Windows example:
; extension = php_xcache.dll

4. 重启apache并测试

1
2
3
4
[root@web xcache-3.0.3] # service httpd restart
Stopping httpd:                                            [  OK  ]
Starting httpd:                                            [  OK  ]
[root@web xcache-3.0.3] #

效果3

说明:测试可以使用windows主机访问linux主机IP,查看php.info中是否有xcache模块相关信息

六、启用服务器状态

说明:

mod_status模块可以让管理员查看服务器的执行状态,它通过一个HTML页面展示了当前服务器的统计数据。这些数据通常包括但不限于:   
(1) 处于工作状态的worker进程数;    
(2) 空闲状态的worker进程数;    
(3) 每个worker的状态,包括此worker已经响应的请求数,及由此worker发送的内容的字节数;    
(4) 当前服务器总共发送的字节数;    
(5) 服务器自上次启动或重启以来至当前的时长;    
(6) 平均每秒钟响应的请求数、平均每秒钟发送的字节数、平均每个请求所请求内容的字节数;

启用状态页面的方法很简单,只需要在主配置文件中添加如下内容即可:

1
2
3
4
5
[root@web xcache-3.0.3] # vim /etc/httpd/httpd.conf
<Location  /server-status >
     SetHandler server-status
     Require all granted
< /Location >

需要提醒的是,这里的状态信息不应该被所有人随意访问,因此,应该限制仅允许某些特定地址的客户端查看。比如使用Require ip 172.16.0.0/16来限制仅允许指定网段的主机查看此页面 。

效果图:

效果4

七、PHP连接Mysql测试

(1). 编辑apache的默认页面/usr/local/apache/htdocs/test.php

1
2
3
4
5
6
7
8
[root@web xcache-3.0.3] # vim /usr/local/apache/htdocs/test.php
<?
         $conn=mysql_connect( 'localhost' , 'root' , '' );
         if  ($conn)
                 echo  "Success" ;
         else
                 echo  "Failure" ;
?>

(2). 测试

效果5

连接成功!

八、安装Discuz论坛(Discuz_X3.0_SC_GBK最新版)

(1). 授权主机对mysql的访问

1
2
3
4
mysql> GRANT ALL PRIVILEGES ON *.* TO  'root' @ '192.168.%.%'  IDENTIFIED BY  '123456' ;
Query OK, 0 rows affected (0.03 sec)
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.02 sec)

(2). 准备Discuz 3.0

1
2
[root@web src] # unzip Discuz_X3.0_SC_GBK.zip
[root@web src] # mv upload/* /usr/local/apache/htdocs/

(3). 安装

1

(4).  修改权限

2

1
2
[root@web htdocs] # chmod 777 ./data ./config/ ./data/cache/ ./data/avatar/ ./data/plugindata/ ./data/download/ ./data/addonmd5/ ./data/template/ ./ data/threadcache/ ./data/attachment/ ./data/attachment/album/ ./data/attachment/forum/ ./data/attachment/group/ ./data/log/ ./uc_client/data/cache/ ./uc_server/data ./uc_server/data/avatar/ ./uc_server/data/backup/ ./uc_server/data/logs/ ./uc_server/data/tmp/ ./uc_server/data/view/ ./uc_server/data/cache/
[root@web htdocs] #

修改后效果如下:

image

(5). 选择全新安装

4

(6). 配置数据库文件

5

(7). 安装完成

6

(8). 最终效果

7

所有演示全部完成 !




本文转自 dengaosky 51CTO博客,原文链接:http://blog.51cto.com/dengaosky/1855403,如需转载请自行联系原作者
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
7天前
|
存储 分布式计算 Hadoop
Centos7.9安装kerberos
Centos7.9安装kerberos
56 25
|
2天前
|
存储 Shell 网络安全
Centos7.9安装openldap
Centos7.9安装openldap
39 16
|
4天前
|
数据可视化 Linux 应用服务中间件
Centos7.9安装phpldapadmin
Centos7.9安装phpldapadmin
36 15
|
14天前
|
安全 关系型数据库 MySQL
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
94 16
|
7天前
|
网络协议 Java 应用服务中间件
centos7环境下tomcat8的安装与配置
本文介绍了在Linux环境下安装和配置Tomcat 8的详细步骤。首先,通过无网络条件下的文件交互软件(如Xftp 6或MobaXterm)下载并解压Tomcat安装包至指定路径,启动Tomcat服务并测试访问。接着,修改Tomcat端口号以避免冲突,并部署Java Web应用项目至Tomcat服务器。最后,调整Linux防火墙规则,确保外部可以正常访问部署的应用。关键步骤包括关闭或配置防火墙、添加必要的端口规则,确保Tomcat服务稳定运行。
|
1月前
|
存储 关系型数据库 MySQL
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####
|
1月前
|
SQL 关系型数据库 MySQL
PHP与MySQL的高效交互:从基础到实践####
本文深入探讨了PHP与MySQL数据库之间的高效交互技术,涵盖了从基础连接到高级查询优化的全过程。不同于传统的摘要概述,这里我们直接以一段精简代码示例作为引子,展示如何在PHP中实现与MySQL的快速连接与简单查询,随后文章将围绕这一核心,逐步展开详细讲解,旨在为读者提供一个从入门到精通的实战指南。 ```php <?php // 数据库配置信息 $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "test_db"; // 创建连接 $conn = new mysqli($se
46 0
|
4天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
54 0
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
61 3
|
1月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
78 3