Cent OS 6.6 下安装mysql(5.5.20)和 PHP(5.3.10)
0.准备步骤(没有连接网络的 linux):
挂载光盘、让网络 yum 源失效、修改光盘 yum 文件、安装 c 语言编译器 gcc。
1.MySQL(5.5.20)
下载 mysql 5.5.20 源码包(由于mysql 官网使用 google cdn 的 jquery 来切换mysql 版本下载的下拉菜单,所以墙内无法获取linux 版本的mysql,这里在 51cto 上下载了一个源码包)
把源码包 mysql-5.5.20.tar.gz 放到 /root 目录下
① 增加组和用户
首先查看是否有mysql 用户:
id mysql
如果没有,增加组和用户:
groupadd mysql
useradd -g mysql mysql
查看用户
id mysql
此时应该会有mysql 用户

② 解压缩
tar -zxvf mysql-5.5..tar.gz
安装完之后可以查看 mysql 解压以后的大小
du -sh mysql-5.5.
显示 205M
③ 进入 mysql -5.5.20 目录(编译和编译安装都需要在源码包解压后的目录中进行)
cd mysql-5.5.
④ 定义安装位置
先创建 /usr/local/mysql
mkdir /usr/local/mysql
然后软件配置与检查,定义安装位置
注意:这一步 mysql 5.5(以上) 的版本源码安装使用 cmake 代替原来的 configure 命令。

先安装 cmake:
yum -y install cmake
运行 cmake
(此步可以参考mysql 官方网站:2.9 Installing MySQL from Source ---- 2.9.2 Installing MySQL Using a Standard Source Distribution )
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \
-DWITH_MYISAM_STORAGE_ENGINE= \
-DWITH_INNOBASE_STORAGE_ENGINE= \
-DWITH_MEMORY_STORAGE_ENGINE= \
-DWITH_READLINE= \
-DENABLED_LOCAL_INFILE= \
-DMYSQL_DATADIR=/data/mysql/mysql -DMYSQL_USER=mysql
或者
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk -DWITH_MYISAM_STORAGE_ENGINE= -DWITH_INNOBASE_STORAGE_ENGINE= -DWITH_MEMORY_STORAGE_ENGINE= -DWITH_READLINE= -DENABLED_LOCAL_INFILE= -DMYSQL_DATADIR=/data/mysql/mysql -DMYSQL_USER=mysql
安装过程中可能会报错,比如:
报错1:
CMake Error at /usr/share/cmake/Modules/CMakeCXXInformation.cmake: (get_filename_component):
get_filename_component called with incorrect number of arguments
Call Stack (most recent call first):
CMakeLists.txt: (PROJECT)
CMake Error: CMAKE_CXX_COMPILER not set, after EnableLanguage
CMake Error: Internal CMake error, TryCompile configure of cmake failed
解决方法:安装 gcc-c++
yum -y install gcc-c++
报错2:
CMake Error at cmake/readline.cmake: (MESSAGE):
Curses library not found. Please install appropriate package, remove CMakeCache.txt and rerun cmake.On Debian/Ubuntu, package name is libncurses5-dev, on Redhat and derivates it is ncurses-devel.
解决方法:
a.安装 ncurses-devel
yum -y install ncurses-devel
b.删除CMakeCache.txt
rm CMakeCache.txt
⑤ make && make install
make && make install
过程比较漫长。
安装完成之后,查看 /usr/local/mysql
ls /usr/local/mysql

⑥ 改变/usr/local/mysql 目录的权限

把 mysql 文件夹的所有者改为mysql 组的用户 mysql
cd /usr/local
chown -R mysql:mysql mysql

⑦ 设置开机启动
cd /root/mysql-5.5.
cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
ll /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on
此时就可以使用 servers mysqld start 来启动 mysql
⑧ 初始化 mysql 的默认的数据库
/usr/local/mysql/scripts/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql --datadir=/data/mysql/ --user=mysql
⑨ 启动 mysql
service mysqld start

