ubuntu16.04编译安装mysql-boost-5.7.21并编译成php扩展测试与使用
我之前的文章已经改造了自定义MVC框架中的工具类(验证码,图片上传,图像处理,分页)4个类,接下来,就要改造模型类,模型类肯定要连接数据库,由于我的Ubuntu Linux是裸装的php(目前只编译了一个gd扩展),所以需要编译安装mysql,并把它编译成扩展,这里,我选用5.7版本带boost的源码包。搞了一个晚上,一边实施,一边做笔记。。。配置太多。
一、需要准备的库
1,cmake编译器
sudo apt-get install cmake
2,bison( Linux下C/C++语法分析器 )
sudo apt-get install bison
3,ncurses库,如果你有学过Linux系统编程游戏开发,可能听过或者使用这个库
sudo apt-get install libncurses5-dev
4,gcc编译器,ubuntu16.04自带
5,Boost 1.59.0,这个库下载下来之后,要编译,安装
wget https://sourceforge.net/projects/boost/files/boost/1.59.0/boost_1_59_0.tar.gz
tar -zxvf boost_1_59_0.tar.gz -C /usr/local/
>进入解压后的源码目录
cd /usr/local
cd boost_1_59_0/
如果切换不进boost_1_59_0这个目录,自己记得修改用户和组以及权限【sudo chmod 755 boost_1_59_0/】
>然后运行bootstrap.sh脚本并设置相关参数
./bootstrap.sh --with-libraries=all --with-toolset=gcc
--with-libraries指定编译哪些boost库,all的话就是全部编译
--with-toolset指定编译时使用哪种编译器
>编译安装boost
./b2 //编译boost
sudo ./b2 install //将生成的库安装到/usr/local/lib目录下面,默认的头文件在/usr/local/include/boost目录下边。
>判断boost库是否安装成功
ghostwu@ghostwu:~/php/test$ cat boost_test.c
#include <string>
#include <iostream>
#include <boost/version.hpp>
#include <boost/timer.hpp>
using namespace std;
int main()
{
boost::timer t;
cout << "max timespan: " << t.elapsed_max() / << "h" << endl;
cout << "min timespan: " << t.elapsed_min() << "s" << endl;
cout << "now time elapsed: " << t.elapsed() << "s" << endl;
cout << "boost version" << BOOST_VERSION <<endl;
cout << "boost lib version" << BOOST_LIB_VERSION <<endl;
return ;
}
编译&执行:
ghostwu@ghostwu:~/php/test$ g++ boost_test.c -o boost_test
ghostwu@ghostwu:~/php/test$ ./boost_test
max timespan: .56205e+09h
min timespan: 1e-06s
now time elapsed: .7e-05s
boost version105900
boost lib version1_59
显示boost版本1.59
二、准备工作已经就绪,接下来开始编译安装mysql
1、添加Mysql用户
groupadd mysql
useradd -r -g mysql mysql
2、创建Mysql安装程序的目录和数据文件的目录 以及修改目录的用户和组
sudo mkdir /usr/local/mysql57 sudo mkdir ~/mysql57_data
chown -R mysql.mysql ~/mysql57_data/ sudo chown -R mysql.mysql /usr/local/mysql57/
3,配置mysql
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql57 \
-DMYSQL_DATADIR=/home/ghostwu/mysql57_data \
-DWITH_BOOST=/usr/local/boost_1_59_0 \
-DSYSCONFDIR=/etc \
-DEXTRA_CHARSETS=all
用cmake配置mysql预编译参数:
-DCMAKE_INSTALL_PREFIX:安装路径
-DMYSQL_DATADIR:数据存放目录
-DWITH_BOOST:boost源码路径
-DSYSCONFDIR:my.cnf配置文件目录
-DEFAULT_CHARSET:数据库默认字符编码
-DDEFAULT_COLLATION:默认排序规则
-DENABLED_LOCAL_INFILE:允许从本文件导入数据
-DEXTRA_CHARSETS:安装所有字符集
更多预编译配置参数请参考mysql官方文档说明:http://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html#cmake-general-options
>make && sudo make install
>初始化数据库
sudo ./bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql57 --datadir=/home/ghostwu/mysql57_data
临时密码:
cat ~/.mysql_secret
拷贝服务启动文件
sudo cp support-files/mysql.server /etc/init.d/mysqld
/etc目录下创建my.cnf
[client]
port=3306
socket=/var/run/mysqld/mysqld.sock
[mysqld]
port=3306
socket=/var/run/mysqld/mysqld.sock
pid-file=/home/ghostwu/mysql57_data/mysql.pid
basedir=/usr/local/mysql57
datadir=/home/ghostwu/mysql57_data
sudo mkdir -p /var/run/mysqld
sudo chown mysql:mysql /var/run/mysqld
启动服务
/etc/init.d/mysqld start|stop|restart
三、如果临时密码太复杂登录不进去,怎么办?重新修改密码
>先关闭mysql服务
/etc/init.d/mysqld stop
>把路径切入到/usr/local/mysql57/bin,执行
mysqld_safe --skip-grant-tables &
>mysql -p连接,用空密码连接
然后更新密码:
>update mysql.user set authentication_string=password('abc123') where user='root' and Host = 'localhost';
新版的mysql数据库下的user表中已经没有Password字段了,而是将加密后的用户密码存储于authentication_string字段
>flush privileges;
>quit
然后重启服务器,就可以用abc123这个密码登录了
四、把mysql编译为php的扩展
没有mysql扩展的时候,php调用mysql_connect报错,同时 用 -m参数 也找不到mysql扩展
ghostwu@ghostwu:~/php/senior_php$ /usr/local/php54/bin/php -f db.php
PHP Fatal error: Call to undefined function mysql_connect() in /home/ghostwu/php/senior_php/db.php on line
ghostwu@ghostwu:~/php/senior_php$ /usr/local/php54/bin/php -m | grep mysql
ghostwu@ghostwu:~/php/senior_php$ cat db.php
<?php
$link = mysql_connect( "localhost", "root", "abc123" );
var_dump( $link );
?>
ghostwu@ghostwu:~/php/senior_php$
扩展安装步骤:
/usr/local/php54/bin/phpize
./configure --with-php-config=/usr/local/php54/bin/php-config --with-mysql=/usr/local/mysql57
make
sudo make install
然后在/usr/local/php54/lib/php.ini中启用mysql.so扩展: extension=mysql.so
再次执行php(db.php)文件,如果出现下面这个错误:
PHP Warning: mysql_connect(): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) in /home/ghostwu/php/senior_php/db.php on line 2
请在php.ini文件下面这个配置中,告诉php mysql的socket文件路径
ghostwu@ghostwu:~/php/senior_php$ cat /usr/local/php54/lib/php.ini | grep mysql.default_socket
pdo_mysql.default_socket=
mysql.default_socket = /var/run/mysqld/mysqld.sock
最后执行数据库连接成功:
ghostwu@ghostwu:~/php/senior_php$ /usr/local/php54/bin/php -f db.php
resource() of type (mysql link)
各种参考文章:
http://www.jb51.net/article/101767.htm
https://www.cnblogs.com/Lam7/p/6090989.html
http://blog.csdn.net/upHailin/article/details/69264389?locationNum=11&fps=1
http://blog.csdn.net/u011573853/article/details/52682256
https://www.cnblogs.com/forest-wow/p/6642025.html
总结:
很重要的一项技能: 看日志,看日志,掌握调试方法, 我的mysql好几次启动不了,全部靠错误日志,找到问题所在!!!
ubuntu16.04编译安装mysql-boost-5.7.21并编译成php扩展测试与使用的更多相关文章
- Ubuntu16.04下安装mysql
系统信息 (lsb_release -a) Distributor ID: Ubuntu Description: Ubuntu 16.04.2 LTS Release: 16.04 Codename ...
- ubuntu16.04下安装mysql详细步骤
1.如果要搭建服务器先去购买一个云主机,比如阿里云.京东云.新网等等都有卖.这里推荐使用京东云服务器,因为最近在搞活动.一元可体验两个月(可能现在活动已经过了,但在京东云里有免费领一个月的,学生机也有 ...
- ubuntu16.04下安装mysql,并开启远程访问
一.安装 apt-get install mysql-server 二.本地连接 mysql默认开启了本地连接 直接通过mysql -uuser -p,然后输入密码访问 三.开启远程访问 3.1.创建 ...
- 图解在Ubuntu16.04中安装MySQL
1.安装mysql-server sudo apt-get install mysql-server 输入y,回车.等待下载,安装 出现下图,需要设定Mysql的密码. 输入密码,回车,弹出确认对话框 ...
- Shell脚本一键部署——源码编译安装MySQL及自动补全工具
Shell脚本一键部署--源码编译安装MySQL及自动补全工具 编译安装MySQL 1.软件包 Mysql安装包 将安装包拖至/opt目录下,编辑一个脚本文件,将以下内容复制进去,然后source或者 ...
- CentOS 6.6 下源码编译安装MySQL 5.7.5
版权声明:转自:http://www.linuxidc.com/Linux/2015-08/121667.htm 说明:CentOS 6.6 下源码编译安装MySQL 5.7.5 1. 安装相关工具# ...
- Linux 环境编译安装mysql (源码安装包)
标注: Linux需要先配置网络yum源,确定yum能在线安装软件包,方便测试过程中安装部分依赖包.配置163网易提示的网络yum源参考博客 http://www.cnblogs.com/zoulo ...
- Linux(CentOS6.5)下编译安装MySQL Community Server 5.7.12
组件 官方网站 直接下载地址 备注 mysql http://dev.mysql.com/downloads/mysql/ http://mirrors.sohu.com/mysql/MySQL- ...
- ubuntu16.04下安装artoolkit5
目前对AR技术的常见理解就是CV(Computer Vision)+CG(Computer Graphic).CV的方法很多,简单些比如FREAK+ICP(ARToolKit中的NFT),复杂些就是S ...
随机推荐
- 关于富文本在Android中的应用以及遇到的坑
富文本可以为用户提供更加多样化的文本展示形式,但由于其使用了H5标签的特殊性,一般都需要第三方框架的支持.这里推荐一款合适的第三方富文本框架,richeditor. 首先我们要使用该功能需要引入相关j ...
- php 利用Gd库添加文字水印乱码的问题及解决方案
最近一个项目进行了服务器迁移,部署后发现 ,其中一个为图片添加水印文字的功能出现了乱码问题,确认功能代码不存在问题,同时项目代码都是使用UTF-8编码,不存在编码问题,也检查排除了字体文件出现问题的可 ...
- JAVA中正则表达式常用的四个方法
JAVA中正则表达式处理字符串的四个常用方法:匹配.分割.替换.截取.其跟字符串的常用函数相似,但是使用正则表达式会更简单.更加简洁.下面是具体的例子: public class TestRegex ...
- Markdown中使用mermaid画流程图
Markown语法简单,用来写文档是个不错的选择. 但是Markdown 语法并不直接支持画图,当然方法还是有的. 本人用的Markdown编辑器为vscode,在里面直接安装merdaid插件即可使 ...
- python-networkx学习(1)
介绍: networkx是python的一个库,它为图的数据结构提供算法.生成器以及画图工具.近日在使用ryu进行最短路径获取,可以通过该库来简化工作量.该库采用函数方式进行调用相应的api,其参数类 ...
- awk完全手册
awk简介 2. awk命令格式和选项 2.1. awk的语法有两种形式 2.2. 命令选项3. 模式和操作 3.1. 模式 3.2. 操作4. awk的环境变量 5. awk运算符 6. 记录和域 ...
- 【转】CentOS 6.3(x86_64)下安装Oracle 10g R2
目 录 一.硬件要求二.软件三.系统安装注意四.安装Oracle前的系统准备工作五.安装Oracle,并进行相关设置六.升级Oracle到patchset 10.2.0.4七.使用rlwrap调用sq ...
- 【sed & awk 第二版笔记】以州和人名排列_P38
[root@nhserver1 02]# cat listJohn Daggett, 341 King Road, Plymouth MAAlice Ford, 22 East Broadday, R ...
- js 判断一个文本框是否获得焦点
1.js 判断一个文本框是否获得焦点 // 可以用document.activeElement判断 // document.activeElement表示当前活动的元素 // 查找你要判断的文本框 ...
- squid安装及运行指南
squid安装及运行指南 0. What is squid Squid是一个高性能的代理缓存服务器,Squid支持FTP.gopher.HTTPS和HTTP协议.和一般的代理缓存软件不同,Squid用 ...