MySQL学习之路 一 : MySQL 5.7.19 源码安装
MySQL 5.7.19 源码安装
- 查看系统:
# cat /etc/redhat-release
CentOS Linux release 7.3.1611 (Core) - 安装依赖包
# yum -y install ncurses-devel libaio-devel cmake gcc gcc-c++ bison perl-Time-HiRes
- 下载安装boost 下载, 解压 mysql
- 下载包
# wget http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
解压
# tar xf boost_1_59_0.tar.gz
将boost 的包放到 /usr/local/boost 下
# mv boost_1_59_0 /usr/local/boost
- 创建 mysql 账号
# useradd -s /sbin/nologin -M mysql 验证
# id mysql
- 下载包
- 安装 mysql
- 下载, 解压 MYsql 源码包
# mkdir /root/tools
# cd /root/tools
# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.19.tar.gz
# wget : 下载 MySQL 5.7.19 源码包
# tar xf mysql-5.7.19.tar.gz - cmake 解压与设置 msyql
cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.7.19 \
-DMYSQL_DATADIR=/application/mysql-5.7.19/data \
-DMYSQL_UNIX_ADDR=/application/mysql-5.7.19/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITH_ZLIB=bundled \
-DWITH_SSL=bundled \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DENABLE_DOWNLOADS=1 \
-DWITH_DEBUG=0 \
-DWITH_BOOST=/usr/local/boost/ 编译安装
# grep processor /proc/cpuinfo|wc -l # 查看本机 CPU 虚拟核数
# make -j 6 && make install
-j : 使用 6个CPU线程进行编译解压, 越多编译快,
测试结果 只用 1 CPU 编译 1个多小时, 使用6 个后 不到10分钟
- 下载, 解压 MYsql 源码包
- 配置mysql
- 设置软连接
# ln -s /application/mysql-5.7.19/ /application/mysql
修改配置文件
# cat /etc/my.cnf
# mysql config file
[mysqld]
# datadir=/application/mysql/data
# socket=/application/mysql/tmp/mysql.sock
# skip-grant-tables
symbolic-links=0 [mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/application/mysql/mysqld.pid
- 设置软连接
初始化数据库
创建目录 /application/mysql-5.7.19/tmp 存放 mysql.sock
# mkdir /application/mysql-5.7.19/tmp
将 /application/ 下的所有文件 用户付给 mysql 用户
# chown -R mysql.mysql /application/mysql*
设置环境变量
# echo 'PATH=$PATH:/application/mysql/bin/' >>/etc/profile
# source /etc/profile配置启动文件
# cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld
初始化数据库
# mysqld --initialize-insecure --user=mysql --basedir=/application/mysql/ --datadir=/application/mysql/data
- 启动 mysql
- 启动
# /etc/init.d/mysqld start
# netstat -lntup |grep 330 设置开启启动
# chkconfig mysqld on
# chkconfig mysqld --list
- 启动
CMAKE 选项解释
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql //MySQL安装的根目录
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock //指定mysql.sock位置
-DMYSQL_DATADIR=/data //MySQL数据库文件存放目录
-DSYSCONFDIR=/etc //MySQL配置文件所在目录
-DWITH_MYISAM_STORAGE_ENGINE=1 //添加MYISAM引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 //添加InnoDB引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 //添加ARCHIVE引擎
-DWITH_FEDERATED_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITH_PARTITION_STORAGE_ENGINE=1 //支持数据库分区
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
-DWITH_READLINE=ON
-DCOMPILATION_COMMENT='Zhaofx for mysqltest' //
-DEXTRA_CHARSETS=all //使MySQL支持所有的扩展字符
-DDEFAULT_CHARSET=utf8 //设置MySQL的默认字符集为utf8
-DDEFAULT_COLLATION=utf8_general_ci //设置默认字符集校对规则
-DWITH_SYSTEMD=1 //可以使用systemd控制mysql服务
-DWITH_BOOST=/usr/local/boost //指向boost库所在目录
-DWITH_EXTRA_CHARSETS=all
-DWITH_ZLIB=bundled
-DWITH_SSL=bundled
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DENABLED_LOCAL_INFILE=1
-DWITH_EMBEDDED_SERVER=1
-DENABLE_DOWNLOADS=1
-DWITH_DEBUG=0
MySQL学习之路 一 : MySQL 5.7.19 源码安装的更多相关文章
- ExtJS学习之路第四步:看源码,实战MessageBox
可以通过看MessageBox.js的源码来深入认识,记住它的主要用法.Ext.MessageBox是实用类,用于生成不同风格的消息框,它是Singleton(单例),别名Ext.Msg.注意Mess ...
- MySQL学习之路(一)——初涉MySQL。
MySQL学习之路(一) 1.1MySQL的概述 MySQL由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一个开源的关系型数据库管理系统. MySQL分为社区版和企业版. 1 ...
- MySQL学习(一)——Java连接MySql数据库
MySQL学习(一)——Java连接MySql数据库 API详解: 获得语句执行 String sql = "Insert into category(cid, cname) values( ...
- linux源码安装mysql,shell编程学习,ubuntu
一.mysql安装 以源码安装的方式编译和安装Mysql 5.6. 1.卸载旧版本 rpm -qa | grep mysql 检查是否有旧版本 查询结果:mysql-libs-5.1.73-7.el6 ...
- Centos7源码安装mysql及读写分离,互为主从
Linux服务器 -源码安装mysql 及读写分离,互为主从 一.环境介绍: Linux版本: CentOS 7 64位 mysq版本: mysql-5.6.26 这是我安装时所使用的版本, ...
- Linux MySQL源码安装缺少ncurses-devel包
在Red Hat Enterprise Linux Server release 5.7 上用源码安装MySQL-5.6.23时,遇到了" remove CMakeCache.txt and ...
- centos 6x系统下源码安装mysql操作记录
在运维工作中经常部署各种运维环境,涉及mysql数据库的安装也是时常需要的.mysql数据库安装可以选择yum在线安装,但是这种安装的mysql一般是系统自带的,版本方面可能跟需求不太匹配.可以通过源 ...
- mysql 在cento下源码安装
虚拟机改为网络地址转换 (NAT) service network restartping www.baidu.com rpm -qa | grep mysql 有的话通过下面的命令来卸载掉 rpm ...
- CentOS 7下源码安装MySQL 5.6
本文转载,并非原创. 目录 准备工作 运行环境 确认你的安装版本 下载MySQL 安装MySQL 准备安装环境 编译和安装 配置MySQL 单实例配置 单实例配置方法 添加防火墙 启动MySQL 重启 ...
随机推荐
- ZJNU 1130 - 龟兔赛跑——中高级
只需求出乌龟最短耗时跟兔子耗时比即可将起点 0 和终点 N+1 也看做充电站,进行动态规划对第i个点进行动态规划,则可以得到状态转移方程为dp[i] = max{dp[j]+time[i][j]} j ...
- django项目班笔记-注册功能
目录 一.用户模型设计 1.用户表字段分析 2.用户模式设计 二.执行迁移 三.图形验证码 四.将图形验证加入到前端文件中 验证码生成源码:https://files.cnblogs.com/file ...
- Spring Cloud服务的注册与发现(Eureka)
一.spring cloud简介 spring cloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理.服务发现.断路器.路由.微代理.事件总线.全局锁.决策竞选.分布式会话等等.它运 ...
- python语法基础-并发编程-线程-长期维护
############### 线程和GIL,全局解释器锁 ############## """ 线程 为什么会有进程? 主要是能够同时处理多个任务,多个任务还 ...
- AJAX数据传输
AJAX = Asynchronous JavaScript and XML(异步的Javascript和XML) AJAX最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页 ...
- sql查询语句解析过程--根据网络资料整理
查询语句: (8)SELECT(9)DISTINCT(11)<TopNum> <selectlist> (1)FROM<left_table> (3)<joi ...
- iOS简单音乐实现、React-Native完整项目、仿闲鱼京东列表分页、语音识别、网络加载过度动画等源码
iOS精选源码 iOS快速入手语音识别.听写.评测.播报 网络加载数据的过渡动画(仿简书网页) iOS 封装跑马灯和轮播效果 crash防护组件,适用常见常用的数组,字典等crash保护 iOS:高仿 ...
- ADB命令-1
1.adb -s 指定设备号(用于已连接多个设备时) 2.adb install -r -t xxx 安装程序 3.adb pull 设备目录 本地目录 复制文件命令 4.adb push 向设 ...
- JS UTC 昨天
var birthday = new Date("Jan 01, 1983 01:15:00") var formatDate = function (date) { ...
- The 2019 Asia Nanchang First Round Online Programming Contest C(cf原题,线段树维护矩阵)
题:https://nanti.jisuanke.com/t/41350 分析:先将字符串转置过来 状态转移,因为只有5个状态,所以 i 状态到 j 状态的最小代价就枚举[i][k]->[k][ ...