解决方法:
cp cp /root/mysql-5.5.20/support-files/my-medium.cnf /etc/my.cnf
y 覆盖
vim /etc/my.cnf
插入 datadir = /usr/local/mysql/data

再插入:
log-error = /usr/local/mysql/data/error.log
pid-file = /usr/local/mysql/data/mysql.pid
user = mysql
tmpdir = /tmp

保存。
如果还是不行的话,参考 http://houzhiqingjava.blog.163.com/blog/static/1673995072014395417615/
[root@localhost ~]# cd /usr/local/mysql
[root@localhost mysql]# chown -R mysql.mysql .
[root@localhost mysql]# su - mysql
[mysql@localhost ~]$ cd /usr/local/mysql
[mysql@localhost mysql]$ scripts/mysql_install_db
Installing MySQL system tables...
OK
Filling help tables...
OK
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 localhost.localdomain 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!
[mysql@localhost mysql]$ /usr/local/mysql/bin/mysqld_safe --user=mysql &
[]
[mysql@localhost mysql]$ :: mysqld_safe Logging to '/usr/local/mysql/data/localhost.localdomain.err'.
:: mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data
敲回车,再次启动 mysql
service mysqld start

错误原因是:没有初始化权限表。
⑩ 登录 mysql
如果报错:

原因:mysql命令的路径在 /usr/local/mysql/bin 下,所以你直接使用mysql命令时,无法查到该命令
解决方法:在/usr/bin 下做一个软链接,指向真实的命令
ln -s /usr/local/mysql/bin/mysql /usr/bin

测试:
select host,user,password from mysql.user;

给root 设置密码 123456
/usr/local/mysql/bin/mysqladmin -uroot -p password ''

使用 \s 查看数据库信息

停止mysql:
service mysqld stop
重启mysql:
service mysqld restart
2.PHP 5.3.10
① 准备工作(可以参考CentOS 6.3下源码安装LAMP(Linux+Apache+Mysql+Php)环境)
a. 安装 libxml2 2.2.26(php 处理 xml 文档)
把 libxml2.tar.gz 复制到 /root 目录下
tar -zxvf libxml2-2.2..tar.gz
cd libxml2-2.2.
./configure --prefix=/usr/local/libxml2
make && make install
b.安装 jpeg6
把 jpegsrc.v6b.tar.gz 复制到 /root 目录下
解压:
tar -zxvf jpeg6.v6b.tar.gz
#手动建立以下目录 mkdir -p /usr/local/jpeg6
mkdir -p /usr/local/jpeg6/bin
mkdir -p /usr/local/jpeg6/lib
mkdir -p /usr/local/jpeg6/include
mkdir -p /usr/local/jpeg6/man
mkdir -p /usr/local/jpeg6/man1
mkdir -p /usr/local/jpeg6/man/man1 cd jpeg-6b
./configure --prefix=/usr/local/jpeg6 --enable-shared --enable-static
make && make install
c.安装 zlib-1.2.5.1
把zlib-1.2.5.1.tar.gz 复制到 /root 下
tar -zxvf zlib-1.2.5.1
cd zlib.1.2.5.1
./configure #不指定任何目录
make && make install
d.安装 libpng 1.2.31
把libpng-1.2.31.tar.gz 复制到 /root 下
tar -zxvf libpng-1.2..tar.gz
cd libpng-1.2.31
./configure #和zlib 一样不要带参数,让它默认安装到相应目录 make && make install
e. 安装 freetype 2.4.11 字体库
把 freetype-2.4.11.tar.gz 复制到 /root 下
tar -zxvf freetype-2.4..tar.gz
cd freetype-2.4.
mkdir -p /usr/local/freetype
./configure --prefix=/usr/local/freetype
make && make install
f.安装 gd 2.0.35 图形库
把 gd-2.0.35.tar.gz 复制到 /root
tar -zxvf gd-2.0..tar.gz
mkdir -p /usr/local/gd
cd gd-2.0.
./configure --prefix=/usr/local/gd \
--with-jpeg=/usr/local/jpeg6 \
--with-png --with-zlib \
--with-freetype=/usr/local/freetype
make && make install
ok,准备工作完成,该装php 了。
把 php-5.3.10.tar.gz 复制到 /root 下
② 解压:
tar -zxvf php-5.3.10
cd php-5.3.10
解压之后大小 127 M
③ 软件配置与检查,定义安装位置
./configure --prefix=/usr/local/php \
--with-apxs2=/usr/local/apache2/bin/apxs \
--with-mysql=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-mysqli=mysqlnd \
--with-freetype-dir=/usr/local/freetype \
--with-gd=/usr/local/gd \
--with-zlib --with-libxml-dir=/usr/local/libxml2 \
--with-jpeg-dir=/usr/local/jpeg6 \
--with-png-dir \
--enable-mbstring=all \
--enable-mbregex \
--enable-shared

④ 编译 并且 安装
make && make install
过程很漫长。
⑤ 复制一份 php.ini 文件
使用:
ls |gerp ini
查看跟php.ini 有关的信息
然后copy:
cp php.ini-development /usr/local/php/lib/php.ini
或者 复制 php.ini-production (生产环境)
⑥ 整合 apache 和 php
进入apache 的安装目录
cd /usr/local/apache2
编辑:
vi conf/httpd.conf
使用 /php 查找和 php 相关的信息。
使用:set nu 显示行数。
166 行
<ifModule dir_modle>
DirectoryIndex index.html
</ifModule>
在 index.html 前加上 index.php
使用 /AddType
310 行添加:
AddType application/x-httpd-php .php
保存。
重启 apache
bin/apachectl restart
进入:
cd htdocs/
编辑:
vi index.php
输入:
<?php
phpinfo();
保存。
重启apache
/usr/local/apache2/bin/apachectl restart
在浏览器中输入 192.168.254.100

设置时区:
vi /usr/local/php/lib/php.ini
1008 行
data.timezone = PRC
重启 apache。
php 安装配置完成。
网站文件放在 /usr/local/apache2/htdocs ,目录下
新建虚拟主机:
cd /usr/local/apache2/conf
vi httpd.conf
搜索 vhosts
大约 389 行
把Virtual hosts 下面一行的 # 去掉
保存。
然后
vi extra/httpd-vhosts.conf
虚拟主机部分修改成:

重启apache。
修改本地主机的hosts,加入
192.168.254.100 test.com
在浏览器中输入 test.com,就可以浏览网站了。
参考:
linux下Apache+PHP+mysql+phpMyAdmin源码包安装配置(Ubuntu)
使用cmake方式安装mysql-5.5.10(mysql cmake)
CentOS 6.2 源码安装MySQL5.5.11(解决mysql cmake 报错)
MySQL: Starting MySQL….. ERROR! The server quit without updating PID file解决办法( 解决mysql 无法启动)
CentOS 6.3下源码安装LAMP(Linux+Apache+Mysql+Php)环境
CentOs5.5+mysql+nginx+php5.3.3安全安装手册
Cent OS 6.6 下安装mysql(5.5.20)和 PHP(5.3.10)的更多相关文章
- (静默安装)Cent OS 6_5(x86_64)下安装Oracle 11g
Cent OS 6_5(x86_64)下安装Oracle 11g 1 硬件要求 1.1 内存 & swap 物理内存不少于1G 硬盘可以空间不少于5G swap分区空间不少于2G Mini ...
- Cent OS 6.5下安装gcc-5.3.0
目录: .下载源码包 .安装以前版本的GCC编译器 .文件传输 .熟悉解压命令 .安装流程 .开始安装 .安装必备包之GMP,MPFR,MPC的安装 .继续安装 [1.下载源码包] ...
- redhat下安装mysql 5.6.20,解压zip包,查看已经安装过的mysql,卸载rpm安装包,安装mysqlserver端和client,改动mysqlusername,登陆mysql,启动关闭mysql
1 将相关的mysql rpm包上传到redhat上 2 我的电脑是Redhat 6.*版本号.所以这里使用上面一个 3 解压zip包 4 安装下面几个rpm MySQL-client-a ...
- Cent OS 6.4下安装JDK1.6
步骤1:查看Linux自带的JDK是否已安装 (卸载CentOS已安装的JDK) 安装好的CentOS会自带OpenJDK,用命令"java -version"查看,会有下面的信 ...
- 在Mac OS环境下安装MySQL服务
在Mac OS环境下安装MySQL服务 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我之前介绍过window环境下安装mysql服务,以及在Linux环境下安装mysql服务,今 ...
- Linux下安装mysql(2) 及常见问题解决(CentOS)
上一篇讲了基本的安装,这篇姑且算作进阶吧 链接Linux下安装mysql(1) 1.准备好mysql的rpm安装包 2.解压并进入usr/local/mysql 3.先执行useradd mysql( ...
- 在Mac下安装MySQL
在Mac下安装MySQL 最近开始将开发工具都转移到 Mac 上了,其中也会莫名其妙的遇到一些坑,不如干脆将整个流程都记录下来,方便以后查找. 下载与安装 首先进入 MySQL 官网,选择免费的C ...
- Linux下安装 MySQL
Ubuntu环境 使用二进制安装包安装,相对简单绿色 1.到官网下载二进制压缩包http://dev.mysql.com/downloads/mysql/ 2.选择需要的版本 目前最新为5.7.之后选 ...
- Ubuntu 下安装 Mysql
这里讲用Ubuntu下安装MySql ubuntu上安装mysql非常简单只需要几条命令就可以完成. 1. sudo apt-get install mysql-server 2. apt-get ...
随机推荐
- .net学习之集合、foreach原理、Hashtable、Path类、File类、Directory类、文件流FileStream类、压缩流GZipStream、拷贝大文件、序列化和反序列化
1.集合(1)ArrayList内部存储数据的是一个object数组,创建这个类的对象的时候,这个对象里的数组的长度为0(2)调用Add方法加元素的时候,如果第一次增加元神,就会将数组的长度变为4往里 ...
- 使用jQuery简单实现产品展示的图片左右滚动功能
今天要做一个产品展示功能,由于产品比较多,一屏展示不完,所以想要做一个通过点击进行翻页的效果,在网上找了几个都不大好用,最后只能自己动手写了. 效果如下所示: 原理比较简单:将要滚动显示的区域的CSS ...
- hdu 1465:不容易系列之一(递推入门题)
不容易系列之一 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- 实例讲解虚拟机3种网络模式(桥接、nat、Host-only)
转自:http://www.cnblogs.com/ggjucheng/archive/2012/08/19/2646007.html 前言 很多人安装虚拟机的时候,经常遇到不能上网的问题,而vmwa ...
- NDK编译生成so文件
1 首先加载项目
- 【maven 报错】maven项目update之后报错One or more constraints have not been satisfied.
在右键项目Update Project之后报错:One or more constraints have not been satisfied.Spring 4.1 requires Java 1.6 ...
- haohantechsoft-PDA软件,PDA管理软件,PDA管理系统,仓库PDA销售开单盘点软件
为了更好服务于广大服装客户群体进行销售.盘点.调拨配送等.推出基于无线网络版移动PDA销售开单盘点软件系统.该系统支持无线3G.WIFI.GPRS系统,用户可以手持PDA在无线网络连接状态下进行销售. ...
- 10686 DeathGod不知道的事情
Description 蚂蚁是很强大的动物,除了DeathGod知道的事情外还有很多不知道的!例如… 根据某种理论,时间方向上有无数个平行世界,有的世界蚂蚁很多,有的世界蚂蚁很少,有的世界蚂蚁会繁殖, ...
- 最短路(Bellman_Ford) POJ 3259 Wormholes
题目传送门 /* 题意:一张有双方向连通和单方向连通的图,单方向的是负权值,问是否能回到过去(权值和为负) Bellman_Ford:循环n-1次松弛操作,再判断是否存在负权回路(因为如果有会一直减下 ...
- cocos2d 定时器
//获取当前系统的语言 LanguageType language=CCApplication::sharedApplication()->getCurrentLanguage(); //每一帧 ...